summaryrefslogtreecommitdiffstats
path: root/src/live_effects
diff options
context:
space:
mode:
authorJabier Arraiza Cenoz <jabier.arraiza@marker.es>2014-05-13 05:34:59 +0000
committerJabiertxof <jtx@jtx.marker.es>2014-05-13 05:34:59 +0000
commit2e6927e7c4ae6b8592dd9f13e8c286ea899e82db (patch)
tree85c2d6cb055ccce256ae829c042d8062ff914814 /src/live_effects
parentFixed a bug in bspline with snaps and 1 sice segments. Pointed by LiamW (diff)
parentPatch from Jabierxto to fix a bug I reported off-tracker. (diff)
downloadinkscape-2e6927e7c4ae6b8592dd9f13e8c286ea899e82db.tar.gz
inkscape-2e6927e7c4ae6b8592dd9f13e8c286ea899e82db.zip
Update to trunk
(bzr r13341.1.11)
Diffstat (limited to 'src/live_effects')
-rw-r--r--src/live_effects/lpe-bspline.cpp22
1 files changed, 3 insertions, 19 deletions
diff --git a/src/live_effects/lpe-bspline.cpp b/src/live_effects/lpe-bspline.cpp
index 454924d2b..edf19d1e5 100644
--- a/src/live_effects/lpe-bspline.cpp
+++ b/src/live_effects/lpe-bspline.cpp
@@ -96,7 +96,7 @@ void LPEBSpline::createAndApply(const char *name, SPDocument *doc,
}
void LPEBSpline::doEffect(SPCurve *curve) {
- if (curve->get_segment_count() < 1)
+ if (curve->get_segment_count() < 2)
return;
// Make copy of old path as it is changed during processing
Geom::PathVector const original_pathv = curve->get_pathvector();
@@ -216,26 +216,10 @@ void LPEBSpline::doEffect(SPCurve *curve) {
++curve_it1;
++curve_it2;
}
- SPCurve *out = new SPCurve();
- out->moveto(curve_it1->initialPoint());
- out->lineto(curve_it1->finalPoint());
- cubic = dynamic_cast<Geom::CubicBezier const *>(&*curve_it1);
- if (cubic) {
- SBasisOut = out->first_segment()->toSBasis();
- nextPointAt1 = SBasisOut.valueAt(Geom::nearest_point((*cubic)[1], *out->first_segment()));
- nextPointAt2 = SBasisOut.valueAt(Geom::nearest_point((*cubic)[2], *out->first_segment()));
- nextPointAt3 = out->first_segment()->finalPoint();
- } else {
- nextPointAt1 = out->first_segment()->initialPoint();
- nextPointAt2 = out->first_segment()->finalPoint();
- nextPointAt3 = out->first_segment()->finalPoint();
- }
- out->reset();
- delete out;
//Si está cerrada la curva, la cerramos sobre el valor guardado
//previamente
//Si no finalizamos en el punto final
- Geom::Point startNode = path_it->begin()->initialPoint();
+ Geom::Point startNode(0, 0);
if (path_it->closed()) {
SPCurve *start = new SPCurve();
start->moveto(path_it->begin()->initialPoint());
@@ -437,7 +421,7 @@ void LPEBSpline::doBSplineFromWidget(SPCurve *curve, double weightValue) {
}
}
//bool hasNodesSelected = LPEBspline::hasNodesSelected();
- if (curve->get_segment_count() < 1)
+ if (curve->get_segment_count() < 2)
return;
// Make copy of old path as it is changed during processing
Geom::PathVector const original_pathv = curve->get_pathvector();