diff options
| author | bulia byak <buliabyak@gmail.com> | 2006-11-18 06:38:51 +0000 |
|---|---|---|
| committer | buliabyak <buliabyak@users.sourceforge.net> | 2006-11-18 06:38:51 +0000 |
| commit | 46d32c358865bd4d23126a7382668f23e783d33e (patch) | |
| tree | 91ea2d0e75c3cb261d8f7aae8ba496be90cb8796 /src/dyna-draw-context.cpp | |
| parent | patch 1219308 for embedding type 1 fonts into ps/eps output (diff) | |
| download | inkscape-46d32c358865bd4d23126a7382668f23e783d33e.tar.gz inkscape-46d32c358865bd4d23126a7382668f23e783d33e.zip | |
correct the cap rounding in the temporary (red) shape
(bzr r1978)
Diffstat (limited to 'src/dyna-draw-context.cpp')
| -rw-r--r-- | src/dyna-draw-context.cpp | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/src/dyna-draw-context.cpp b/src/dyna-draw-context.cpp index 91079aaa4..7285f7b37 100644 --- a/src/dyna-draw-context.cpp +++ b/src/dyna-draw-context.cpp @@ -896,14 +896,18 @@ static void draw_temporary_box(SPDynaDrawContext *dc) { sp_curve_reset(dc->currentcurve); - sp_curve_moveto(dc->currentcurve, dc->point1[0]); - for (gint i = 1; i < dc->npoints; i++) { + + sp_curve_moveto(dc->currentcurve, dc->point1[dc->npoints-1]); + for (gint i = dc->npoints-2; i >= 0; i--) { sp_curve_lineto(dc->currentcurve, dc->point1[i]); } - for (gint i = dc->npoints-1; i >= 0; i--) { + for (gint i = 0; i < dc->npoints; i++) { sp_curve_lineto(dc->currentcurve, dc->point2[i]); } - add_cap(dc->currentcurve, dc->point2[1], dc->point2[0], dc->point1[0], dc->point1[1], dc->cap_rounding); + if (dc->npoints >= 2) { + add_cap(dc->currentcurve, dc->point2[dc->npoints-2], dc->point2[dc->npoints-1], dc->point1[dc->npoints-1], dc->point1[dc->npoints-2], dc->cap_rounding); + } + sp_curve_closepath(dc->currentcurve); sp_canvas_bpath_set_bpath(SP_CANVAS_BPATH(dc->currentshape), dc->currentcurve); } |
