[gimp/goat-invasion: 280/325] app: add gimp_gegl_progress_connect()
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/goat-invasion: 280/325] app: add gimp_gegl_progress_connect()
- Date: Fri, 30 Mar 2012 09:57:47 +0000 (UTC)
commit ec71dc50e74f07681ea90ddac5d6beaf4f937dbe
Author: Michael Natterer <mitch gimp org>
Date: Tue Mar 27 17:06:44 2012 +0200
app: add gimp_gegl_progress_connect()
which connects to notify::progress of the operation inside a node an
updates a GimpProgress accordingly.
app/gegl/gimp-gegl-utils.c | 57 ++++++++++++++++++++++++++++++++++++++++++++
app/gegl/gimp-gegl-utils.h | 4 +++
2 files changed, 61 insertions(+), 0 deletions(-)
---
diff --git a/app/gegl/gimp-gegl-utils.c b/app/gegl/gimp-gegl-utils.c
index 52abde5..3feeb01 100644
--- a/app/gegl/gimp-gegl-utils.c
+++ b/app/gegl/gimp-gegl-utils.c
@@ -27,6 +27,8 @@
#include "base/temp-buf.h"
#include "base/tile-manager.h"
+#include "core/gimpprogress.h"
+
#include "gimp-gegl-utils.h"
#include "gimptilebackendtilemanager.h"
@@ -290,3 +292,58 @@ gimp_gegl_color_new (const GimpRGB *rgb)
return color;
}
+
+static void
+gimp_gegl_progress_notify (GObject *object,
+ const GParamSpec *pspec,
+ GimpProgress *progress)
+{
+ const gchar *text;
+ gdouble value;
+
+ g_object_get (object, "progress", &value, NULL);
+
+ text = g_object_get_data (object, "gimp-progress-text");
+
+ if (text)
+ {
+ if (value == 0.0)
+ {
+ gimp_progress_start (progress, text, FALSE);
+ return;
+ }
+ else if (value == 1.0)
+ {
+ gimp_progress_end (progress);
+ return;
+ }
+ }
+
+ gimp_progress_set_value (progress, value);
+}
+
+void
+gimp_gegl_progress_connect (GeglNode *node,
+ GimpProgress *progress,
+ const gchar *text)
+{
+ GObject *operation = NULL;
+
+ g_return_if_fail (GEGL_IS_NODE (node));
+ g_return_if_fail (GIMP_IS_PROGRESS (progress));
+
+ g_object_get (node, "gegl-operation", &operation, NULL);
+
+ g_return_if_fail (operation != NULL);
+
+ g_signal_connect (operation, "notify::progress",
+ G_CALLBACK (gimp_gegl_progress_notify),
+ progress);
+
+ if (text)
+ g_object_set_data_full (operation,
+ "gimp-progress-text", g_strdup (text),
+ (GDestroyNotify) g_free);
+
+ g_object_unref (operation);
+}
diff --git a/app/gegl/gimp-gegl-utils.h b/app/gegl/gimp-gegl-utils.h
index 959db0b..fdbb89c 100644
--- a/app/gegl/gimp-gegl-utils.h
+++ b/app/gegl/gimp-gegl-utils.h
@@ -50,6 +50,10 @@ void gimp_gegl_buffer_refetch_tiles (GeglBuffer *buffer)
GeglColor * gimp_gegl_color_new (const GimpRGB *rgb);
+void gimp_gegl_progress_connect (GeglNode *node,
+ GimpProgress *progress,
+ const gchar *text);
+
#define GIMP_GEGL_RECT(x,y,w,h) (&((GeglRectangle){(x), (y), (w), (h)}))
#endif /* __GIMP_GEGL_UTILS_H__ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]