[gimp/soc-2011-seamless-clone2] app: port GimpImageMap to GimpApplicator
- From: Clayton Walker <claytonw src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/soc-2011-seamless-clone2] app: port GimpImageMap to GimpApplicator
- Date: Wed, 8 May 2013 15:13:23 +0000 (UTC)
commit 8100a693e5e637d009cc1cb229189de1a52b5df7
Author: Michael Natterer <mitch gimp org>
Date: Sun Apr 14 22:46:52 2013 +0200
app: port GimpImageMap to GimpApplicator
app/core/gimpimagemap.c | 101 ++++++++++++++++++++++++++--------------------
1 files changed, 57 insertions(+), 44 deletions(-)
---
diff --git a/app/core/gimpimagemap.c b/app/core/gimpimagemap.c
index e071445..5eb1c40 100644
--- a/app/core/gimpimagemap.c
+++ b/app/core/gimpimagemap.c
@@ -37,7 +37,7 @@
#include "core-types.h"
-#include "gegl/gimp-gegl-nodes.h"
+#include "gegl/gimpapplicator.h"
#include "gegl/gimp-gegl-utils.h"
#include "gimpdrawable.h"
@@ -61,15 +61,16 @@ enum
struct _GimpImageMap
{
- GimpObject parent_instance;
+ GimpObject parent_instance;
- GimpDrawable *drawable;
- gchar *undo_desc;
+ GimpDrawable *drawable;
+ gchar *undo_desc;
- GimpFilter *filter;
+ GimpFilter *filter;
- GeglNode *operation;
- GeglNode *translate;
+ GeglNode *operation;
+ GeglNode *translate;
+ GimpApplicator *applicator;
};
@@ -166,6 +167,12 @@ gimp_image_map_finalize (GObject *object)
image_map->filter = NULL;
}
+ if (image_map->applicator)
+ {
+ g_object_unref (image_map->applicator);
+ image_map->applicator = NULL;
+ }
+
if (image_map->drawable)
{
g_object_unref (image_map->drawable);
@@ -247,7 +254,9 @@ void
gimp_image_map_apply (GimpImageMap *image_map,
const GeglRectangle *visible)
{
- GeglRectangle rect;
+ GimpImage *image;
+ GimpChannel *mask;
+ GeglRectangle rect;
g_return_if_fail (GIMP_IS_IMAGE_MAP (image_map));
@@ -263,18 +272,9 @@ gimp_image_map_apply (GimpImageMap *image_map,
if (! image_map->filter)
{
- GimpImage *image = gimp_item_get_image (GIMP_ITEM (image_map->drawable));
- GimpChannel *mask = gimp_image_get_mask (image);
- GeglBuffer *mask_buffer;
- GeglNode *filter_node;
- GeglNode *filter_output;
- GeglNode *input;
- GeglNode *output;
- GeglNode *apply;
- gint offset_x, offset_y;
-
- gimp_item_get_offset (GIMP_ITEM (image_map->drawable),
- &offset_x, &offset_y);
+ GeglNode *filter_node;
+ GeglNode *filter_output;
+ GeglNode *input;
image_map->filter = gimp_filter_new ("Image Map");
@@ -282,12 +282,13 @@ gimp_image_map_apply (GimpImageMap *image_map,
gegl_node_add_child (filter_node, image_map->operation);
+ image_map->applicator = gimp_applicator_new (filter_node);
+
image_map->translate = gegl_node_new_child (filter_node,
"operation", "gegl:translate",
NULL);
input = gegl_node_get_input_proxy (filter_node, "input");
- output = gegl_node_get_output_proxy (filter_node, "output");
if (gegl_node_has_pad (image_map->operation, "input") &&
gegl_node_has_pad (image_map->operation, "output"))
@@ -333,25 +334,12 @@ gimp_image_map_apply (GimpImageMap *image_map,
filter_output = image_map->translate;
}
- if (gimp_channel_is_empty (mask))
- mask_buffer = NULL;
- else
- mask_buffer = gimp_drawable_get_buffer (GIMP_DRAWABLE (mask));
-
- apply = gimp_gegl_create_apply_node (filter_output,
- rect.x,
- rect.y,
- 0, 0, 0, 0,
- mask_buffer,
- -offset_x, -offset_y,
- GIMP_OPACITY_OPAQUE,
- GIMP_REPLACE_MODE,
- gimp_drawable_get_active_mask (image_map->drawable));
-
- gegl_node_add_child (filter_node, apply);
- g_object_unref (apply);
-
- gegl_node_link_many (input, apply, output, NULL);
+ gegl_node_connect_to (filter_output, "output",
+ filter_node, "aux");
+
+ gimp_applicator_set_mode (image_map->applicator,
+ GIMP_OPACITY_OPAQUE,
+ GIMP_REPLACE_MODE);
}
if (! gimp_drawable_has_filter (image_map->drawable, image_map->filter))
@@ -362,6 +350,33 @@ gimp_image_map_apply (GimpImageMap *image_map,
"y", (gdouble) -rect.y,
NULL);
+ gimp_applicator_set_apply_offset (image_map->applicator,
+ rect.x, rect.y);
+
+ gimp_applicator_set_affect (image_map->applicator,
+ gimp_drawable_get_active_mask (image_map->drawable));
+
+ image = gimp_item_get_image (GIMP_ITEM (image_map->drawable));
+ mask = gimp_image_get_mask (image);
+
+ if (gimp_channel_is_empty (mask))
+ {
+ gimp_applicator_set_mask_buffer (image_map->applicator, NULL);
+ }
+ else
+ {
+ GeglBuffer *mask_buffer;
+ gint offset_x, offset_y;
+
+ mask_buffer = gimp_drawable_get_buffer (GIMP_DRAWABLE (mask));
+ gimp_item_get_offset (GIMP_ITEM (image_map->drawable),
+ &offset_x, &offset_y);
+
+ gimp_applicator_set_mask_buffer (image_map->applicator, mask_buffer);
+ gimp_applicator_set_mask_offset (image_map->applicator,
+ offset_x, offset_y);
+ }
+
gimp_drawable_update (image_map->drawable,
rect.x, rect.y,
rect.width, rect.height);
@@ -393,16 +408,14 @@ gimp_image_map_abort (GimpImageMap *image_map)
{
g_return_if_fail (GIMP_IS_IMAGE_MAP (image_map));
- if (! gimp_item_is_attached (GIMP_ITEM (image_map->drawable)))
- return;
-
if (gimp_drawable_has_filter (image_map->drawable, image_map->filter))
{
GeglRectangle rect;
gimp_drawable_remove_filter (image_map->drawable, image_map->filter);
- if (gimp_item_mask_intersect (GIMP_ITEM (image_map->drawable),
+ if (gimp_item_is_attached (GIMP_ITEM (image_map->drawable)) &&
+ gimp_item_mask_intersect (GIMP_ITEM (image_map->drawable),
&rect.x, &rect.y,
&rect.width, &rect.height))
{
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]