[gtk+/wip/baedert/gtkimageview: 30/31] GtkImageView: Implement first 'scale to pointer' version
- From: Timm Bäder <baedert src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/baedert/gtkimageview: 30/31] GtkImageView: Implement first 'scale to pointer' version
- Date: Mon, 10 Aug 2015 04:38:38 +0000 (UTC)
commit 9c35bc812655429ac515fa4df5431afacd4d337e
Author: Timm Bäder <mail baedert org>
Date: Fri Aug 7 14:28:24 2015 +0200
GtkImageView: Implement first 'scale to pointer' version
Works if values == 0
gtk/gtkimageview.c | 78 ++++++++++++++++++++++++++++++++++++----------------
1 files changed, 54 insertions(+), 24 deletions(-)
---
diff --git a/gtk/gtkimageview.c b/gtk/gtkimageview.c
index d52d685..de89d43 100644
--- a/gtk/gtkimageview.c
+++ b/gtk/gtkimageview.c
@@ -110,7 +110,7 @@ struct _LoadTaskData
static void
free_load_task_data (LoadTaskData *data)
{
- g_clear_object ((&data->source));
+ g_clear_object (&data->source);
}
static void
@@ -535,7 +535,7 @@ gtk_image_view_draw (GtkWidget *widget, cairo_t *ct)
#if 1
- g_message ("old_x: %d,old_y: %d", _old_x, _old_y);
+ /*g_message ("old_x: %d,old_y: %d", _old_x, _old_y);*/
cairo_set_source_rgba (ct, 1, 0, 0, 1);
cairo_rectangle (ct, _old_x - 2, _old_y - 2, 4, 4);
cairo_fill (ct);
@@ -661,32 +661,53 @@ gtk_image_view_fix_point (GtkImageView *image_view,
int y_before)
{
GtkImageViewPrivate *priv = gtk_image_view_get_instance_private (image_view);
- int x_after;
- int y_after;
+ double x_after;
+ double y_after;
+ double x_value;
+ double y_value;
double scale_diff = priv->scale - scale_before;
g_assert (!(priv->hadjustment == NULL && priv->vadjustment == NULL));
- /* We need to take the point (x_before, y_before), which now got moved
- * around because we changed the scale (XXX and the adjustment value?!),
- * and we need to move that point (on the drawn surface) to where it
- * was before.
- */
+ x_value = gtk_adjustment_get_value (priv->hadjustment);
+ y_value = gtk_adjustment_get_value (priv->vadjustment);
- x_after = x_before + x_before * scale_diff;
- y_after = y_before + y_before * scale_diff;
+ /*x_after = (x_value + x_before) * (1 + scale_diff);*/
+ /*y_after = (y_value + y_before) * (1 + scale_diff);*/
-#if 1
- _old_x = x_before;
- _old_y = y_before;
+ x_after = (x_before) * (1 + scale_diff);
+ y_after = (y_before) * (1 + scale_diff);
+
+
+ double x_diff = x_after - (x_before);
+ double y_diff = y_after - (y_before);
+
+ g_message ("x_diff: %f", x_diff);
+ gtk_adjustment_set_value (priv->hadjustment,
+ x_value + x_diff);
+ gtk_adjustment_set_value (priv->vadjustment,
+ y_value + y_diff);
+ /*gtk_adjustment_set_value (priv->hadjustment,*/
+ /*x_value + x_diff);*/
+
+ /*gtk_adjustment_set_value (priv->vadjustment,*/
+ /*gtk_adjustment_get_value (priv->vadjustment) + y_diff);*/
+
+
+ gtk_widget_queue_draw ((GtkWidget *)image_view);
+
+#if 0
+ _old_x = x_before - gtk_adjustment_get_value (priv->hadjustment);
+ _old_y = y_before - gtk_adjustment_get_value (priv->vadjustment);
- _new_x = x_after;
- _new_y = y_after;
+
+ _new_x = x_after - gtk_adjustment_get_value (priv->hadjustment);
+ _new_y = y_after - gtk_adjustment_get_value (priv->vadjustment);
gtk_widget_queue_draw ((GtkWidget *)image_view);
@@ -713,6 +734,10 @@ gtk_image_view_set_scale (GtkImageView *image_view,
GtkImageViewPrivate *priv = gtk_image_view_get_instance_private (image_view);
g_return_if_fail (GTK_IS_IMAGE_VIEW (image_view));
+ /* XXX Do we have to do this here? */
+ scale = MAX (0, scale);
+
+
priv->scale = scale;
g_object_notify_by_pspec ((GObject *)image_view,
widget_props[PROP_SCALE]);
@@ -1069,8 +1094,6 @@ gtk_image_view_get_preferred_width (GtkWidget *widget,
}
-
-#define SCROLL_FACTOR (0.05)
static gboolean
gtk_image_view_scroll_event (GtkWidget *widget,
GdkEventScroll *event)
@@ -1085,18 +1108,22 @@ gtk_image_view_scroll_event (GtkWidget *widget,
gtk_image_view_set_scale (image_view, new_scale);
- if (priv->hadjustment)
- x += gtk_adjustment_get_value (priv->hadjustment);
+ /*if (priv->hadjustment)*/
+ /*x += gtk_adjustment_get_value (priv->hadjustment);*/
- if (priv->vadjustment)
- y += gtk_adjustment_get_value (priv->vadjustment);
+ /*if (priv->vadjustment)*/
+ /*y += gtk_adjustment_get_value (priv->vadjustment);*/
+
+
+ /*x += gtk_adjustment_get_value (priv->hadjustment);*/
+ /*y += gtk_adjustment_get_value (priv->vadjustment);*/
if (priv->hadjustment || priv->vadjustment)
gtk_image_view_fix_point (image_view, old_scale, x, y);
- return TRUE;
+ return GDK_EVENT_STOP;
}
/* }}} */
@@ -1632,6 +1659,7 @@ gtk_image_view_set_surface (GtkImageView *image_view,
{
GtkImageViewPrivate *priv = gtk_image_view_get_instance_private (image_view);
double scale_x = 0.0;
+ double scale_y;
g_return_if_fail (GTK_IS_IMAGE_VIEW (image_view));
@@ -1639,7 +1667,9 @@ gtk_image_view_set_surface (GtkImageView *image_view,
{
g_return_if_fail (cairo_surface_get_type (surface) == CAIRO_SURFACE_TYPE_IMAGE);
- cairo_surface_get_device_scale (surface, &scale_x, NULL);
+ cairo_surface_get_device_scale (surface, &scale_x, &scale_y);
+
+ g_return_if_fail (scale_x == scale_y);
}
else
{
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]