[gimp/gtk3-port: 229/444] libgimpwidgets: make GimpColorScale more-or-less work fine



commit 63f16f315a6336b9331b4c1645bab368622e7a06
Author: Michael Natterer <mitch gimp org>
Date:   Mon May 22 22:55:25 2017 +0200

    libgimpwidgets: make GimpColorScale more-or-less work fine
    
    also derive it from GtkRange directly not from GtkScale.

 libgimpwidgets/gimpcolorscale.c |  104 +++++++++++++++------------------------
 libgimpwidgets/gimpcolorscale.h |    4 +-
 libgimpwidgets/gimpscaleentry.c |    4 +-
 3 files changed, 44 insertions(+), 68 deletions(-)
---
diff --git a/libgimpwidgets/gimpcolorscale.c b/libgimpwidgets/gimpcolorscale.c
index a5cd506..9a17978 100644
--- a/libgimpwidgets/gimpcolorscale.c
+++ b/libgimpwidgets/gimpcolorscale.c
@@ -103,10 +103,6 @@ static void     gimp_color_scale_size_allocate       (GtkWidget        *widget,
                                                       GtkAllocation    *allocation);
 static void     gimp_color_scale_state_flags_changed (GtkWidget        *widget,
                                                       GtkStateFlags     previous_state);
