summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 20c1c16)
raw | patch | inline | side by side (parent: 20c1c16)
author | jfbarraud <jfbarraud@users.sourceforge.net> | |
Sun, 16 Mar 2008 18:24:29 +0000 (18:24 +0000) | ||
committer | jfbarraud <jfbarraud@users.sourceforge.net> | |
Sun, 16 Mar 2008 18:24:29 +0000 (18:24 +0000) |
src/live_effects/lpe-sketch.cpp | patch | blob | history |
index fcdbfefc0a4afe370949f860fa149e5996491a45..79f4d67f93f99a1fa85bec20a7bd2a501a7cee2a 100644 (file)
LPESketch::doEffect_pwd2 (Geom::Piecewise<Geom::D2<Geom::SBasis> > & pwd2_in)
{
using namespace Geom;
+ //If the input path is empty, do nothing.
+ //Note: this happens when duplicating a 3d box... dunno why.
+ if (pwd2_in.size()==0) return pwd2_in;
+
Piecewise<D2<SBasis> > output;
while (!done){
// if the start point is already too far... do nothing. (this should not happen!)
- assert (s0>=0);//this should not happen!!
if (!closed && s1>piece_total_length - ends_tolerance.get_value()*strokelength) break;
if ( closed && s0>piece_total_length + s0_initial) break;
std::vector<double> times;
times = roots(piecelength-s0);
- if (times.size()==0) break;//we should not be there.
- t0 = times[0];
+ t0 = times.at(0);//there should be one and only one solution!!
// pick a new end point (s1 = s0 + strokelength).
s1 = s0 + strokelength*(1-strokelength_rdm);
double s = total_length * ( i + tgtlength_rdm ) / (nbtangents+1.);
std::vector<double> times;
times = roots(pathlength-s);
- assert(times.size()>0);//there should be one and only one solution!
- double t = times[0];
+ double t = times.at(0);//there should be one and only one solution!
Point m_t = m(t), v_t = v(t), a_t = a(t);
//Compute tgt length according to curvature (not exceeding tgtlength) so that
// dist to origninal curve ~ 4 * (parallel_offset+tremble_size).