QWT 7.0.1
Loading...
Searching...
No Matches
Public Member Functions | List of all members
QwtSyntheticPointData Class Referenceabstract

Synthetic point data. More...

#include <qwt_point_data.h>

Inheritance diagram for QwtSyntheticPointData:
QwtPointSeriesData QwtArraySeriesData< QPointF > QwtSeriesData< T >

Public Member Functions

 QwtSyntheticPointData (size_t size, const QwtInterval &=QwtInterval())
 Constructor.
 
void setSize (size_t size)
 Change the number of points.
 
virtual size_t size () const QWT_OVERRIDE
 
void setInterval (const QwtInterval &)
 Set the bounding interval.
 
QwtInterval interval () const
 
virtual QRectF boundingRect () const QWT_OVERRIDE
 Calculate the bounding rectangle.
 
virtual QPointF sample (size_t index) const QWT_OVERRIDE
 Calculate the point from an index.
 
virtual double y (double x) const =0
 Calculate a y value for a x value.
 
virtual double x (size_t index) const
 Calculate a x-value from an index.
 
virtual void setRectOfInterest (const QRectF &) QWT_OVERRIDE
 Set a the "rectangle of interest".
 
QRectF rectOfInterest () const
 
- Public Member Functions inherited from QwtPointSeriesData
 QwtPointSeriesData (const QVector< QPointF > &=QVector< QPointF >())
 Constructor.
 
- Public Member Functions inherited from QwtArraySeriesData< QPointF >
 QwtArraySeriesData ()
 Constructor.
 
 QwtArraySeriesData (const QVector< QPointF > &samples)
 Constructor.
 
 QwtArraySeriesData (QVector< QPointF > &&samples)
 
void setSamples (const QVector< QPointF > &samples)
 Assign an array of samples.
 
void setSamples (QVector< QPointF > &&samples)
 
const QVector< QPointF > samples () const
 
- Public Member Functions inherited from QwtSeriesData< T >
 QwtSeriesData ()
 Constructor.
 
virtual ~QwtSeriesData ()
 Destructor.
 

Additional Inherited Members

- Protected Attributes inherited from QwtArraySeriesData< QPointF >
QVector< QPointF > m_samples
 Vector of samples.
 
- Protected Attributes inherited from QwtSeriesData< T >
QRectF cachedBoundingRect
 Can be used to cache a calculated bounding rectangle.
 

Detailed Description

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 "rectangle 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.

Example

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():
{
}
virtual double y( double x ) const
{
return qSin( x );
}
};
int main(int argc, char **argv)
{
QApplication a( argc, argv );
QwtPlot plot;
plot.setAxisScale( QwtAxis::XBottom, 0.0, 10.0 );
plot.setAxisScale( QwtAxis::YLeft, -1.0, 1.0 );
QwtPlotCurve *curve = new QwtPlotCurve( "y = sin(x)" );
curve->setData( new SinusData() );
curve->attach( &plot );
plot.show();
return a.exec();
}
A plot item, that represents a series of points.
Definition qwt_plot_curve.h:75
void attach(QwtPlot *plot)
Attach the item to a plot.
Definition qwt_plot_item.cpp:115
A 2-D plotting widget.
Definition qwt_plot.h:99
void setAxisScale(QwtAxisId, double min, double max, double stepSize=0)
Disable autoscaling and specify a fixed scale for a selected axis/为指定坐标轴关闭自动缩放并设定固定刻度范围
Definition qwt_plot_axis.cpp:596
void setData(QwtSeriesData< T > *series)
Assign a series of samples.
Definition qwt_series_store.h:192
Synthetic point data.
Definition qwt_point_data.h:176
@ XBottom
X axis below the canvas.
Definition qwt_axis.h:47
@ YLeft
Y axis left of the canvas.
Definition qwt_axis.h:41

Constructor & Destructor Documentation

◆ QwtSyntheticPointData()

QwtSyntheticPointData::QwtSyntheticPointData ( size_t  size,
const QwtInterval interval = QwtInterval() 
)

Constructor.

Parameters
sizeNumber of points
intervalBounding interval for the points
See also
setInterval(), setSize()

Member Function Documentation

◆ boundingRect()

QRectF QwtSyntheticPointData::boundingRect ( ) const
virtual

Calculate the bounding rectangle.

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 ).

Returns
Bounding rectangle

Reimplemented from QwtPointSeriesData.

◆ interval()

QwtInterval QwtSyntheticPointData::interval ( ) const
Returns
Bounding interval
See also
setInterval(), size()

◆ rectOfInterest()

QRectF QwtSyntheticPointData::rectOfInterest ( ) const
Returns
"rectangle of interest"
See also
setRectOfInterest()

◆ sample()

QPointF QwtSyntheticPointData::sample ( size_t  index) const
virtual

Calculate the point from an index.

Parameters
indexIndex
Returns
QPointF(x(index), y(x(index)));
Warning
For invalid indices ( index < 0 || index >= size() ) (0, 0) is returned.

Reimplemented from QwtArraySeriesData< QPointF >.

◆ setInterval()

void QwtSyntheticPointData::setInterval ( const QwtInterval interval)

Set the bounding interval.

Parameters
intervalInterval
See also
interval(), setSize()

◆ setRectOfInterest()

void QwtSyntheticPointData::setRectOfInterest ( const QRectF &  rect)
virtual

Set a the "rectangle 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().

See also
rectOfInterest()

Reimplemented from QwtSeriesData< T >.

◆ setSize()

void QwtSyntheticPointData::setSize ( size_t  size)

Change the number of points.

Parameters
sizeNumber of points
See also
size(), setInterval()

◆ size()

size_t QwtSyntheticPointData::size ( ) const
virtual
Returns
Number of points
See also
setSize(), interval()

Reimplemented from QwtArraySeriesData< QPointF >.

◆ x()

double QwtSyntheticPointData::x ( size_t  index) const
virtual

Calculate a x-value from an index.

x values are calculated by dividing an interval into equidistant steps. If !interval().isValid() the interval is calculated from the "rectangle of interest".

Parameters
indexIndex of the requested point
Returns
Calculated x coordinate
See also
interval(), rectOfInterest(), y()

◆ y()

virtual double QwtSyntheticPointData::y ( double  x) const
pure virtual

Calculate a y value for a x value.

Parameters
xx value
Returns
Corresponding y value

The documentation for this class was generated from the following files: