[gimp] app: use temporary canvas items for exposing guides and sample points
- From: Michael Natterer <mitch src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp] app: use temporary canvas items for exposing guides and sample points
- Date: Thu, 30 Sep 2010 07:03:17 +0000 (UTC)
commit 7f1cadddd04bebf65b13ab3e4184269b293f56c8
Author: Michael Natterer <mitch gimp org>
Date: Thu Sep 30 08:59:36 2010 +0200
app: use temporary canvas items for exposing guides and sample points
and remove gimp_display_shell_expose_guide() and _sample_point().
app/display/gimpdisplayshell-expose.c | 64 -------------------------------
app/display/gimpdisplayshell-expose.h | 24 +++++-------
app/display/gimpdisplayshell-handlers.c | 25 +++++++++++-
3 files changed, 33 insertions(+), 80 deletions(-)
---
diff --git a/app/display/gimpdisplayshell-expose.c b/app/display/gimpdisplayshell-expose.c
index cb0dd02..c29645e 100644
--- a/app/display/gimpdisplayshell-expose.c
+++ b/app/display/gimpdisplayshell-expose.c
@@ -24,9 +24,6 @@
#include "display-types.h"
-#include "core/gimpguide.h"
-#include "core/gimpsamplepoint.h"
-
#include "vectors/gimpvectors.h"
#include "gimpcanvasitem.h"
@@ -89,67 +86,6 @@ gimp_display_shell_expose_item (GimpDisplayShell *shell,
}
void
-gimp_display_shell_expose_guide (GimpDisplayShell *shell,
- GimpGuide *guide)
-{
- gint position;
- gint x, y;
-
- g_return_if_fail (GIMP_IS_DISPLAY_SHELL (shell));
- g_return_if_fail (GIMP_IS_GUIDE (guide));
-
- position = gimp_guide_get_position (guide);
-
- if (position < 0)
- return;
-
- gimp_display_shell_transform_xy (shell,
- position, position,
- &x, &y);
-
- switch (gimp_guide_get_orientation (guide))
- {
- case GIMP_ORIENTATION_HORIZONTAL:
- gimp_display_shell_expose_area (shell, 0, y, shell->disp_width, 1);
- break;
-
- case GIMP_ORIENTATION_VERTICAL:
- gimp_display_shell_expose_area (shell, x, 0, 1, shell->disp_height);
- break;
-
- default:
- break;
- }
-}
-
-void
-gimp_display_shell_expose_sample_point (GimpDisplayShell *shell,
- GimpSamplePoint *sample_point)
-{
- gdouble x, y;
- gint x1, y1, x2, y2;
-
- g_return_if_fail (GIMP_IS_DISPLAY_SHELL (shell));
- g_return_if_fail (sample_point != NULL);
-
- if (sample_point->x < 0)
- return;
-
- gimp_display_shell_transform_xy_f (shell,
- sample_point->x + 0.5,
- sample_point->y + 0.5,
- &x, &y);
-
- x1 = MAX (0, floor (x - GIMP_SAMPLE_POINT_DRAW_SIZE));
- y1 = MAX (0, floor (y - GIMP_SAMPLE_POINT_DRAW_SIZE));
- x2 = MIN (shell->disp_width, ceil (x + GIMP_SAMPLE_POINT_DRAW_SIZE));
- y2 = MIN (shell->disp_height, ceil (y + GIMP_SAMPLE_POINT_DRAW_SIZE));
-
- /* HACK: add 4 instead of 1 so the number gets cleared too */
- gimp_display_shell_expose_area (shell, x1, y1, x2 - x1 + 4, y2 - y1 + 4);
-}
-
-void
gimp_display_shell_expose_vectors (GimpDisplayShell *shell,
GimpVectors *vectors)
{
diff --git a/app/display/gimpdisplayshell-expose.h b/app/display/gimpdisplayshell-expose.h
index 5546097..58ea2fb 100644
--- a/app/display/gimpdisplayshell-expose.h
+++ b/app/display/gimpdisplayshell-expose.h
@@ -19,20 +19,16 @@
#define __GIMP_DISPLAY_SHELL_EXPOSE_H__
-void gimp_display_shell_expose_area (GimpDisplayShell *shell,
- gint x,
- gint y,
- gint w,
- gint h);
-void gimp_display_shell_expose_item (GimpDisplayShell *shell,
- GimpCanvasItem *item);
-void gimp_display_shell_expose_guide (GimpDisplayShell *shell,
- GimpGuide *guide);
-void gimp_display_shell_expose_sample_point (GimpDisplayShell *shell,
- GimpSamplePoint *sample_point);
-void gimp_display_shell_expose_vectors (GimpDisplayShell *shell,
- GimpVectors *vectors);
-void gimp_display_shell_expose_full (GimpDisplayShell *shell);
+void gimp_display_shell_expose_area (GimpDisplayShell *shell,
+ gint x,
+ gint y,
+ gint w,
+ gint h);
+void gimp_display_shell_expose_item (GimpDisplayShell *shell,
+ GimpCanvasItem *item);
+void gimp_display_shell_expose_vectors (GimpDisplayShell *shell,
+ GimpVectors *vectors);
+void gimp_display_shell_expose_full (GimpDisplayShell *shell);
#endif /* __GIMP_DISPLAY_SHELL_EXPOSE_H__ */
diff --git a/app/display/gimpdisplayshell-handlers.c b/app/display/gimpdisplayshell-handlers.c
index ff65d8b..1e9f8c5 100644
--- a/app/display/gimpdisplayshell-handlers.c
+++ b/app/display/gimpdisplayshell-handlers.c
@@ -31,16 +31,20 @@
#include "core/gimp.h"
#include "core/gimpcontainer.h"
+#include "core/gimpguide.h"
#include "core/gimpimage.h"
#include "core/gimpimage-grid.h"
#include "core/gimpimage-quick-mask.h"
#include "core/gimpitem.h"
+#include "core/gimpsamplepoint.h"
#include "core/gimptreehandler.h"
#include "file/file-utils.h"
#include "widgets/gimpwidgets-utils.h"
+#include "gimpcanvasguide.h"
+#include "gimpcanvassamplepoint.h"
#include "gimpdisplay.h"
#include "gimpdisplayshell.h"
#include "gimpdisplayshell-appearance.h"
@@ -463,7 +467,15 @@ gimp_display_shell_update_guide_handler (GimpImage *image,
GimpGuide *guide,
GimpDisplayShell *shell)
{
- gimp_display_shell_expose_guide (shell, guide);
+ GimpCanvasItem *item;
+
+ item = gimp_canvas_guide_new (gimp_guide_get_orientation (guide),
+ gimp_guide_get_position (guide));
+ g_object_set (item, "guide-style", TRUE, NULL);
+
+ gimp_display_shell_expose_item (shell, item);
+
+ g_object_unref (item);
}
static void
@@ -471,7 +483,16 @@ gimp_display_shell_update_sample_point_handler (GimpImage *image,
GimpSamplePoint *sample_point,
GimpDisplayShell *shell)
{
- gimp_display_shell_expose_sample_point (shell, sample_point);
+ GimpCanvasItem *item;
+
+ item = gimp_canvas_sample_point_new (sample_point->x,
+ sample_point->y,
+ 0 /* eek */);
+ g_object_set (item, "sample-point-style", TRUE, NULL);
+
+ gimp_display_shell_expose_item (shell, item);
+
+ g_object_unref (item);
}
static void
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]