app: use temporary canvas items for exposing guides and sample points
and remove gimp_display_shell_expose_guide() and _sample_point().
This commit is contained in:
@ -24,9 +24,6 @@
|
|||||||
|
|
||||||
#include "display-types.h"
|
#include "display-types.h"
|
||||||
|
|
||||||
#include "core/gimpguide.h"
|
|
||||||
#include "core/gimpsamplepoint.h"
|
|
||||||
|
|
||||||
#include "vectors/gimpvectors.h"
|
#include "vectors/gimpvectors.h"
|
||||||
|
|
||||||
#include "gimpcanvasitem.h"
|
#include "gimpcanvasitem.h"
|
||||||
@ -88,67 +85,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
|
void
|
||||||
gimp_display_shell_expose_vectors (GimpDisplayShell *shell,
|
gimp_display_shell_expose_vectors (GimpDisplayShell *shell,
|
||||||
GimpVectors *vectors)
|
GimpVectors *vectors)
|
||||||
|
@ -19,20 +19,16 @@
|
|||||||
#define __GIMP_DISPLAY_SHELL_EXPOSE_H__
|
#define __GIMP_DISPLAY_SHELL_EXPOSE_H__
|
||||||
|
|
||||||
|
|
||||||
void gimp_display_shell_expose_area (GimpDisplayShell *shell,
|
void gimp_display_shell_expose_area (GimpDisplayShell *shell,
|
||||||
gint x,
|
gint x,
|
||||||
gint y,
|
gint y,
|
||||||
gint w,
|
gint w,
|
||||||
gint h);
|
gint h);
|
||||||
void gimp_display_shell_expose_item (GimpDisplayShell *shell,
|
void gimp_display_shell_expose_item (GimpDisplayShell *shell,
|
||||||
GimpCanvasItem *item);
|
GimpCanvasItem *item);
|
||||||
void gimp_display_shell_expose_guide (GimpDisplayShell *shell,
|
void gimp_display_shell_expose_vectors (GimpDisplayShell *shell,
|
||||||
GimpGuide *guide);
|
GimpVectors *vectors);
|
||||||
void gimp_display_shell_expose_sample_point (GimpDisplayShell *shell,
|
void gimp_display_shell_expose_full (GimpDisplayShell *shell);
|
||||||
GimpSamplePoint *sample_point);
|
|
||||||
void gimp_display_shell_expose_vectors (GimpDisplayShell *shell,
|
|
||||||
GimpVectors *vectors);
|
|
||||||
void gimp_display_shell_expose_full (GimpDisplayShell *shell);
|
|
||||||
|
|
||||||
|
|
||||||
#endif /* __GIMP_DISPLAY_SHELL_EXPOSE_H__ */
|
#endif /* __GIMP_DISPLAY_SHELL_EXPOSE_H__ */
|
||||||
|
@ -31,16 +31,20 @@
|
|||||||
|
|
||||||
#include "core/gimp.h"
|
#include "core/gimp.h"
|
||||||
#include "core/gimpcontainer.h"
|
#include "core/gimpcontainer.h"
|
||||||
|
#include "core/gimpguide.h"
|
||||||
#include "core/gimpimage.h"
|
#include "core/gimpimage.h"
|
||||||
#include "core/gimpimage-grid.h"
|
#include "core/gimpimage-grid.h"
|
||||||
#include "core/gimpimage-quick-mask.h"
|
#include "core/gimpimage-quick-mask.h"
|
||||||
#include "core/gimpitem.h"
|
#include "core/gimpitem.h"
|
||||||
|
#include "core/gimpsamplepoint.h"
|
||||||
#include "core/gimptreehandler.h"
|
#include "core/gimptreehandler.h"
|
||||||
|
|
||||||
#include "file/file-utils.h"
|
#include "file/file-utils.h"
|
||||||
|
|
||||||
#include "widgets/gimpwidgets-utils.h"
|
#include "widgets/gimpwidgets-utils.h"
|
||||||
|
|
||||||
|
#include "gimpcanvasguide.h"
|
||||||
|
#include "gimpcanvassamplepoint.h"
|
||||||
#include "gimpdisplay.h"
|
#include "gimpdisplay.h"
|
||||||
#include "gimpdisplayshell.h"
|
#include "gimpdisplayshell.h"
|
||||||
#include "gimpdisplayshell-appearance.h"
|
#include "gimpdisplayshell-appearance.h"
|
||||||
@ -463,7 +467,15 @@ gimp_display_shell_update_guide_handler (GimpImage *image,
|
|||||||
GimpGuide *guide,
|
GimpGuide *guide,
|
||||||
GimpDisplayShell *shell)
|
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
|
static void
|
||||||
@ -471,7 +483,16 @@ gimp_display_shell_update_sample_point_handler (GimpImage *image,
|
|||||||
GimpSamplePoint *sample_point,
|
GimpSamplePoint *sample_point,
|
||||||
GimpDisplayShell *shell)
|
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
|
static void
|
||||||
|
Reference in New Issue
Block a user