[gimp/goat-invasion: 268/418] app: add infrastructure to invoke GEGL filters from a menu item
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/goat-invasion: 268/418] app: add infrastructure to invoke GEGL filters from a menu item
- Date: Wed, 4 Apr 2012 10:48:19 +0000 (UTC)
commit 0103a0b1103b4ebb183914d78e3cd35d7b44fa04
Author: Michael Natterer <mitch gimp org>
Date: Mon Mar 26 22:56:53 2012 +0200
app: add infrastructure to invoke GEGL filters from a menu item
and for fun add pixelize and gaussian blur to Filters -> Blur.
app/actions/Makefile.am | 4 ++
app/actions/actions.c | 4 ++
app/actions/filters-actions.c | 101 ++++++++++++++++++++++++++++++++++++++++
app/actions/filters-actions.h | 27 +++++++++++
app/actions/filters-commands.c | 84 +++++++++++++++++++++++++++++++++
app/actions/filters-commands.h | 27 +++++++++++
app/dialogs/dialogs.c | 1 +
app/menus/menus.c | 4 ++
app/tools/gimp-tools.c | 2 +
app/tools/gimpgegltool.c | 2 +-
app/tools/gimpoperationtool.c | 31 ++++++++----
app/tools/gimpoperationtool.h | 11 ++--
menus/image-menu.xml.in | 5 ++-
13 files changed, 285 insertions(+), 18 deletions(-)
---
diff --git a/app/actions/Makefile.am b/app/actions/Makefile.am
index afffe7a..3d0b6c6 100644
--- a/app/actions/Makefile.am
+++ b/app/actions/Makefile.am
@@ -91,6 +91,10 @@ libappactions_a_SOURCES = \
file-actions.h \
file-commands.c \
file-commands.h \
+ filters-actions.c \
+ filters-actions.h \
+ filters-commands.c \
+ filters-commands.h \
fonts-actions.c \
fonts-actions.h \
fonts-commands.c \
diff --git a/app/actions/actions.c b/app/actions/actions.c
index c4ca0ab..36bd0b9 100644
--- a/app/actions/actions.c
+++ b/app/actions/actions.c
@@ -69,6 +69,7 @@
#include "edit-actions.h"
#include "error-console-actions.h"
#include "file-actions.h"
+#include "filters-actions.h"
#include "fonts-actions.h"
#include "gradient-editor-actions.h"
#include "gradients-actions.h"
@@ -163,6 +164,9 @@ static const GimpActionFactoryEntry action_groups[] =
{ "file", N_("File"), GTK_STOCK_FILE,
file_actions_setup,
file_actions_update },
+ { "filters", N_("Filters"), GIMP_STOCK_GEGL,
+ filters_actions_setup,
+ filters_actions_update },
{ "fonts", N_("Fonts"), GIMP_STOCK_FONT,
fonts_actions_setup,
fonts_actions_update },
diff --git a/app/actions/filters-actions.c b/app/actions/filters-actions.c
new file mode 100644
index 0000000..2ec97c3
--- /dev/null
+++ b/app/actions/filters-actions.c
@@ -0,0 +1,101 @@
+/* GIMP - The GNU Image Manipulation Program
+ * Copyright (C) 1995 Spencer Kimball and Peter Mattis
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "config.h"
+
+#include <gegl.h>
+#include <gtk/gtk.h>
+
+#include "libgimpwidgets/gimpwidgets.h"
+
+#include "actions-types.h"
+
+#include "core/gimpimage.h"
+#include "core/gimplayermask.h"
+
+#include "widgets/gimpactiongroup.h"
+#include "widgets/gimphelp-ids.h"
+
+#include "actions.h"
+#include "filters-actions.h"
+#include "filters-commands.h"
+
+#include "gimp-intl.h"
+
+
+static const GimpStringActionEntry filters_actions[] =
+{
+ { "filters-pixelize", GIMP_STOCK_GEGL,
+ NC_("filters-action", "_Pixelize"), NULL,
+ NC_("filters-action", "Simplify image into an array of solid-colored squares"),
+ "gegl:pixelise",
+ NULL /* FIXME GIMP_HELP_FILTER_PIXELIZE */ },
+
+ { "filters-gaussian-blur", GIMP_STOCK_GEGL,
+ NC_("filters-action", "_Gaussian Blur"), NULL,
+ NC_("filters-action", "Apply a gaussian blur"),
+ "gegl:gaussian-blur",
+ NULL /* FIXME GIMP_HELP_FILTER_GAUSSIAN_BLUR */ },
+};
+
+void
+filters_actions_setup (GimpActionGroup *group)
+{
+ gimp_action_group_add_string_actions (group, "filters-action",
+ filters_actions,
+ G_N_ELEMENTS (filters_actions),
+ G_CALLBACK (filters_filter_cmd_callback));
+}
+
+void
+filters_actions_update (GimpActionGroup *group,
+ gpointer data)
+{
+ GimpImage *image;
+ GimpDrawable *drawable = NULL;
+ gboolean writable = FALSE;
+ gboolean children = FALSE;
+
+ image = action_data_get_image (data);
+
+ if (image)
+ {
+ drawable = gimp_image_get_active_drawable (image);
+
+ if (drawable)
+ {
+ GimpItem *item;
+
+ if (GIMP_IS_LAYER_MASK (drawable))
+ item = GIMP_ITEM (gimp_layer_mask_get_layer (GIMP_LAYER_MASK (drawable)));
+ else
+ item = GIMP_ITEM (drawable);
+
+ writable = ! gimp_item_is_content_locked (item);
+
+ if (gimp_viewable_get_children (GIMP_VIEWABLE (drawable)))
+ children = TRUE;
+ }
+ }
+
+#define SET_SENSITIVE(action,condition) \
+ gimp_action_group_set_action_sensitive (group, action, (condition) != 0)
+
+ SET_SENSITIVE ("filters-pixelize", writable && !children);
+
+#undef SET_SENSITIVE
+}
diff --git a/app/actions/filters-actions.h b/app/actions/filters-actions.h
new file mode 100644
index 0000000..a7a1c08
--- /dev/null
+++ b/app/actions/filters-actions.h
@@ -0,0 +1,27 @@
+/* GIMP - The GNU Image Manipulation Program
+ * Copyright (C) 1995 Spencer Kimball and Peter Mattis
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __FILTERS_ACTIONS_H__
+#define __FILTERS_ACTIONS_H__
+
+
+void filters_actions_setup (GimpActionGroup *group);
+void filters_actions_update (GimpActionGroup *group,
+ gpointer data);
+
+
+#endif /* __FILTERS_ACTIONS_H__ */
diff --git a/app/actions/filters-commands.c b/app/actions/filters-commands.c
new file mode 100644
index 0000000..ef18869
--- /dev/null
+++ b/app/actions/filters-commands.c
@@ -0,0 +1,84 @@
+/* GIMP - The GNU Image Manipulation Program
+ * Copyright (C) 1995 Spencer Kimball and Peter Mattis
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "config.h"
+
+#include <gegl.h>
+#include <gtk/gtk.h>
+
+#include "libgimpbase/gimpbase.h"
+#include "libgimpwidgets/gimpwidgets.h"
+
+#include "actions-types.h"
+
+#include "core/gimp.h"
+#include "core/gimpdrawable.h"
+#include "core/gimpimage.h"
+#include "core/gimptooloptions.h"
+#include "core/gimptoolinfo.h"
+
+#include "tools/gimpimagemapoptions.h"
+#include "tools/gimpoperationtool.h"
+#include "tools/tool_manager.h"
+
+#include "actions.h"
+#include "filters-commands.h"
+
+#include "gimp-intl.h"
+
+
+/* public functions */
+
+void
+filters_filter_cmd_callback (GtkAction *action,
+ const gchar *operation,
+ gpointer data)
+{
+ GimpImage *image;
+ GimpDrawable *drawable;
+ GimpDisplay *display;
+ GimpTool *active_tool;
+ return_if_no_drawable (image, drawable, data);
+ return_if_no_display (display, data);
+
+ active_tool = tool_manager_get_active (image->gimp);
+
+ if (! GIMP_IS_OPERATION_TOOL (active_tool))
+ {
+ GimpToolInfo *tool_info = gimp_get_tool_info (image->gimp,
+ "gimp-operation-tool");
+
+ if (GIMP_IS_TOOL_INFO (tool_info))
+ {
+ gimp_context_set_tool (action_data_get_context (data), tool_info);
+ active_tool = tool_manager_get_active (image->gimp);
+ }
+ }
+
+ if (GIMP_IS_OPERATION_TOOL (active_tool))
+ {
+ gchar *label = gimp_strip_uline (gtk_action_get_label (action));
+
+ tool_manager_control_active (image->gimp, GIMP_TOOL_ACTION_HALT,
+ display);
+ tool_manager_initialize_active (image->gimp, display);
+ gimp_operation_tool_set_operation (GIMP_OPERATION_TOOL (active_tool),
+ operation, label);
+
+ g_free (label);
+ }
+}
diff --git a/app/actions/filters-commands.h b/app/actions/filters-commands.h
new file mode 100644
index 0000000..744b49e
--- /dev/null
+++ b/app/actions/filters-commands.h
@@ -0,0 +1,27 @@
+/* GIMP - The GNU Image Manipulation Program
+ * Copyright (C) 1995 Spencer Kimball and Peter Mattis
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef __FILTERS_COMMANDS_H__
+#define __FILTERS_COMMANDS_H__
+
+
+void filters_filter_cmd_callback (GtkAction *action,
+ const gchar *operation,
+ gpointer data);
+
+
+#endif /* __FILTERS_COMMANDS_H__ */
diff --git a/app/dialogs/dialogs.c b/app/dialogs/dialogs.c
index 8c4d9e5..b2533e6 100644
--- a/app/dialogs/dialogs.c
+++ b/app/dialogs/dialogs.c
@@ -231,6 +231,7 @@ static const GimpDialogFactoryEntry entries[] =
FOREIGN ("gimp-hue-saturation-tool-dialog", TRUE, FALSE),
FOREIGN ("gimp-levels-tool-dialog", TRUE, TRUE),
FOREIGN ("gimp-measure-tool-dialog", TRUE, FALSE),
+ FOREIGN ("gimp-operation-tool-dialog", TRUE, FALSE),
FOREIGN ("gimp-posterize-tool-dialog", TRUE, FALSE),
FOREIGN ("gimp-rotate-tool-dialog", TRUE, FALSE),
FOREIGN ("gimp-scale-tool-dialog", TRUE, FALSE),
diff --git a/app/menus/menus.c b/app/menus/menus.c
index 58cdac3..10230fc 100644
--- a/app/menus/menus.c
+++ b/app/menus/menus.c
@@ -109,6 +109,7 @@ menus_init (Gimp *gimp,
"dialogs",
"windows",
"plug-in",
+ "filters",
"quick-mask",
NULL,
"/image-menubar",
@@ -135,6 +136,7 @@ menus_init (Gimp *gimp,
"windows",
"dialogs",
"plug-in",
+ "filters",
"quick-mask",
NULL,
NULL);
@@ -162,6 +164,7 @@ menus_init (Gimp *gimp,
gimp_menu_factory_manager_register (global_menu_factory, "<Layers>",
"layers",
"plug-in",
+ "filters",
NULL,
"/layers-popup",
"layers-menu.xml", plug_in_menus_setup,
@@ -170,6 +173,7 @@ menus_init (Gimp *gimp,
gimp_menu_factory_manager_register (global_menu_factory, "<Channels>",
"channels",
"plug-in",
+ "filters",
NULL,
"/channels-popup",
"channels-menu.xml", plug_in_menus_setup,
diff --git a/app/tools/gimp-tools.c b/app/tools/gimp-tools.c
index 6959383..f546705 100644
--- a/app/tools/gimp-tools.c
+++ b/app/tools/gimp-tools.c
@@ -66,6 +66,7 @@
#include "gimpinktool.h"
#include "gimpiscissorstool.h"
#include "gimplevelstool.h"
+#include "gimpoperationtool.h"
#include "gimpmagnifytool.h"
#include "gimpmeasuretool.h"
#include "gimpmovetool.h"
@@ -118,6 +119,7 @@ gimp_tools_init (Gimp *gimp)
/* register tools in reverse order */
/* color tools */
+ gimp_operation_tool_register,
gimp_gegl_tool_register,
gimp_posterize_tool_register,
gimp_curves_tool_register,
diff --git a/app/tools/gimpgegltool.c b/app/tools/gimpgegltool.c
index d91ff8b..48d590c 100644
--- a/app/tools/gimpgegltool.c
+++ b/app/tools/gimpgegltool.c
@@ -330,7 +330,7 @@ gimp_gegl_tool_operation_changed (GtkWidget *widget,
if (operation)
{
gimp_operation_tool_set_operation (GIMP_OPERATION_TOOL (tool),
- operation);
+ operation, NULL);
g_free (operation);
}
}
diff --git a/app/tools/gimpoperationtool.c b/app/tools/gimpoperationtool.c
index a0e83f8..7fbc5a7 100644
--- a/app/tools/gimpoperationtool.c
+++ b/app/tools/gimpoperationtool.c
@@ -73,7 +73,6 @@ G_DEFINE_TYPE (GimpOperationTool, gimp_operation_tool,
#define parent_class gimp_operation_tool_parent_class
-#if 0
void
gimp_operation_tool_register (GimpToolRegisterCallback callback,
gpointer data)
@@ -85,11 +84,10 @@ gimp_operation_tool_register (GimpToolRegisterCallback callback,
_("GEGL Operation"),
_("Operation Tool: Use an arbitrary GEGL operation"),
N_("_GEGL Operation..."), NULL,
- NULL, GIMP_HELP_TOOL_OPERATION,
+ NULL, GIMP_HELP_TOOL_GEGL,
GIMP_STOCK_GEGL,
data);
}
-#endif
static void
gimp_operation_tool_class_init (GimpOperationToolClass *klass)
@@ -140,9 +138,9 @@ gimp_operation_tool_initialize (GimpTool *tool,
GimpDisplay *display,
GError **error)
{
- GimpOperationTool *o_tool = GIMP_OPERATION_TOOL (tool);
- GimpImage *image = gimp_display_get_image (display);
- GimpDrawable *drawable = gimp_image_get_active_drawable (image);
+ GimpOperationTool *o_tool = GIMP_OPERATION_TOOL (tool);
+ GimpImage *image = gimp_display_get_image (display);
+ GimpDrawable *drawable = gimp_image_get_active_drawable (image);
if (! drawable)
return FALSE;
@@ -150,7 +148,14 @@ gimp_operation_tool_initialize (GimpTool *tool,
if (o_tool->config)
gimp_config_reset (GIMP_CONFIG (o_tool->config));
- return GIMP_TOOL_CLASS (parent_class)->initialize (tool, display, error);
+ if (! GIMP_TOOL_CLASS (parent_class)->initialize (tool, display, error))
+ {
+ return FALSE;
+ }
+
+ gimp_image_map_tool_preview (GIMP_IMAGE_MAP_TOOL (tool));
+
+ return TRUE;
}
static GeglNode *
@@ -170,9 +175,9 @@ gimp_operation_tool_map (GimpImageMapTool *image_map_tool)
}
-/*****************/
+/**********************/
/* Operation dialog */
-/*****************/
+/**********************/
static void
gimp_operation_tool_dialog (GimpImageMapTool *image_map_tool)
@@ -208,7 +213,8 @@ gimp_operation_tool_config_notify (GObject *object,
void
gimp_operation_tool_set_operation (GimpOperationTool *tool,
- const gchar *operation)
+ const gchar *operation,
+ const gchar *label)
{
g_return_if_fail (GIMP_IS_OPERATION_TOOL (tool));
g_return_if_fail (operation != NULL);
@@ -263,5 +269,10 @@ gimp_operation_tool_set_operation (GimpOperationTool *tool,
gtk_widget_show (tool->options_table);
}
+ if (label)
+ g_object_set (GIMP_IMAGE_MAP_TOOL (tool)->dialog,
+ "description", label,
+ NULL);
+
gimp_image_map_tool_preview (GIMP_IMAGE_MAP_TOOL (tool));
}
diff --git a/app/tools/gimpoperationtool.h b/app/tools/gimpoperationtool.h
index 5ec8b28..a4a8ad1 100644
--- a/app/tools/gimpoperationtool.h
+++ b/app/tools/gimpoperationtool.h
@@ -51,15 +51,14 @@ struct _GimpOperationToolClass
};
-#if 0
-void gimp_operation_tool_register (GimpToolRegisterCallback callback,
- gpointer data);
-#endif
+void gimp_operation_tool_register (GimpToolRegisterCallback callback,
+ gpointer data);
GType gimp_operation_tool_get_type (void) G_GNUC_CONST;
-void gimp_operation_tool_set_operation (GimpOperationTool *tool,
- const gchar *operation);
+void gimp_operation_tool_set_operation (GimpOperationTool *tool,
+ const gchar *operation,
+ const gchar *label);
#endif /* __GIMP_OPERATION_TOOL_H__ */
diff --git a/menus/image-menu.xml.in b/menus/image-menu.xml.in
index 27c747a..8acf747 100644
--- a/menus/image-menu.xml.in
+++ b/menus/image-menu.xml.in
@@ -586,7 +586,10 @@
</menu>
<menuitem action="plug-in-reset-all" />
<separator />
- <menu action="plug-in-blur-menu" name="Blur" />
+ <menu action="plug-in-blur-menu" name="Blur">
+ <menuitem action="filters-gaussian-blur" />
+ <menuitem action="filters-pixelize" />
+ </menu>
<menu action="plug-in-enhance-menu" name="Enhance" />
<menu action="plug-in-distorts-menu" name="Distorts" />
<menu action="plug-in-light-shadow-menu" name="Light and Shadow">
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]