mirror of
https://gitlab.gnome.org/GNOME/gtk.git
synced 2025-01-15 06:40:08 +00:00
revealer: Add swing transitions
And make the revealer on page 2 of the widget-factory use one.
This commit is contained in:
parent
1513bf4174
commit
ad5c5d477e
@ -1432,6 +1432,7 @@ Suspendisse feugiat quam quis dolor accumsan cursus.</property>
|
|||||||
<object class="GtkOverlay" id="page2">
|
<object class="GtkOverlay" id="page2">
|
||||||
<child type="overlay">
|
<child type="overlay">
|
||||||
<object class="GtkRevealer" id="page2revealer">
|
<object class="GtkRevealer" id="page2revealer">
|
||||||
|
<property name="transition-type">swing-down</property>
|
||||||
<property name="halign">center</property>
|
<property name="halign">center</property>
|
||||||
<property name="valign">start</property>
|
<property name="valign">start</property>
|
||||||
<child>
|
<child>
|
||||||
|
@ -66,6 +66,10 @@
|
|||||||
* @GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT: Slide in from the right
|
* @GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT: Slide in from the right
|
||||||
* @GTK_REVEALER_TRANSITION_TYPE_SLIDE_UP: Slide in from the bottom
|
* @GTK_REVEALER_TRANSITION_TYPE_SLIDE_UP: Slide in from the bottom
|
||||||
* @GTK_REVEALER_TRANSITION_TYPE_SLIDE_DOWN: Slide in from the top
|
* @GTK_REVEALER_TRANSITION_TYPE_SLIDE_DOWN: Slide in from the top
|
||||||
|
* @GTK_REVEALER_TRANSITION_TYPE_SWING_RIGHT: Floop in from the left
|
||||||
|
* @GTK_REVEALER_TRANSITION_TYPE_SWING_LEFT: Floop in from the right
|
||||||
|
* @GTK_REVEALER_TRANSITION_TYPE_SWING_UP: Floop in from the bottom
|
||||||
|
* @GTK_REVEALER_TRANSITION_TYPE_SWING_DOWN: Floop in from the top
|
||||||
*
|
*
|
||||||
* These enumeration values describe the possible transitions
|
* These enumeration values describe the possible transitions
|
||||||
* when the child of a #GtkRevealer widget is shown or hidden.
|
* when the child of a #GtkRevealer widget is shown or hidden.
|
||||||
@ -287,6 +291,10 @@ effective_transition (GtkRevealer *revealer)
|
|||||||
return GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT;
|
return GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT;
|
||||||
else if (priv->transition_type == GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT)
|
else if (priv->transition_type == GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT)
|
||||||
return GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT;
|
return GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT;
|
||||||
|
if (priv->transition_type == GTK_REVEALER_TRANSITION_TYPE_SWING_LEFT)
|
||||||
|
return GTK_REVEALER_TRANSITION_TYPE_SWING_RIGHT;
|
||||||
|
else if (priv->transition_type == GTK_REVEALER_TRANSITION_TYPE_SWING_RIGHT)
|
||||||
|
return GTK_REVEALER_TRANSITION_TYPE_SWING_LEFT;
|
||||||
}
|
}
|
||||||
|
|
||||||
return priv->transition_type;
|
return priv->transition_type;
|
||||||
@ -328,6 +336,20 @@ get_child_size_scale (GtkRevealer *revealer,
|
|||||||
else
|
else
|
||||||
return 1.0;
|
return 1.0;
|
||||||
|
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SWING_RIGHT:
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SWING_LEFT:
|
||||||
|
if (orientation == GTK_ORIENTATION_HORIZONTAL)
|
||||||
|
return sin (G_PI * priv->current_pos / 2);
|
||||||
|
else
|
||||||
|
return 1.0;
|
||||||
|
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SWING_DOWN:
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SWING_UP:
|
||||||
|
if (orientation == GTK_ORIENTATION_VERTICAL)
|
||||||
|
return sin (G_PI * priv->current_pos / 2);
|
||||||
|
else
|
||||||
|
return 1.0;
|
||||||
|
|
||||||
case GTK_REVEALER_TRANSITION_TYPE_NONE:
|
case GTK_REVEALER_TRANSITION_TYPE_NONE:
|
||||||
case GTK_REVEALER_TRANSITION_TYPE_CROSSFADE:
|
case GTK_REVEALER_TRANSITION_TYPE_CROSSFADE:
|
||||||
default:
|
default:
|
||||||
@ -342,14 +364,18 @@ gtk_revealer_real_size_allocate (GtkWidget *widget,
|
|||||||
int baseline)
|
int baseline)
|
||||||
{
|
{
|
||||||
GtkRevealer *revealer = GTK_REVEALER (widget);
|
GtkRevealer *revealer = GTK_REVEALER (widget);
|
||||||
|
GtkRevealerPrivate *priv = gtk_revealer_get_instance_private (revealer);
|
||||||
GtkWidget *child;
|
GtkWidget *child;
|
||||||
|
|
||||||
child = gtk_bin_get_child (GTK_BIN (revealer));
|
child = gtk_bin_get_child (GTK_BIN (revealer));
|
||||||
if (child != NULL && gtk_widget_get_visible (child))
|
if (child != NULL && gtk_widget_get_visible (child))
|
||||||
{
|
{
|
||||||
GtkAllocation child_allocation = {0, 0, width, height};
|
GskTransform *transform;
|
||||||
double hscale, vscale;
|
double hscale, vscale;
|
||||||
|
int child_width, child_height;
|
||||||
|
|
||||||
|
child_width = width;
|
||||||
|
child_height = height;
|
||||||
hscale = get_child_size_scale (revealer, GTK_ORIENTATION_HORIZONTAL);
|
hscale = get_child_size_scale (revealer, GTK_ORIENTATION_HORIZONTAL);
|
||||||
vscale = get_child_size_scale (revealer, GTK_ORIENTATION_VERTICAL);
|
vscale = get_child_size_scale (revealer, GTK_ORIENTATION_VERTICAL);
|
||||||
|
|
||||||
@ -362,17 +388,61 @@ gtk_revealer_real_size_allocate (GtkWidget *widget,
|
|||||||
else if (hscale < 1.0)
|
else if (hscale < 1.0)
|
||||||
{
|
{
|
||||||
g_assert (vscale == 1.0);
|
g_assert (vscale == 1.0);
|
||||||
child_allocation.width = MIN (G_MAXINT, ceil (width / hscale));
|
child_width = MIN (G_MAXINT, ceil (width / hscale));
|
||||||
if (effective_transition (revealer) == GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT)
|
|
||||||
child_allocation.x = width - child_allocation.width;
|
|
||||||
}
|
}
|
||||||
else if (vscale < 1.0)
|
else if (vscale < 1.0)
|
||||||
{
|
{
|
||||||
child_allocation.height = MIN (G_MAXINT, ceil (height / vscale));
|
child_height = MIN (G_MAXINT, ceil (height / vscale));
|
||||||
if (effective_transition (revealer) == GTK_REVEALER_TRANSITION_TYPE_SLIDE_DOWN)
|
|
||||||
child_allocation.y = height - child_allocation.height;
|
|
||||||
}
|
}
|
||||||
gtk_widget_size_allocate (child, &child_allocation, -1);
|
|
||||||
|
transform = NULL;
|
||||||
|
switch (effective_transition (revealer))
|
||||||
|
{
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT:
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (width - child_width, 0));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SLIDE_DOWN:
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (0, height - child_height));
|
||||||
|
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SWING_LEFT:
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (width, height / 2));
|
||||||
|
transform = gsk_transform_perspective (transform, 2 * MAX (width, height));
|
||||||
|
transform = gsk_transform_rotate_3d (transform, -90 * (1.0 - priv->current_pos), graphene_vec3_y_axis ());
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (- child_width, - child_height / 2));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SWING_RIGHT:
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (0, height / 2));
|
||||||
|
transform = gsk_transform_perspective (transform, 2 * MAX (width, height));
|
||||||
|
transform = gsk_transform_rotate_3d (transform, 90 * (1.0 - priv->current_pos), graphene_vec3_y_axis ());
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (0, - child_height / 2));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SWING_DOWN:
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (width / 2, 0));
|
||||||
|
transform = gsk_transform_perspective (transform, 2 * MAX (width, height));
|
||||||
|
transform = gsk_transform_rotate_3d (transform, -90 * (1.0 - priv->current_pos), graphene_vec3_x_axis ());
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (- child_width / 2, 0));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SWING_UP:
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (width / 2, height));
|
||||||
|
transform = gsk_transform_perspective (transform, 2 * MAX (width, height));
|
||||||
|
transform = gsk_transform_rotate_3d (transform, 90 * (1.0 - priv->current_pos), graphene_vec3_x_axis ());
|
||||||
|
transform = gsk_transform_translate (transform, &GRAPHENE_POINT_INIT (- child_width / 2, - child_height));
|
||||||
|
break;
|
||||||
|
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_NONE:
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_CROSSFADE:
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT:
|
||||||
|
case GTK_REVEALER_TRANSITION_TYPE_SLIDE_UP:
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
gtk_widget_allocate (child, child_width, child_height, -1, transform);
|
||||||
|
gsk_transform_unref (transform);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,7 +43,11 @@ typedef enum {
|
|||||||
GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT,
|
GTK_REVEALER_TRANSITION_TYPE_SLIDE_RIGHT,
|
||||||
GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT,
|
GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT,
|
||||||
GTK_REVEALER_TRANSITION_TYPE_SLIDE_UP,
|
GTK_REVEALER_TRANSITION_TYPE_SLIDE_UP,
|
||||||
GTK_REVEALER_TRANSITION_TYPE_SLIDE_DOWN
|
GTK_REVEALER_TRANSITION_TYPE_SLIDE_DOWN,
|
||||||
|
GTK_REVEALER_TRANSITION_TYPE_SWING_RIGHT,
|
||||||
|
GTK_REVEALER_TRANSITION_TYPE_SWING_LEFT,
|
||||||
|
GTK_REVEALER_TRANSITION_TYPE_SWING_UP,
|
||||||
|
GTK_REVEALER_TRANSITION_TYPE_SWING_DOWN
|
||||||
} GtkRevealerTransitionType;
|
} GtkRevealerTransitionType;
|
||||||
|
|
||||||
struct _GtkRevealer {
|
struct _GtkRevealer {
|
||||||
|
Loading…
Reference in New Issue
Block a user