QWT 7.0.1
Loading...
Searching...
No Matches
qwt_spline_parametrization.h
1/******************************************************************************
2 * Qwt Widget Library
3 * Copyright (C) 1997 Josef Wilgen
4 * Copyright (C) 2002 Uwe Rathmann
5 *
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the Qwt License, Version 1.0
8 *
9 * Modified by ChenZongYan in 2024 <czy.t@163.com>
10 * Summary of major modifications (see ChangeLog.md for full history):
11 * 1. CMake build system & C++11 throughout.
12 * 2. Core panner/ zoomer refactored:
13 * - QwtPanner → QwtCachePanner (pixmap-cache version)
14 * - New real-time QwtPlotPanner derived from QwtPicker.
15 * 3. Zoomer supports multi-axis.
16 * 4. Parasite-plot framework:
17 * - QwtFigure, QwtPlotParasiteLayout, QwtPlotTransparentCanvas,
18 * - QwtPlotScaleEventDispatcher, built-in pan/zoom on axis.
19 * 5. New picker: QwtPlotSeriesDataPicker (works with date axis).
20 * 6. Raster & color-map extensions:
21 * - QwtGridRasterData (2-D table + interpolation)
22 * - QwtLinearColorMap::stopColors(), stopPos() API rename.
23 * 7. Bar-chart: expose pen/brush control.
24 * 8. Amalgamated build: single QwtPlot.h / QwtPlot.cpp pair in src-amalgamate.
25 *****************************************************************************/
26
27#ifndef QWT_SPLINE_PARAMETRIZATION_H
28#define QWT_SPLINE_PARAMETRIZATION_H
29
30#include "qwt_global.h"
31#include "qwt_math.h"
32
33#include <qpoint.h>
34
62{
63 public:
65 enum Type
66 {
72
78
90
100
112
113
122 ParameterManhattan
123 };
124
125 explicit QwtSplineParametrization( int type );
127
128 int type() const;
129
130 virtual double valueIncrement( const QPointF&, const QPointF& ) const;
131
132 static double valueIncrementX( const QPointF&, const QPointF& );
133 static double valueIncrementY( const QPointF&, const QPointF& );
134 static double valueIncrementUniform( const QPointF&, const QPointF& );
135 static double valueIncrementChordal( const QPointF&, const QPointF& );
136 static double valueIncrementCentripetal( const QPointF&, const QPointF& );
137 static double valueIncrementManhattan( const QPointF&, const QPointF& );
138
139 private:
140 const int m_type;
141};
142
152 const QPointF& point1, const QPointF& point2 )
153{
154 return point2.x() - point1.x();
155}
156
166 const QPointF& point1, const QPointF& point2 )
167{
168 return point2.y() - point1.y();
169}
170
180 const QPointF& point1, const QPointF& point2 )
181{
182 Q_UNUSED( point1 )
183 Q_UNUSED( point2 )
184
185 return 1.0;
186}
187
197 const QPointF& point1, const QPointF& point2 )
198{
199 const double dx = point2.x() - point1.x();
200 const double dy = point2.y() - point1.y();
201
202 return std::sqrt( dx * dx + dy * dy );
203}
204
214 const QPointF& point1, const QPointF& point2 )
215{
216 return std::sqrt( valueIncrementChordal( point1, point2 ) );
217}
218
228 const QPointF& point1, const QPointF& point2 )
229{
230 return qAbs( point2.x() - point1.x() ) + qAbs( point2.y() - point1.y() );
231}
232
233#endif
Curve parametrization used for a spline interpolation.
Definition qwt_spline_parametrization.h:62
static double valueIncrementChordal(const QPointF &, const QPointF &)
Calculate the ParameterChordal value increment for 2 points.
Definition qwt_spline_parametrization.h:196
static double valueIncrementCentripetal(const QPointF &, const QPointF &)
Calculate the ParameterCentripetal value increment for 2 points.
Definition qwt_spline_parametrization.h:213
static double valueIncrementX(const QPointF &, const QPointF &)
Calculate the ParameterX value increment for 2 points.
Definition qwt_spline_parametrization.h:151
static double valueIncrementUniform(const QPointF &, const QPointF &)
Calculate the ParameterUniform value increment.
Definition qwt_spline_parametrization.h:179
Type
Parametrization type.
Definition qwt_spline_parametrization.h:66
@ ParameterY
No parametrization: t[i] = y[i].
Definition qwt_spline_parametrization.h:77
@ ParameterCentripetal
Centripetal parametrization.
Definition qwt_spline_parametrization.h:111
@ ParameterX
No parametrization: t[i] = x[i].
Definition qwt_spline_parametrization.h:71
@ ParameterUniform
Uniform parametrization: t[i] = i;.
Definition qwt_spline_parametrization.h:89
@ ParameterChordal
Parametrization using the chordal length between two control points.
Definition qwt_spline_parametrization.h:99
static double valueIncrementManhattan(const QPointF &, const QPointF &)
Calculate the ParameterManhattan value increment for 2 points.
Definition qwt_spline_parametrization.h:227
static double valueIncrementY(const QPointF &, const QPointF &)
Calculate the ParameterY value increment for 2 points.
Definition qwt_spline_parametrization.h:165