-static gboolean gimp_color_scale_button_press        (GtkWidget        *widget,
-                                                      GdkEventButton   *event);
-static gboolean gimp_color_scale_button_release      (GtkWidget        *widget,
-                                                      GdkEventButton   *event);
 static gboolean gimp_color_scale_scroll              (GtkWidget        *widget,
                                                       GdkEventScroll   *event);
 static gboolean gimp_color_scale_draw                (GtkWidget        *widget,
@@ -123,7 +119,7 @@ static void     gimp_color_scale_notify_config       (GimpColorConfig  *config,
                                                       GimpColorScale   *scale);
 
 
-G_DEFINE_TYPE (GimpColorScale, gimp_color_scale, GTK_TYPE_SCALE)
+G_DEFINE_TYPE (GimpColorScale, gimp_color_scale, GTK_TYPE_RANGE)
 
 #define parent_class gimp_color_scale_parent_class
 
@@ -144,11 +140,11 @@ gimp_color_scale_class_init (GimpColorScaleClass *klass)
 
   widget_class->size_allocate        = gimp_color_scale_size_allocate;
   widget_class->state_flags_changed  = gimp_color_scale_state_flags_changed;
-  widget_class->button_press_event   = gimp_color_scale_button_press;
-  widget_class->button_release_event = gimp_color_scale_button_release;
   widget_class->scroll_event         = gimp_color_scale_scroll;
   widget_class->draw                 = gimp_color_scale_draw;
 
+  gtk_widget_class_set_css_name (widget_class, "GimpColorScale");
+
   /**
    * GimpColorScale:channel:
    *
@@ -178,12 +174,13 @@ gimp_color_scale_init (GimpColorScale *scale)
 {
   GimpColorScalePrivate *priv  = GET_PRIVATE (scale);
   GtkRange              *range = GTK_RANGE (scale);
+  GtkCssProvider        *css;
+
+  gtk_widget_set_can_focus (GTK_WIDGET (scale), TRUE);
 
   gtk_range_set_slider_size_fixed (range, TRUE);
   gtk_range_set_flippable (GTK_RANGE (scale), TRUE);
 
-  gtk_scale_set_draw_value (GTK_SCALE (scale), FALSE);
-
   priv->channel      = GIMP_COLOR_SELECTOR_VALUE;
   priv->needs_render = TRUE;
 
@@ -196,6 +193,22 @@ gimp_color_scale_init (GimpColorScale *scale)
   gimp_widget_track_monitor (GTK_WIDGET (scale),
                              G_CALLBACK (gimp_color_scale_destroy_transform),
                              NULL);
+
+  css = gtk_css_provider_new ();
+  gtk_css_provider_load_from_data (css,
+                                   "GimpColorScale contents {"
+                                   "  min-width:  24px;"
+                                   "  min-height: 24px;"
+                                   "}\n"
+                                   "GimpColorScale slider {"
+                                   "  min-width:  14px;"
+                                   "  min-height: 14px;"
+                                   "}",
+                                   -1, NULL);
+  gtk_style_context_add_provider (gtk_widget_get_style_context (GTK_WIDGET (scale)),
+                                  GTK_STYLE_PROVIDER (css),
+                                  GTK_STYLE_PROVIDER_PRIORITY_APPLICATION);
+  g_object_unref (css);
 }
 
 static void
@@ -267,11 +280,15 @@ gimp_color_scale_size_allocate (GtkWidget     *widget,
 {
   GimpColorScalePrivate *priv  = GET_PRIVATE (widget);
   GtkRange              *range = GTK_RANGE (widget);
+  GtkStyleContext       *style = gtk_widget_get_style_context (widget);
   GdkRectangle           range_rect;
   gint                   focus = 0;
   gint                   trough_border;
   gint                   scale_width;
   gint                   scale_height;
+  gint                   slider_start;
+  gint                   slider_end;
+  gint                   slider_size;
 
   gtk_widget_style_get (widget,
                         "trough-border", &trough_border,
@@ -288,14 +305,17 @@ gimp_color_scale_size_allocate (GtkWidget     *widget,
       focus += focus_padding;
     }
 
-  gtk_range_set_min_slider_size (range,
-                                 (MIN (allocation->width,
-                                       allocation->height) - 2 * focus) / 2);
+  gtk_range_set_min_slider_size (range, 14);
 
   if (GTK_WIDGET_CLASS (parent_class)->size_allocate)
     GTK_WIDGET_CLASS (parent_class)->size_allocate (widget, allocation);
 
   gtk_range_get_range_rect (range, &range_rect);
+  gtk_range_get_slider_range (range, &slider_start, &slider_end);
+  slider_size = slider_end - slider_start;
+
+  g_printerr ("slider_size = %d   min = %d\n",
+              slider_size, gtk_range_get_min_slider_size (range));
 
   scale_width  = range_rect.width  - 2 * (focus + trough_border);
   scale_height = range_rect.height - 2 * (focus + trough_border);
@@ -303,13 +323,13 @@ gimp_color_scale_size_allocate (GtkWidget     *widget,
   switch (gtk_orientable_get_orientation (GTK_ORIENTABLE (range)))
     {
     case GTK_ORIENTATION_HORIZONTAL:
-      scale_width  -= gtk_range_get_min_slider_size (range) - 1;
+      scale_width  -= slider_size / 2;
       scale_height -= 2;
       break;
 
     case GTK_ORIENTATION_VERTICAL:
       scale_width  -= 2;
-      scale_height -= gtk_range_get_min_slider_size (range) - 1;
+      scale_height -= slider_size / 2;
       break;
     }
 
@@ -343,52 +363,6 @@ gimp_color_scale_state_flags_changed (GtkWidget     *widget,
 }
 
 static gboolean
-gimp_color_scale_button_press (GtkWidget      *widget,
-                               GdkEventButton *event)
-{
-  if (event->button == 1)
-    {
-      GdkEventButton *my_event;
-      gboolean        retval;
-
-      my_event = (GdkEventButton *) gdk_event_copy ((GdkEvent *) event);
-      my_event->button = 2;
-
-      retval = GTK_WIDGET_CLASS (parent_class)->button_press_event (widget,
-                                                                    my_event);
-
-      gdk_event_free ((GdkEvent *) my_event);
-
-      return retval;
-    }
-
-  return GTK_WIDGET_CLASS (parent_class)->button_press_event (widget, event);
-}
-
-static gboolean
-gimp_color_scale_button_release (GtkWidget      *widget,
-                                 GdkEventButton *event)
-{
-  if (event->button == 1)
-    {
-      GdkEventButton *my_event;
-      gboolean        retval;
-
-      my_event = (GdkEventButton *) gdk_event_copy ((GdkEvent *) event);
-      my_event->button = 2;
-
-      retval = GTK_WIDGET_CLASS (parent_class)->button_release_event (widget,
-                                                                      my_event);
-
-      gdk_event_free ((GdkEvent *) my_event);
-
-      return retval;
-    }
-
-  return GTK_WIDGET_CLASS (parent_class)->button_release_event (widget, event);
-}
-
-static gboolean
 gimp_color_scale_scroll (GtkWidget      *widget,
                          GdkEventScroll *event)
 {
@@ -439,6 +413,7 @@ gimp_color_scale_draw (GtkWidget *widget,
   gint                   focus = 0;
   gint                   trough_border;
   gint                   slider_start;
+  gint                   slider_end;
   gint                   slider_size;
   gint                   x, y;
   gint                   w, h;
@@ -466,14 +441,15 @@ gimp_color_scale_draw (GtkWidget *widget,
     }
 
   gtk_range_get_range_rect (range, &range_rect);
-  gtk_range_get_slider_range (range, &slider_start, NULL);
+  gtk_range_get_slider_range (range, &slider_start, &slider_end);
+  slider_size = slider_end - slider_start;
 
   x = range_rect.x + focus;
   y = range_rect.y + focus;
   w = range_rect.width  - 2 * focus;
   h = range_rect.height - 2 * focus;
 
-  slider_size = gtk_range_get_min_slider_size (range) / 2;
+  slider_size /= 2;
 
   if (priv->needs_render)
     {
@@ -533,14 +509,14 @@ gimp_color_scale_draw (GtkWidget *widget,
     {
     case GTK_ORIENTATION_HORIZONTAL:
       cairo_set_source_surface (cr, buffer,
-                                x + trough_border + slider_size,
+                                x + trough_border + slider_size / 2 + 1,
                                 y + trough_border + 1);
       break;
 
     case GTK_ORIENTATION_VERTICAL:
       cairo_set_source_surface (cr, buffer,
                                 x + trough_border + 1,
-                                y + trough_border + slider_size);
+                                y + trough_border + slider_size / 2 + 1);
       break;
     }
 
diff --git a/libgimpwidgets/gimpcolorscale.h b/libgimpwidgets/gimpcolorscale.h
index aede7cd..6f7cfea 100644
--- a/libgimpwidgets/gimpcolorscale.h
+++ b/libgimpwidgets/gimpcolorscale.h
@@ -42,12 +42,12 @@ typedef struct _GimpColorScaleClass  GimpColorScaleClass;
 
 struct _GimpColorScale
 {
-  GtkScale  parent_instance;
+  GtkRange  parent_instance;
 };
 
 struct _GimpColorScaleClass
 {
-  GtkScaleClass  parent_class;
+  GtkRangeClass  parent_class;
 
   /* Padding for future expansion */
   void (* _gimp_reserved1) (void);
diff --git a/libgimpwidgets/gimpscaleentry.c b/libgimpwidgets/gimpscaleentry.c
index 47038e2..5d00553 100644
--- a/libgimpwidgets/gimpscaleentry.c
+++ b/libgimpwidgets/gimpscaleentry.c
@@ -180,12 +180,12 @@ gimp_scale_entry_new_internal (gboolean     color_scale,
   else
     {
       scale = gtk_scale_new (GTK_ORIENTATION_HORIZONTAL, scale_adjustment);
+      gtk_scale_set_digits (GTK_SCALE (scale), digits);
+      gtk_scale_set_draw_value (GTK_SCALE (scale), FALSE);
     }
 
   if (scale_width > 0)
     gtk_widget_set_size_request (scale, scale_width, -1);
-  gtk_scale_set_digits (GTK_SCALE (scale), digits);
-  gtk_scale_set_draw_value (GTK_SCALE (scale), FALSE);
   gtk_widget_show (scale);
 
   gtk_table_attach (GTK_TABLE (table), label,


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