Qwt User's Guide
svn
|
#include <qwt_series_data.h>
Inherits QwtSeriesData< QPointF >.
Public Member Functions | |
virtual QRectF | boundingRect () const |
QwtInterval | interval () const |
QwtSyntheticPointData (size_t size, const QwtInterval &=QwtInterval()) | |
QRectF | rectOfInterest () const |
virtual QPointF | sample (size_t i) const |
void | setInterval (const QwtInterval &) |
virtual void | setRectOfInterest (const QRectF &) |
void | setSize (size_t size) |
size_t | size () const |
virtual double | x (uint index) const |
virtual double | y (double x) const =0 |
Protected Attributes | |
QRectF | d_boundingRect |
Synthetic point data.
QwtSyntheticPointData provides a fixed number of points for an interval. The points are calculated in equidistant steps in x-direction.
If the interval is invalid, the points are calculated for the "rect of interest", what normally is the displayed area on the plot canvas. In this mode you get different levels of detail, when zooming in/out.
The following example shows how to implement a sinus curve.
#include <cmath> #include <qwt_series_data.h> #include <qwt_plot_curve.h> #include <qwt_plot.h> #include <qapplication.h> class SinusData: public QwtSyntheticPointData { public: SinusData(): QwtSyntheticPointData(100) { } virtual double y(double x) const { return qSin(x); } }; int main(int argc, char **argv) { QApplication a(argc, argv); QwtPlot plot; plot.setAxisScale(QwtPlot::xBottom, 0.0, 10.0); plot.setAxisScale(QwtPlot::yLeft, -1.0, 1.0); QwtPlotCurve *curve = new QwtPlotCurve("y = sin(x)"); curve->setData(SinusData()); curve->attach(&plot); plot.show(); return a.exec(); }
QwtSyntheticPointData::QwtSyntheticPointData | ( | size_t | size, |
const QwtInterval & | interval = QwtInterval() |
||
) |
Constructor
size | Number of points |
interval | Bounding interval for the points |
QRectF QwtSyntheticPointData::boundingRect | ( | ) | const [virtual] |
Calculate the bounding rect.
This implementation iterates over all points, what could often be implemented much faster using the characteristics of the series. When there are many points it is recommended to overload and reimplement this method using the characteristics of the series ( if possible ).
Implements QwtSeriesData< QPointF >.
QwtInterval QwtSyntheticPointData::interval | ( | ) | const |
QRectF QwtSyntheticPointData::rectOfInterest | ( | ) | const |
QPointF QwtSyntheticPointData::sample | ( | size_t | index | ) | const [virtual] |
Calculate the point from an index
index | Index |
Implements QwtSeriesData< QPointF >.
void QwtSyntheticPointData::setInterval | ( | const QwtInterval & | interval | ) |
void QwtSyntheticPointData::setRectOfInterest | ( | const QRectF & | rect | ) | [virtual] |
Set a the "rect of interest"
QwtPlotSeriesItem defines the current area of the plot canvas as "rect of interest" ( QwtPlotSeriesItem::updateScaleDiv() ).
If interval().isValid() == false the x values are calculated in the interval rect.left() -> rect.right().
Reimplemented from QwtSeriesData< QPointF >.
void QwtSyntheticPointData::setSize | ( | size_t | size | ) |
size_t QwtSyntheticPointData::size | ( | ) | const [virtual] |
double QwtSyntheticPointData::x | ( | uint | index | ) | const [virtual] |
Calculate a x-value from an index
x values are calculated by deviding an interval into equidistant steps. If !interval().isValid() the interval is calculated from the "rect of interest".
virtual double QwtSyntheticPointData::y | ( | double | x | ) | const [pure virtual] |
Calculate a y value for a x value
x | x value |
QRectF QwtSeriesData< QPointF >::d_boundingRect [mutable, protected, inherited] |
Can be used to cache a calculated bounding rectangle.