mirror of https://github.com/GNOME/gimp.git
app: move all GimpDial members to a private struct
This commit is contained in:
parent
8f07ea37f0
commit
41b15c709d
|
@ -39,12 +39,10 @@
|
||||||
#define TICK 10
|
#define TICK 10
|
||||||
#define EACH_OR_BOTH 0.3
|
#define EACH_OR_BOTH 0.3
|
||||||
|
|
||||||
|
|
||||||
typedef void (* GimpDialBGFunc) (gdouble angle,
|
typedef void (* GimpDialBGFunc) (gdouble angle,
|
||||||
gdouble distance,
|
gdouble distance,
|
||||||
guchar *rgb);
|
guchar *rgb);
|
||||||
|
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
PROP_0,
|
PROP_0,
|
||||||
|
@ -53,6 +51,29 @@ enum
|
||||||
PROP_CLOCKWISE
|
PROP_CLOCKWISE
|
||||||
};
|
};
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
DIAL_TARGET_ALPHA,
|
||||||
|
DIAL_TARGET_BETA,
|
||||||
|
DIAL_TARGET_BOTH
|
||||||
|
} DialTarget;
|
||||||
|
|
||||||
|
struct _GimpDialPrivate
|
||||||
|
{
|
||||||
|
gdouble alpha;
|
||||||
|
gdouble beta;
|
||||||
|
gboolean clockwise;
|
||||||
|
|
||||||
|
GdkWindow *event_window;
|
||||||
|
|
||||||
|
DialTarget target;
|
||||||
|
gdouble press_angle;
|
||||||
|
|
||||||
|
gint border_width;
|
||||||
|
guint has_grab : 1;
|
||||||
|
GdkModifierType press_state;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
static void gimp_dial_dispose (GObject *object);
|
static void gimp_dial_dispose (GObject *object);
|
||||||
static void gimp_dial_set_property (GObject *object,
|
static void gimp_dial_set_property (GObject *object,
|
||||||
|
@ -141,18 +162,24 @@ gimp_dial_class_init (GimpDialClass *klass)
|
||||||
FALSE,
|
FALSE,
|
||||||
GIMP_PARAM_READWRITE |
|
GIMP_PARAM_READWRITE |
|
||||||
G_PARAM_CONSTRUCT));
|
G_PARAM_CONSTRUCT));
|
||||||
|
|
||||||
|
g_type_class_add_private (klass, sizeof (GimpDialPrivate));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gimp_dial_init (GimpDial *dial)
|
gimp_dial_init (GimpDial *dial)
|
||||||
{
|
{
|
||||||
|
dial->priv = G_TYPE_INSTANCE_GET_PRIVATE (dial,
|
||||||
|
GIMP_TYPE_DIAL,
|
||||||
|
GimpDialPrivate);
|
||||||
|
|
||||||
gtk_widget_set_has_window (GTK_WIDGET (dial), FALSE);
|
gtk_widget_set_has_window (GTK_WIDGET (dial), FALSE);
|
||||||
gtk_widget_add_events (GTK_WIDGET (dial),
|
gtk_widget_add_events (GTK_WIDGET (dial),
|
||||||
GDK_BUTTON_PRESS_MASK |
|
GDK_BUTTON_PRESS_MASK |
|
||||||
GDK_BUTTON_RELEASE_MASK |
|
GDK_BUTTON_RELEASE_MASK |
|
||||||
GDK_BUTTON1_MOTION_MASK);
|
GDK_BUTTON1_MOTION_MASK);
|
||||||
|
|
||||||
dial->border_width = 4;
|
dial->priv->border_width = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -172,17 +199,17 @@ gimp_dial_set_property (GObject *object,
|
||||||
switch (property_id)
|
switch (property_id)
|
||||||
{
|
{
|
||||||
case PROP_ALPHA:
|
case PROP_ALPHA:
|
||||||
dial->alpha = g_value_get_double (value);
|
dial->priv->alpha = g_value_get_double (value);
|
||||||
gtk_widget_queue_draw (GTK_WIDGET (dial));
|
gtk_widget_queue_draw (GTK_WIDGET (dial));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PROP_BETA:
|
case PROP_BETA:
|
||||||
dial->beta = g_value_get_double (value);
|
dial->priv->beta = g_value_get_double (value);
|
||||||
gtk_widget_queue_draw (GTK_WIDGET (dial));
|
gtk_widget_queue_draw (GTK_WIDGET (dial));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PROP_CLOCKWISE:
|
case PROP_CLOCKWISE:
|
||||||
dial->clockwise = g_value_get_boolean (value);
|
dial->priv->clockwise = g_value_get_boolean (value);
|
||||||
gtk_widget_queue_draw (GTK_WIDGET (dial));
|
gtk_widget_queue_draw (GTK_WIDGET (dial));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -203,15 +230,15 @@ gimp_dial_get_property (GObject *object,
|
||||||
switch (property_id)
|
switch (property_id)
|
||||||
{
|
{
|
||||||
case PROP_ALPHA:
|
case PROP_ALPHA:
|
||||||
g_value_set_double (value, dial->alpha);
|
g_value_set_double (value, dial->priv->alpha);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PROP_BETA:
|
case PROP_BETA:
|
||||||
g_value_set_double (value, dial->beta);
|
g_value_set_double (value, dial->priv->beta);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PROP_CLOCKWISE:
|
case PROP_CLOCKWISE:
|
||||||
g_value_set_boolean (value, dial->clockwise);
|
g_value_set_boolean (value, dial->priv->clockwise);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -242,9 +269,9 @@ gimp_dial_realize (GtkWidget *widget)
|
||||||
|
|
||||||
attributes_mask = GDK_WA_X | GDK_WA_Y;
|
attributes_mask = GDK_WA_X | GDK_WA_Y;
|
||||||
|
|
||||||
dial->event_window = gdk_window_new (gtk_widget_get_window (widget),
|
dial->priv->event_window = gdk_window_new (gtk_widget_get_window (widget),
|
||||||
&attributes, attributes_mask);
|
&attributes, attributes_mask);
|
||||||
gdk_window_set_user_data (dial->event_window, dial);
|
gdk_window_set_user_data (dial->priv->event_window, dial);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -252,11 +279,11 @@ gimp_dial_unrealize (GtkWidget *widget)
|
||||||
{
|
{
|
||||||
GimpDial *dial = GIMP_DIAL (widget);
|
GimpDial *dial = GIMP_DIAL (widget);
|
||||||
|
|
||||||
if (dial->event_window)
|
if (dial->priv->event_window)
|
||||||
{
|
{
|
||||||
gdk_window_set_user_data (dial->event_window, NULL);
|
gdk_window_set_user_data (dial->priv->event_window, NULL);
|
||||||
gdk_window_destroy (dial->event_window);
|
gdk_window_destroy (dial->priv->event_window);
|
||||||
dial->event_window = NULL;
|
dial->priv->event_window = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
GTK_WIDGET_CLASS (parent_class)->unrealize (widget);
|
GTK_WIDGET_CLASS (parent_class)->unrealize (widget);
|
||||||
|
@ -269,8 +296,8 @@ gimp_dial_map (GtkWidget *widget)
|
||||||
|
|
||||||
GTK_WIDGET_CLASS (parent_class)->map (widget);
|
GTK_WIDGET_CLASS (parent_class)->map (widget);
|
||||||
|
|
||||||
if (dial->event_window)
|
if (dial->priv->event_window)
|
||||||
gdk_window_show (dial->event_window);
|
gdk_window_show (dial->priv->event_window);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -278,14 +305,14 @@ gimp_dial_unmap (GtkWidget *widget)
|
||||||
{
|
{
|
||||||
GimpDial *dial = GIMP_DIAL (widget);
|
GimpDial *dial = GIMP_DIAL (widget);
|
||||||
|
|
||||||
if (dial->has_grab)
|
if (dial->priv->has_grab)
|
||||||
{
|
{
|
||||||
gtk_grab_remove (widget);
|
gtk_grab_remove (widget);
|
||||||
dial->has_grab = FALSE;
|
dial->priv->has_grab = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dial->event_window)
|
if (dial->priv->event_window)
|
||||||
gdk_window_hide (dial->event_window);
|
gdk_window_hide (dial->priv->event_window);
|
||||||
|
|
||||||
GTK_WIDGET_CLASS (parent_class)->unmap (widget);
|
GTK_WIDGET_CLASS (parent_class)->unmap (widget);
|
||||||
}
|
}
|
||||||
|
@ -296,8 +323,8 @@ gimp_dial_size_request (GtkWidget *widget,
|
||||||
{
|
{
|
||||||
GimpDial *dial = GIMP_DIAL (widget);
|
GimpDial *dial = GIMP_DIAL (widget);
|
||||||
|
|
||||||
requisition->width = 2 * dial->border_width + 128;
|
requisition->width = 2 * dial->priv->border_width + 96;
|
||||||
requisition->height = 2 * dial->border_width + 128;
|
requisition->height = 2 * dial->priv->border_width + 96;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -309,7 +336,7 @@ gimp_dial_size_allocate (GtkWidget *widget,
|
||||||
gtk_widget_set_allocation (widget, allocation);
|
gtk_widget_set_allocation (widget, allocation);
|
||||||
|
|
||||||
if (gtk_widget_get_realized (widget))
|
if (gtk_widget_get_realized (widget))
|
||||||
gdk_window_move_resize (dial->event_window,
|
gdk_window_move_resize (dial->priv->event_window,
|
||||||
allocation->x,
|
allocation->x,
|
||||||
allocation->y,
|
allocation->y,
|
||||||
allocation->width,
|
allocation->width,
|
||||||
|
@ -325,6 +352,7 @@ gimp_dial_expose_event (GtkWidget *widget,
|
||||||
if (gtk_widget_is_drawable (widget))
|
if (gtk_widget_is_drawable (widget))
|
||||||
{
|
{
|
||||||
GtkAllocation allocation;
|
GtkAllocation allocation;
|
||||||
|
gint border_width = dial->priv->border_width;
|
||||||
cairo_t *cr;
|
cairo_t *cr;
|
||||||
gint size;
|
gint size;
|
||||||
gint x, y;
|
gint x, y;
|
||||||
|
@ -335,17 +363,19 @@ gimp_dial_expose_event (GtkWidget *widget,
|
||||||
gdk_cairo_region (cr, event->region);
|
gdk_cairo_region (cr, event->region);
|
||||||
cairo_clip (cr);
|
cairo_clip (cr);
|
||||||
|
|
||||||
size = MIN (allocation.width, allocation.height) - 2 * dial->border_width;
|
size = MIN (allocation.width, allocation.height) - 2 * border_width;
|
||||||
|
|
||||||
x = (allocation.width - 2 * dial->border_width - size) / 2;
|
x = (allocation.width - 2 * border_width - size) / 2;
|
||||||
y = (allocation.height - 2 * dial->border_width - size) / 2;
|
y = (allocation.height - 2 * border_width - size) / 2;
|
||||||
|
|
||||||
cairo_translate (cr,
|
cairo_translate (cr,
|
||||||
allocation.x + dial->border_width + x,
|
allocation.x + border_width + x,
|
||||||
allocation.y + dial->border_width + y);
|
allocation.y + border_width + y);
|
||||||
|
|
||||||
gimp_dial_draw_background (cr, size, gimp_dial_background_func_hsv);
|
gimp_dial_draw_background (cr, size, gimp_dial_background_func_hsv);
|
||||||
gimp_dial_draw_arrows (cr, size, dial->alpha, dial->beta, dial->clockwise);
|
gimp_dial_draw_arrows (cr, size,
|
||||||
|
dial->priv->alpha, dial->priv->beta,
|
||||||
|
dial->priv->clockwise);
|
||||||
|
|
||||||
cairo_destroy (cr);
|
cairo_destroy (cr);
|
||||||
}
|
}
|
||||||
|
@ -413,7 +443,7 @@ gimp_dial_button_press_event (GtkWidget *widget,
|
||||||
{
|
{
|
||||||
if (gdk_event_triggers_context_menu ((GdkEvent *) bevent))
|
if (gdk_event_triggers_context_menu ((GdkEvent *) bevent))
|
||||||
{
|
{
|
||||||
dial->press_state = 0;
|
dial->priv->press_state = 0;
|
||||||
|
|
||||||
//g_signal_emit (widget, dial_signals[CONTEXT], 0);
|
//g_signal_emit (widget, dial_signals[CONTEXT], 0);
|
||||||
}
|
}
|
||||||
|
@ -427,34 +457,36 @@ gimp_dial_button_press_event (GtkWidget *widget,
|
||||||
|
|
||||||
gtk_widget_get_allocation (widget, &allocation);
|
gtk_widget_get_allocation (widget, &allocation);
|
||||||
|
|
||||||
size = MIN (allocation.width, allocation.height) - 2 * dial->border_width;
|
size = MIN (allocation.width, allocation.height) - 2 * dial->priv->border_width;
|
||||||
|
|
||||||
center_x = allocation.width / 2.0;
|
center_x = allocation.width / 2.0;
|
||||||
center_y = allocation.height / 2.0;
|
center_y = allocation.height / 2.0;
|
||||||
|
|
||||||
gtk_grab_add (widget);
|
gtk_grab_add (widget);
|
||||||
|
|
||||||
dial->has_grab = TRUE;
|
dial->priv->has_grab = TRUE;
|
||||||
dial->press_state = bevent->state;
|
dial->priv->press_state = bevent->state;
|
||||||
|
|
||||||
press_angle = angle_mod_2PI (arctg (center_y - bevent->y,
|
press_angle = angle_mod_2PI (arctg (center_y - bevent->y,
|
||||||
bevent->x - center_x));
|
bevent->x - center_x));
|
||||||
dial->press_angle = press_angle;
|
dial->priv->press_angle = press_angle;
|
||||||
|
|
||||||
if ((sqrt (SQR (bevent->y - center_y) +
|
if ((sqrt (SQR (bevent->y - center_y) +
|
||||||
SQR (bevent->x - center_x)) > size / 2.0 * EACH_OR_BOTH) &&
|
SQR (bevent->x - center_x)) > size / 2.0 * EACH_OR_BOTH) &&
|
||||||
(min_prox (dial->alpha, dial->beta, press_angle) < G_PI / 12))
|
(min_prox (dial->priv->alpha, dial->priv->beta,
|
||||||
|
press_angle) < G_PI / 12))
|
||||||
{
|
{
|
||||||
dial->target = closest (dial->alpha, dial->beta, press_angle);
|
dial->priv->target = closest (dial->priv->alpha, dial->priv->beta,
|
||||||
|
press_angle);
|
||||||
|
|
||||||
if (dial->target == DIAL_TARGET_ALPHA)
|
if (dial->priv->target == DIAL_TARGET_ALPHA)
|
||||||
g_object_set (dial, "alpha", press_angle, NULL);
|
g_object_set (dial, "alpha", press_angle, NULL);
|
||||||
else
|
else
|
||||||
g_object_set (dial, "beta", press_angle, NULL);
|
g_object_set (dial, "beta", press_angle, NULL);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
dial->target = DIAL_TARGET_BOTH;
|
dial->priv->target = DIAL_TARGET_BOTH;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -471,7 +503,7 @@ gimp_dial_button_release_event (GtkWidget *widget,
|
||||||
if (bevent->button == 1)
|
if (bevent->button == 1)
|
||||||
{
|
{
|
||||||
gtk_grab_remove (widget);
|
gtk_grab_remove (widget);
|
||||||
dial->has_grab = FALSE;
|
dial->priv->has_grab = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
@ -495,24 +527,24 @@ gimp_dial_motion_notify_event (GtkWidget *widget,
|
||||||
motion_angle = angle_mod_2PI (arctg (center_y - mevent->y,
|
motion_angle = angle_mod_2PI (arctg (center_y - mevent->y,
|
||||||
mevent->x - center_x));
|
mevent->x - center_x));
|
||||||
|
|
||||||
delta = motion_angle - dial->press_angle;
|
delta = motion_angle - dial->priv->press_angle;
|
||||||
dial->press_angle = motion_angle;
|
dial->priv->press_angle = motion_angle;
|
||||||
|
|
||||||
if (delta)
|
if (delta)
|
||||||
{
|
{
|
||||||
if (dial->target == DIAL_TARGET_ALPHA)
|
if (dial->priv->target == DIAL_TARGET_ALPHA)
|
||||||
{
|
{
|
||||||
g_object_set (dial, "alpha", motion_angle, NULL);
|
g_object_set (dial, "alpha", motion_angle, NULL);
|
||||||
}
|
}
|
||||||
else if (dial->target == DIAL_TARGET_BETA)
|
else if (dial->priv->target == DIAL_TARGET_BETA)
|
||||||
{
|
{
|
||||||
g_object_set (dial, "beta", motion_angle, NULL);
|
g_object_set (dial, "beta", motion_angle, NULL);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
g_object_set (dial,
|
g_object_set (dial,
|
||||||
"alpha", angle_mod_2PI (dial->alpha + delta),
|
"alpha", angle_mod_2PI (dial->priv->alpha + delta),
|
||||||
"beta", angle_mod_2PI (dial->beta + delta),
|
"beta", angle_mod_2PI (dial->priv->beta + delta),
|
||||||
NULL);
|
NULL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,14 +22,6 @@
|
||||||
#define __GIMP_DIAL_H__
|
#define __GIMP_DIAL_H__
|
||||||
|
|
||||||
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
DIAL_TARGET_ALPHA,
|
|
||||||
DIAL_TARGET_BETA,
|
|
||||||
DIAL_TARGET_BOTH
|
|
||||||
} DialTarget;
|
|
||||||
|
|
||||||
|
|
||||||
#define GIMP_TYPE_DIAL (gimp_dial_get_type ())
|
#define GIMP_TYPE_DIAL (gimp_dial_get_type ())
|
||||||
#define GIMP_DIAL(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GIMP_TYPE_DIAL, GimpDial))
|
#define GIMP_DIAL(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GIMP_TYPE_DIAL, GimpDial))
|
||||||
#define GIMP_DIAL_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GIMP_TYPE_DIAL, GimpDialClass))
|
#define GIMP_DIAL_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GIMP_TYPE_DIAL, GimpDialClass))
|
||||||
|
@ -38,24 +30,14 @@ typedef enum
|
||||||
#define GIMP_DIAL_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GIMP_TYPE_DIAL, GimpDialClass))
|
#define GIMP_DIAL_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GIMP_TYPE_DIAL, GimpDialClass))
|
||||||
|
|
||||||
|
|
||||||
typedef struct _GimpDialClass GimpDialClass;
|
typedef struct _GimpDialPrivate GimpDialPrivate;
|
||||||
|
typedef struct _GimpDialClass GimpDialClass;
|
||||||
|
|
||||||
struct _GimpDial
|
struct _GimpDial
|
||||||
{
|
{
|
||||||
GtkWidget parent_instance;
|
GtkWidget parent_instance;
|
||||||
|
|
||||||
gdouble alpha;
|
GimpDialPrivate *priv;
|
||||||
gdouble beta;
|
|
||||||
gboolean clockwise;
|
|
||||||
|
|
||||||
GdkWindow *event_window;
|
|
||||||
|
|
||||||
DialTarget target;
|
|
||||||
gdouble press_angle;
|
|
||||||
|
|
||||||
gint border_width;
|
|
||||||
guint has_grab : 1;
|
|
||||||
GdkModifierType press_state;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _GimpDialClass
|
struct _GimpDialClass
|
||||||
|
|
Loading…
Reference in New Issue