diff options
author | G.Willems <g.willems.dev@laposte.net> | 2023-04-11 23:53:35 +0200 |
---|---|---|
committer | G.Willems <g.willems.dev@laposte.net> | 2023-04-11 23:54:06 +0200 |
commit | d625ff81061f9627c6ad2b5d1f1e78c93c424252 (patch) | |
tree | bd4ee54f9674ce425a04e1788844da0c2826ddcb | |
parent | 5ecd8a1c102e4eaf02ecc0c38f0eded370660e0f (diff) | |
download | gtk+-d625ff81061f9627c6ad2b5d1f1e78c93c424252.tar.gz |
scalebutton: fix orientation not applied to scale
-rw-r--r-- | gtk/gtkscalebutton.c | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/gtk/gtkscalebutton.c b/gtk/gtkscalebutton.c index d7c61a2314..4b7617a479 100644 --- a/gtk/gtkscalebutton.c +++ b/gtk/gtkscalebutton.c @@ -817,6 +817,40 @@ gtk_scale_button_get_active (GtkScaleButton *button) } static void +apply_orientation (GtkScaleButton *button, + GtkOrientation orientation) +{ + GtkScaleButtonPrivate *priv = gtk_scale_button_get_instance_private (button); + + if (priv->applied_orientation != orientation) + { + priv->applied_orientation = orientation; + + gtk_orientable_set_orientation (GTK_ORIENTABLE (priv->box), orientation); + gtk_orientable_set_orientation (GTK_ORIENTABLE (priv->scale), orientation); + + if (orientation == GTK_ORIENTATION_VERTICAL) + { + gtk_box_reorder_child_after (GTK_BOX (priv->box), priv->scale, + priv->plus_button); + gtk_box_reorder_child_after (GTK_BOX (priv->box), priv->minus_button, + priv->scale); + gtk_widget_set_size_request (GTK_WIDGET (priv->scale), -1, SCALE_SIZE); + gtk_range_set_inverted (GTK_RANGE (priv->scale), TRUE); + } + else + { + gtk_box_reorder_child_after (GTK_BOX (priv->box), priv->scale, + priv->minus_button); + gtk_box_reorder_child_after (GTK_BOX (priv->box), priv->plus_button, + priv->scale); + gtk_widget_set_size_request (GTK_WIDGET (priv->scale), SCALE_SIZE, -1); + gtk_range_set_inverted (GTK_RANGE (priv->scale), FALSE); + } + } +} + +static void gtk_scale_button_set_orientation_private (GtkScaleButton *button, GtkOrientation orientation) { @@ -825,6 +859,9 @@ gtk_scale_button_set_orientation_private (GtkScaleButton *button, if (priv->orientation != orientation) { priv->orientation = orientation; + + apply_orientation (button, priv->orientation); + g_object_notify (G_OBJECT (button), "orientation"); } } @@ -861,6 +898,8 @@ gtk_scale_popup (GtkWidget *widget) GtkScaleButton *button = GTK_SCALE_BUTTON (widget); GtkScaleButtonPrivate *priv = gtk_scale_button_get_instance_private (button); + apply_orientation (button, priv->orientation); + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (priv->button), TRUE); } |