[gimp/goat-invasion: 377/608] app: fix/enable continuous color updates in GimpColorPanel
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/goat-invasion: 377/608] app: fix/enable continuous color updates in GimpColorPanel
- Date: Fri, 27 Apr 2012 20:57:04 +0000 (UTC)
commit d8ec18b6f3d1904d43077d75cc230ffaea61efd4
Author: Michael Natterer <mitch gimp org>
Date: Sun Apr 1 15:46:48 2012 +0200
app: fix/enable continuous color updates in GimpColorPanel
app/widgets/gimpcolorpanel.c | 28 ++++++++++++++++++++++------
1 files changed, 22 insertions(+), 6 deletions(-)
---
diff --git a/app/widgets/gimpcolorpanel.c b/app/widgets/gimpcolorpanel.c
index 867d340..7bc5a7c 100644
--- a/app/widgets/gimpcolorpanel.c
+++ b/app/widgets/gimpcolorpanel.c
@@ -166,8 +166,8 @@ gimp_color_panel_clicked (GtkButton *button)
NULL, NULL,
GTK_WIDGET (button),
NULL, NULL,
- (const GimpRGB *) &color,
- FALSE,
+ &color,
+ gimp_color_button_get_update (GIMP_COLOR_BUTTON (button)),
gimp_color_button_has_alpha (GIMP_COLOR_BUTTON (button)));
g_signal_connect (panel->color_dialog, "destroy",
@@ -220,9 +220,18 @@ gimp_color_panel_color_changed (GimpColorButton *button)
if (panel->color_dialog)
{
+ GimpRGB dialog_color;
+
gimp_color_button_get_color (GIMP_COLOR_BUTTON (button), &color);
- gimp_color_dialog_set_color (GIMP_COLOR_DIALOG (panel->color_dialog),
- &color);
+ gimp_color_dialog_get_color (GIMP_COLOR_DIALOG (panel->color_dialog),
+ &dialog_color);
+
+ if (gimp_rgba_distance (&color, &dialog_color) > 0.00001 ||
+ color.a != dialog_color.a)
+ {
+ gimp_color_dialog_set_color (GIMP_COLOR_DIALOG (panel->color_dialog),
+ &color);
+ }
}
}
@@ -248,13 +257,20 @@ gimp_color_panel_dialog_update (GimpColorDialog *dialog,
switch (state)
{
case GIMP_COLOR_DIALOG_UPDATE:
+ if (gimp_color_button_get_update (GIMP_COLOR_BUTTON (panel)))
+ gimp_color_button_set_color (GIMP_COLOR_BUTTON (panel), color);
break;
case GIMP_COLOR_DIALOG_OK:
- gimp_color_button_set_color (GIMP_COLOR_BUTTON (panel), color);
- /* Fallthrough */
+ if (! gimp_color_button_get_update (GIMP_COLOR_BUTTON (panel)))
+ gimp_color_button_set_color (GIMP_COLOR_BUTTON (panel), color);
+ gtk_widget_hide (panel->color_dialog);
+ break;
case GIMP_COLOR_DIALOG_CANCEL:
+ if (gimp_color_button_get_update (GIMP_COLOR_BUTTON (panel)))
+ gimp_color_button_set_color (GIMP_COLOR_BUTTON (panel), color);
gtk_widget_hide (panel->color_dialog);
+ break;
}
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]