[gimp/wip/gradient-edit: 23/42] app: add gimp_color_panel_dialog_response(); add "response" signal
- From: N/A <ell src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/wip/gradient-edit: 23/42] app: add gimp_color_panel_dialog_response(); add "response" signal
- Date: Fri, 6 Oct 2017 19:42:25 +0000 (UTC)
commit 1d65f69ee2d1af0a4231b911e52f77e2d5185c0d
Author: Ell <ell_se yahoo com>
Date: Wed Aug 2 19:46:26 2017 -0400
app: add gimp_color_panel_dialog_response(); add "response" signal
Add gimp_color_panel_dialong_response() to GimpColorPanel, which
emits a response for the color panel's color dialog, if shown.
Add a "response" signal to GimpColorPanel, which is emitted upon
color dialog response.
In both cases, the response is a GimpColorDialogState, which should
be either GIMP_COLOR_DIALOG_OK or GIMP_COLOR_DIALOG_CANCEL, and not
an actual dialog response id.
app/widgets/gimpcolorpanel.c | 38 ++++++++++++++++++++++++++++++++++++++
app/widgets/gimpcolorpanel.h | 23 +++++++++++++++--------
2 files changed, 53 insertions(+), 8 deletions(-)
---
diff --git a/app/widgets/gimpcolorpanel.c b/app/widgets/gimpcolorpanel.c
index 9a338ee..9a124aa 100644
--- a/app/widgets/gimpcolorpanel.c
+++ b/app/widgets/gimpcolorpanel.c
@@ -29,12 +29,20 @@
#include "core/gimp.h"
#include "core/gimpcontext.h"
+#include "core/gimpmarshal.h"
#include "gimpaction.h"
#include "gimpcolordialog.h"
#include "gimpcolorpanel.h"
+enum
+{
+ RESPONSE,
+ LAST_SIGNAL
+};
+
+
/* local function prototypes */
static void gimp_color_panel_dispose (GObject *object);
@@ -57,6 +65,8 @@ G_DEFINE_TYPE (GimpColorPanel, gimp_color_panel, GIMP_TYPE_COLOR_BUTTON)
#define parent_class gimp_color_panel_parent_class
+static guint color_panel_signals[LAST_SIGNAL] = { 0, };
+
static void
gimp_color_panel_class_init (GimpColorPanelClass *klass)
@@ -74,6 +84,16 @@ gimp_color_panel_class_init (GimpColorPanelClass *klass)
color_button_class->color_changed = gimp_color_panel_color_changed;
color_button_class->get_action_type = gimp_color_panel_get_action_type;
+
+ color_panel_signals[RESPONSE] =
+ g_signal_new ("response",
+ G_TYPE_FROM_CLASS (klass),
+ G_SIGNAL_RUN_LAST,
+ G_STRUCT_OFFSET (GimpColorPanelClass, response),
+ NULL, NULL,
+ gimp_marshal_VOID__ENUM,
+ G_TYPE_NONE, 1,
+ GIMP_TYPE_COLOR_DIALOG_STATE);
}
static void
@@ -258,6 +278,18 @@ gimp_color_panel_set_context (GimpColorPanel *panel,
context->gimp->config->color_management);
}
+void
+gimp_color_panel_dialog_response (GimpColorPanel *panel,
+ GimpColorDialogState state)
+{
+ g_return_if_fail (GIMP_IS_COLOR_PANEL (panel));
+ g_return_if_fail (state == GIMP_COLOR_DIALOG_OK ||
+ state == GIMP_COLOR_DIALOG_CANCEL);
+
+ if (panel->color_dialog && gtk_widget_get_visible (panel->color_dialog))
+ gimp_color_panel_dialog_update (NULL, NULL, state, panel);
+}
+
/* private functions */
@@ -278,12 +310,18 @@ gimp_color_panel_dialog_update (GimpColorDialog *dialog,
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);
+
+ g_signal_emit (panel, color_panel_signals[RESPONSE], 0,
+ state);
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);
+
+ g_signal_emit (panel, color_panel_signals[RESPONSE], 0,
+ state);
break;
}
}
diff --git a/app/widgets/gimpcolorpanel.h b/app/widgets/gimpcolorpanel.h
index e1c3d47..4e07ab9 100644
--- a/app/widgets/gimpcolorpanel.h
+++ b/app/widgets/gimpcolorpanel.h
@@ -40,19 +40,26 @@ struct _GimpColorPanel
struct _GimpColorPanelClass
{
GimpColorButtonClass parent_class;
+
+ /* signals */
+ void (* response) (GimpColorPanel *panel,
+ GimpColorDialogState state);
};
-GType gimp_color_panel_get_type (void) G_GNUC_CONST;
+GType gimp_color_panel_get_type (void) G_GNUC_CONST;
+
+GtkWidget * gimp_color_panel_new (const gchar *title,
+ const GimpRGB *color,
+ GimpColorAreaType type,
+ gint width,
+ gint height);
-GtkWidget * gimp_color_panel_new (const gchar *title,
- const GimpRGB *color,
- GimpColorAreaType type,
- gint width,
- gint height);
+void gimp_color_panel_set_context (GimpColorPanel *panel,
+ GimpContext *context);
-void gimp_color_panel_set_context (GimpColorPanel *panel,
- GimpContext *context);
+void gimp_color_panel_dialog_response (GimpColorPanel *panel,
+ GimpColorDialogState state);
#endif /* __GIMP_COLOR_PANEL_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]