[gtk+/wip/baedert/gtkimageview: 2063/2075] Use gtk_image_view_replace_image



commit 96dae0b0f446b66d750f8e549bf3b2d6e053bf71
Author: Timm Bäder <mail baedert org>
Date:   Fri Feb 26 16:00:07 2016 +0100

    Use gtk_image_view_replace_image

 gtk/gtkabstractimage.c |    3 +-
 gtk/gtkimageview.c     |   79 ++++++++++++++++++++----------------------------
 2 files changed, 34 insertions(+), 48 deletions(-)
---
diff --git a/gtk/gtkabstractimage.c b/gtk/gtkabstractimage.c
index 6b71048..4ba1bb6 100644
--- a/gtk/gtkabstractimage.c
+++ b/gtk/gtkabstractimage.c
@@ -174,8 +174,7 @@ gtk_pixbuf_animation_image_get_height (GtkAbstractImage *image)
 static int
 gtk_pixbuf_animation_image_get_scale_factor (GtkAbstractImage *image)
 {
-  /*return GTK_PIXBUF_ANIMATION_IMAGE (image)->scale_factor;*/
-  return 1;
+  return GTK_PIXBUF_ANIMATION_IMAGE (image)->scale_factor;
 }
 
 static gboolean
diff --git a/gtk/gtkimageview.c b/gtk/gtkimageview.c
index ebc399c..95d9d85 100644
--- a/gtk/gtkimageview.c
+++ b/gtk/gtkimageview.c
@@ -264,10 +264,17 @@ gtk_image_view_transitions_enabled (GtkImageView *image_view)
                 "gtk-enable-animations", &animations_enabled,
                 NULL);
 
-  /*return priv->transitions_enabled && animations_enabled && priv->image_surface;*/
   return priv->transitions_enabled && animations_enabled && priv->image;
 }
 
+void
+image_changed_cb (GtkAbstractImage *image, gpointer user_data)
+{
+  GtkImageView *image_view = user_data;
+
+  gtk_widget_queue_draw (GTK_WIDGET (image_view));
+}
+
 static gboolean
 scale_frameclock_cb (GtkWidget     *widget,
                      GdkFrameClock *frame_clock,
@@ -2107,21 +2114,35 @@ gtk_image_view_replace_image (GtkImageView     *image_view,
   GtkImageViewPrivate *priv = gtk_image_view_get_instance_private (image_view);
 
   if (priv->image)
-    g_object_unref (priv->image);
+    {
+      g_signal_handlers_disconnect_by_func (priv->image, image_changed_cb, image_view);
+      g_object_unref (priv->image);
+    }
 
-  /* TODO: How to do that? */
-  /*if (scale_factor == 0)*/
-    /*priv->scale_factor = gtk_widget_get_scale_factor (GTK_WIDGET (image_view));*/
-  /*else*/
-    /*priv->scale_factor = scale_factor;*/
+  /* TODO: Handle scale-factor 0 */
 
-  /* TODO: Set size_valid depending on the size changing... */
+  if (!image ^ !priv->image ||
+      (gtk_abstract_image_get_width (image)  != gtk_abstract_image_get_width (priv->image) ||
+       gtk_abstract_image_get_height (image) != gtk_abstract_image_get_height (priv->image) ||
+       gtk_abstract_image_get_scale_factor (image) != gtk_abstract_image_get_scale_factor (priv->image)))
+    {
+      priv->size_valid = FALSE;
+    }
 
   priv->image = image;
-  priv->size_valid = FALSE;
 
   if (priv->image)
-    g_object_ref (priv->image);
+    {
+      g_object_ref (priv->image);
+      g_signal_connect (priv->image, "changed", G_CALLBACK (image_changed_cb), image_view);
+    }
+
+  gtk_image_view_update_adjustments (image_view);
+
+  if (priv->fit_allocation)
+    gtk_widget_queue_draw (GTK_WIDGET (image_view));
+  else
+    gtk_widget_queue_resize (GTK_WIDGET (image_view));
 }
 
 static void
@@ -2151,6 +2172,7 @@ gtk_image_view_load_image_from_stream (GtkImageView *image_view,
         }
       else
         {
+          /* Takes ownership of @result */
           image = GTK_ABSTRACT_IMAGE (gtk_pixbuf_animation_image_new (result, scale_factor));
         }
 
@@ -2357,7 +2379,6 @@ gtk_image_view_set_pixbuf (GtkImageView    *image_view,
                            int              scale_factor)
 {
   GtkPixbufImage *image;
-  /*GtkImageViewPrivate *priv = gtk_image_view_get_instance_private (image_view);*/
 
   g_return_if_fail (GTK_IS_IMAGE_VIEW (image_view));
   g_return_if_fail (GDK_IS_PIXBUF (pixbuf));
@@ -2383,32 +2404,13 @@ void
 gtk_image_view_set_surface (GtkImageView    *image_view,
                             cairo_surface_t *surface)
 {
-  GtkImageViewPrivate *priv = gtk_image_view_get_instance_private (image_view);
   GtkSurfaceImage *image;
-  double scale_x = 0.0;
-  double scale_y;
 
   g_return_if_fail (GTK_IS_IMAGE_VIEW (image_view));
 
-  if (surface)
-    {
-      g_return_if_fail (cairo_surface_get_type (surface) == CAIRO_SURFACE_TYPE_IMAGE);
-
-      cairo_surface_get_device_scale (surface, &scale_x, &scale_y);
-
-      g_return_if_fail (scale_x == scale_y);
-    }
-
   image = gtk_surface_image_new (surface);
 
   gtk_image_view_replace_image (image_view, GTK_ABSTRACT_IMAGE (image));
-
-  gtk_image_view_update_adjustments (image_view);
-
-  if (priv->fit_allocation)
-    gtk_widget_queue_draw (GTK_WIDGET (image_view));
-  else
-    gtk_widget_queue_resize (GTK_WIDGET (image_view));
 }
 
 /**
@@ -2439,26 +2441,11 @@ gtk_image_view_set_animation (GtkImageView       *image_view,
 }
 
 void
-image_changed_cb (GtkAbstractImage *image, gpointer user_data)
-{
-  GtkImageView *image_view = user_data;
-
-  gtk_widget_queue_draw (GTK_WIDGET (image_view));
-}
-
-void
 gtk_image_view_set_abstract_image (GtkImageView     *image_view,
                                    GtkAbstractImage *abstract_image)
 {
-  GtkImageViewPrivate *priv = gtk_image_view_get_instance_private (image_view);
-
   g_return_if_fail (GTK_IS_IMAGE_VIEW (image_view));
   g_return_if_fail (GTK_IS_ABSTRACT_IMAGE (abstract_image));
 
-  priv->image = abstract_image;
-
-  g_signal_connect (G_OBJECT (priv->image),
-                    "changed", G_CALLBACK (image_changed_cb), image_view);
-
-  gtk_widget_queue_resize (GTK_WIDGET (image_view));
+  gtk_image_view_replace_image (image_view, abstract_image);
 }


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]