13 #include <qpainterpath.h> 34 Line(
int i1 = 0,
int i2 = 0 ):
104 numPoints = qMax( numPoints, 3U );
126 if ( points.isEmpty() )
129 QPolygonF fittedPoints;
154 path.addPolygon(
fitCurve( points ) );
163 stack.reserve( 500 );
165 const QPointF *p = points.data();
166 const int nPoints = points.size();
170 stack.push(
Line( 0, nPoints - 1 ) );
172 while ( !stack.isEmpty() )
174 const Line r = stack.pop();
177 const double vecX = p[r.
to].x() - p[r.
from].x();
178 const double vecY = p[r.
to].y() - p[r.
from].y();
180 const double vecLength = std::sqrt( vecX * vecX + vecY * vecY );
182 const double unitVecX = ( vecLength != 0.0 ) ? vecX / vecLength : 0.0;
183 const double unitVecY = ( vecLength != 0.0 ) ? vecY / vecLength : 0.0;
185 double maxDistSqr = 0.0;
186 int nVertexIndexMaxDistance = r.
from + 1;
187 for (
int i = r.
from + 1; i < r.
to; i++ )
190 const double fromVecX = p[i].x() - p[r.
from].x();
191 const double fromVecY = p[i].y() - p[r.
from].y();
193 double distToSegmentSqr;
194 if ( fromVecX * unitVecX + fromVecY * unitVecY < 0.0 )
196 distToSegmentSqr = fromVecX * fromVecX + fromVecY * fromVecY;
200 const double toVecX = p[i].x() - p[r.
to].x();
201 const double toVecY = p[i].y() - p[r.
to].y();
202 const double toVecLength = toVecX * toVecX + toVecY * toVecY;
204 const double s = toVecX * ( -unitVecX ) + toVecY * ( -unitVecY );
207 distToSegmentSqr = toVecLength;
211 distToSegmentSqr = std::fabs( toVecLength - s * s );
215 if ( maxDistSqr < distToSegmentSqr )
217 maxDistSqr = distToSegmentSqr;
218 nVertexIndexMaxDistance = i;
221 if ( maxDistSqr <= toleranceSqr )
223 usePoint[r.
from] =
true;
224 usePoint[r.
to] =
true;
228 stack.push(
Line( r.
from, nVertexIndexMaxDistance ) );
229 stack.push(
Line( nVertexIndexMaxDistance, r.
to ) );
234 for (
int i = 0; i < nPoints; i++ )
QWT_CONSTEXPR float qwtMaxF(float a, float b)
virtual ~QwtWeedingCurveFitter()
Destructor.
void setTolerance(double)
virtual QPolygonF simplify(const QPolygonF &) const
virtual QPolygonF fitCurve(const QPolygonF &) const QWT_OVERRIDE
QwtWeedingCurveFitter(double tolerance=1.0)
virtual QPainterPath fitCurvePath(const QPolygonF &) const QWT_OVERRIDE
Abstract base class for a curve fitter.