forked from AuroraMiddleware/gtk
widget: Make gtk_widget_allocate() take a GtkTransform
We can reason about GtkTransform way better - and determine its category or do equality checks.
This commit is contained in:
parent
49d83820a2
commit
c24f32619f
@ -47,8 +47,8 @@
|
||||
#include "gtkgesturesingle.h"
|
||||
#include "gtkgestureswipe.h"
|
||||
#include "gtkintl.h"
|
||||
#include "gtkmarshalers.h"
|
||||
#include "gtkmain.h"
|
||||
#include "gtkmarshalers.h"
|
||||
#include "gtkmenu.h"
|
||||
#include "gtkpopover.h"
|
||||
#include "gtkprivate.h"
|
||||
@ -61,6 +61,7 @@
|
||||
#include "gtksnapshotprivate.h"
|
||||
#include "gtkstylecontextprivate.h"
|
||||
#include "gtktooltipprivate.h"
|
||||
#include "gtktransform.h"
|
||||
#include "gtktypebuiltins.h"
|
||||
#include "gtkversion.h"
|
||||
#include "gtkwidgetpaintableprivate.h"
|
||||
@ -4164,15 +4165,20 @@ gtk_widget_size_allocate (GtkWidget *widget,
|
||||
const GtkAllocation *allocation,
|
||||
int baseline)
|
||||
{
|
||||
graphene_matrix_t transform;
|
||||
GtkTransform *transform;
|
||||
|
||||
if (allocation->x || allocation->y)
|
||||
transform = gtk_transform_translate (NULL, &GRAPHENE_POINT_INIT (allocation->x, allocation->y));
|
||||
else
|
||||
transform = NULL;
|
||||
|
||||
graphene_matrix_init_translate (&transform,
|
||||
&GRAPHENE_POINT3D_INIT (allocation->x, allocation->y, 0));
|
||||
gtk_widget_allocate (widget,
|
||||
allocation->width,
|
||||
allocation->height,
|
||||
baseline,
|
||||
&transform);
|
||||
transform);
|
||||
|
||||
gtk_transform_unref (transform);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -4181,7 +4187,7 @@ gtk_widget_size_allocate (GtkWidget *widget,
|
||||
* @width: New width of @widget
|
||||
* @height: New height of @widget
|
||||
* @baseline: New baseline of @widget, or -1
|
||||
* @transform: Transformation to be applied to @widget
|
||||
* @transform: (transfer none) (allow-none): Transformation to be applied to @widget
|
||||
*
|
||||
* This function is only used by #GtkWidget subclasses, to assign a size,
|
||||
* position and (optionally) baseline to their child widgets.
|
||||
@ -4197,7 +4203,7 @@ gtk_widget_allocate (GtkWidget *widget,
|
||||
int width,
|
||||
int height,
|
||||
int baseline,
|
||||
const graphene_matrix_t *transform)
|
||||
GtkTransform *transform)
|
||||
{
|
||||
GtkWidgetPrivate *priv = gtk_widget_get_instance_private (widget);
|
||||
GdkRectangle adjusted;
|
||||
@ -4209,11 +4215,13 @@ gtk_widget_allocate (GtkWidget *widget,
|
||||
gint min_width, min_height;
|
||||
GtkCssStyle *style;
|
||||
GtkBorder margin, border, padding;
|
||||
graphene_matrix_t transform_matrix;
|
||||
#ifdef G_ENABLE_DEBUG
|
||||
GdkDisplay *display;
|
||||
#endif
|
||||
|
||||
g_return_if_fail (GTK_IS_WIDGET (widget));
|
||||
g_return_if_fail (baseline >= -1);
|
||||
g_return_if_fail (transform != NULL);
|
||||
|
||||
gtk_widget_push_verify_invariants (widget);
|
||||
|
||||
@ -4243,11 +4251,12 @@ gtk_widget_allocate (GtkWidget *widget,
|
||||
baseline_changed = priv->allocated_size_baseline != baseline;
|
||||
size_changed = (priv->allocated_width != width ||
|
||||
priv->allocated_height != height);
|
||||
transform_changed = memcmp (&priv->allocated_transform,
|
||||
transform,
|
||||
sizeof (graphene_matrix_t)) != 0;
|
||||
transform_changed = !gtk_transform_equal (priv->allocated_transform, transform);
|
||||
|
||||
graphene_matrix_init_from_matrix (&priv->allocated_transform, transform);
|
||||
/* order is important, sometimes priv->allocated_transform == transform */
|
||||
gtk_transform_ref (transform);
|
||||
gtk_transform_unref (priv->allocated_transform);
|
||||
priv->allocated_transform = transform;
|
||||
priv->allocated_width = width;
|
||||
priv->allocated_height = height;
|
||||
priv->allocated_size_baseline = baseline;
|
||||
@ -4337,7 +4346,8 @@ gtk_widget_allocate (GtkWidget *widget,
|
||||
baseline -= margin.top + border.top + padding.top;
|
||||
|
||||
graphene_matrix_init_translate (&priv->transform, &GRAPHENE_POINT3D_INIT (adjusted.x, adjusted.y, 0));
|
||||
graphene_matrix_multiply (&priv->transform, transform, &priv->transform);
|
||||
gtk_transform_to_matrix (transform, &transform_matrix);
|
||||
graphene_matrix_multiply (&priv->transform, &transform_matrix, &priv->transform);
|
||||
|
||||
if (!alloc_needed && !size_changed && !baseline_changed)
|
||||
{
|
||||
@ -6217,7 +6227,7 @@ _gtk_widget_set_visible_flag (GtkWidget *widget,
|
||||
|
||||
if (!visible)
|
||||
{
|
||||
graphene_matrix_init_identity (&priv->allocated_transform);
|
||||
g_clear_pointer (&priv->allocated_transform, gtk_transform_unref);
|
||||
priv->allocated_width = 0;
|
||||
priv->allocated_height = 0;
|
||||
priv->allocated_size_baseline = 0;
|
||||
@ -11929,7 +11939,7 @@ gtk_widget_ensure_allocate (GtkWidget *widget)
|
||||
priv->allocated_width,
|
||||
priv->allocated_height,
|
||||
priv->allocated_size_baseline,
|
||||
&priv->allocated_transform);
|
||||
priv->allocated_transform);
|
||||
}
|
||||
else if (priv->alloc_needed_on_child)
|
||||
{
|
||||
|
@ -416,7 +416,7 @@ void gtk_widget_allocate (GtkWidget *widget,
|
||||
int width,
|
||||
int height,
|
||||
int baseline,
|
||||
const graphene_matrix_t *transform);
|
||||
GtkTransform *transform);
|
||||
|
||||
GDK_AVAILABLE_IN_ALL
|
||||
GtkSizeRequestMode gtk_widget_get_request_mode (GtkWidget *widget);
|
||||
|
@ -144,7 +144,7 @@ struct _GtkWidgetPrivate
|
||||
GtkStyleContext *context;
|
||||
|
||||
/* The widget's allocated size */
|
||||
graphene_matrix_t allocated_transform;
|
||||
GtkTransform *allocated_transform;
|
||||
int allocated_width;
|
||||
int allocated_height;
|
||||
gint allocated_size_baseline;
|
||||
|
@ -104,7 +104,7 @@ gtk_transform_tester_size_allocate (GtkWidget *widget,
|
||||
int baseline)
|
||||
{
|
||||
GtkTransformTester *self = (GtkTransformTester *)widget;
|
||||
graphene_matrix_t global_transform;
|
||||
GtkTransform *global_transform;
|
||||
int w, h;
|
||||
|
||||
if (!self->test_widget)
|
||||
@ -119,24 +119,18 @@ gtk_transform_tester_size_allocate (GtkWidget *widget,
|
||||
|
||||
g_message ("%s: %d, %d", __FUNCTION__, w, h);
|
||||
|
||||
graphene_matrix_init_identity (&global_transform);
|
||||
global_transform = NULL;
|
||||
|
||||
graphene_matrix_translate (&global_transform, &(graphene_point3d_t){ -w/2.0f, -h/2.0f, 0});
|
||||
graphene_matrix_rotate (&global_transform, scale,
|
||||
graphene_vec3_z_axis ());
|
||||
global_transform = gtk_transform_translate (global_transform, &GRAPHENE_POINT_INIT (width / 2.0f, height / 2.0f));
|
||||
global_transform = gtk_transform_rotate (global_transform, scale);
|
||||
global_transform = gtk_transform_translate (global_transform, &GRAPHENE_POINT_INIT (-w / 2.0f, -h / 2.0f));
|
||||
|
||||
graphene_matrix_translate (&global_transform, &(graphene_point3d_t){ width / 2.0f, height / 2.0f, 0});
|
||||
|
||||
|
||||
#if 0
|
||||
gtk_widget_size_allocate (self->test_widget,
|
||||
&(GtkAllocation){ (width- w) / 2, (height - h) / 2, w,h }, -1);
|
||||
#else
|
||||
gtk_widget_allocate (self->test_widget,
|
||||
w, h,
|
||||
-1,
|
||||
&global_transform);
|
||||
#endif
|
||||
global_transform);
|
||||
|
||||
gtk_transform_unref (global_transform);
|
||||
}
|
||||
|
||||
static void
|
||||
|
Loading…
Reference in New Issue
Block a user