[gimp/gimp-2-10] Issue #2553 - Can't Move Imported or Pasted Path
- From: Ell <ell src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gimp/gimp-2-10] Issue #2553 - Can't Move Imported or Pasted Path
- Date: Fri, 23 Nov 2018 13:49:07 +0000 (UTC)
commit 4b647c52e1c913fdfd95e6939f8c1427f146fa0a
Author: Ell <ell_se yahoo com>
Date: Fri Nov 23 08:42:35 2018 -0500
Issue #2553 - Can't Move Imported or Pasted Path
Initialize the X/Y tilt fields of improted/pasted path control
points to 0, instead of 0.5, which is the normal value for these
fields in paths. This avoids calculating bogus distances when
trying to pick the path, causing picking to fail.
(cherry picked from commit 0a123a81a3335f180e1e4aaecf63ee1253d7a6fb)
app/vectors/gimpvectors-import.c | 45 ++++++++++++++++++++++++++--------------
1 file changed, 29 insertions(+), 16 deletions(-)
---
diff --git a/app/vectors/gimpvectors-import.c b/app/vectors/gimpvectors-import.c
index 62c0cb277c..fa631eed5a 100644
--- a/app/vectors/gimpvectors-import.c
+++ b/app/vectors/gimpvectors-import.c
@@ -55,6 +55,19 @@
#include "gimp-intl.h"
+#define COORDS_INIT \
+ { \
+ .x = 0.0, \
+ .y = 0.0, \
+ .pressure = 1.0, \
+ .xtilt = 0.0, \
+ .ytilt = 0.0, \
+ .wheel = 0.5, \
+ .velocity = 0.0, \
+ .direction = 0.0 \
+ }
+
+
typedef struct
{
GQueue *stack;
@@ -743,7 +756,7 @@ svg_handler_rect_start (SvgHandler *handler,
if (width > 0.0 && height > 0.0 && rx >= 0.0 && ry >= 0.0)
{
GimpStroke *stroke;
- GimpCoords point = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords point = COORDS_INIT;
if (rx == 0.0)
rx = ry;
@@ -759,7 +772,7 @@ svg_handler_rect_start (SvgHandler *handler,
if (rx)
{
- GimpCoords end = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords end = COORDS_INIT;
end.x = x + width;
end.y = y + ry;
@@ -773,7 +786,7 @@ svg_handler_rect_start (SvgHandler *handler,
if (rx)
{
- GimpCoords end = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords end = COORDS_INIT;
end.x = x + width - rx;
end.y = y + height;
@@ -787,7 +800,7 @@ svg_handler_rect_start (SvgHandler *handler,
if (rx)
{
- GimpCoords end = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords end = COORDS_INIT;
end.x = x;
end.y = y + height - ry;
@@ -801,7 +814,7 @@ svg_handler_rect_start (SvgHandler *handler,
if (rx)
{
- GimpCoords end = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords end = COORDS_INIT;
end.x = x + rx;
end.y = y;
@@ -825,7 +838,7 @@ svg_handler_ellipse_start (SvgHandler *handler,
SvgParser *parser)
{
SvgPath *path = g_slice_new0 (SvgPath);
- GimpCoords center = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords center = COORDS_INIT;
gdouble rx = 0.0;
gdouble ry = 0.0;
gdouble xres;
@@ -898,8 +911,8 @@ svg_handler_line_start (SvgHandler *handler,
SvgParser *parser)
{
SvgPath *path = g_slice_new0 (SvgPath);
- GimpCoords start = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
- GimpCoords end = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords start = COORDS_INIT;
+ GimpCoords end = COORDS_INIT;
GimpStroke *stroke;
gdouble xres;
gdouble yres;
@@ -1574,7 +1587,7 @@ static void
parse_path_do_cmd (ParsePathContext *ctx,
gboolean final)
{
- GimpCoords coords = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords coords = COORDS_INIT;
switch (ctx->cmd)
{
@@ -1618,8 +1631,8 @@ parse_path_do_cmd (ParsePathContext *ctx,
/* curveto */
if (ctx->param == 6 || final)
{
- GimpCoords ctrl1 = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
- GimpCoords ctrl2 = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords ctrl1 = COORDS_INIT;
+ GimpCoords ctrl2 = COORDS_INIT;
parse_path_default_xy (ctx, 6);
@@ -1640,8 +1653,8 @@ parse_path_do_cmd (ParsePathContext *ctx,
/* smooth curveto */
if (ctx->param == 4 || final)
{
- GimpCoords ctrl1 = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
- GimpCoords ctrl2 = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords ctrl1 = COORDS_INIT;
+ GimpCoords ctrl2 = COORDS_INIT;
parse_path_default_xy (ctx, 4);
@@ -1688,7 +1701,7 @@ parse_path_do_cmd (ParsePathContext *ctx,
/* quadratic bezier curveto */
if (ctx->param == 4 || final)
{
- GimpCoords ctrl = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords ctrl = COORDS_INIT;
parse_path_default_xy (ctx, 4);
@@ -1707,7 +1720,7 @@ parse_path_do_cmd (ParsePathContext *ctx,
/* truetype quadratic bezier curveto */
if (ctx->param == 2 || final)
{
- GimpCoords ctrl = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords ctrl = COORDS_INIT;
parse_path_default_xy (ctx, 2);
@@ -1724,7 +1737,7 @@ parse_path_do_cmd (ParsePathContext *ctx,
{
if (ctx->param > 2)
{
- GimpCoords ctrl = { 0.0, 0.0, 1.0, 0.5, 0.5, 0.5 };
+ GimpCoords ctrl = COORDS_INIT;
parse_path_default_xy (ctx, 4);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]