123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337 |
- /* -*- mode: C++ ; c-file-style: "stroustrup" -*- *****************************
- * Qwt Widget Library
- * Copyright (C) 1997 Josef Wilgen
- * Copyright (C) 2002 Uwe Rathmann
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the Qwt License, Version 1.0
- *****************************************************************************/
- #ifndef QWT_PLOT_CURVE_H
- #define QWT_PLOT_CURVE_H
- #include "qwt_global.h"
- #include "qwt_plot_seriesitem.h"
- #include "qwt_series_data.h"
- #include "qwt_text.h"
- #include <qpen.h>
- #include <qstring.h>
- class QPainter;
- class QPolygonF;
- class QwtScaleMap;
- class QwtSymbol;
- class QwtCurveFitter;
- /*!
- \brief A plot item, that represents a series of points
- A curve is the representation of a series of points in the x-y plane.
- It supports different display styles, interpolation ( f.e. spline )
- and symbols.
- \par Usage
- <dl><dt>a) Assign curve properties</dt>
- <dd>When a curve is created, it is configured to draw black solid lines
- with in QwtPlotCurve::Lines style and no symbols.
- You can change this by calling
- setPen(), setStyle() and setSymbol().</dd>
- <dt>b) Connect/Assign data.</dt>
- <dd>QwtPlotCurve gets its points using a QwtSeriesData object offering
- a bridge to the real storage of the points ( like QAbstractItemModel ).
- There are several convenience classes derived from QwtSeriesData, that also store
- the points inside ( like QStandardItemModel ). QwtPlotCurve also offers
- a couple of variations of setSamples(), that build QwtSeriesData objects from
- arrays internally.</dd>
- <dt>c) Attach the curve to a plot</dt>
- <dd>See QwtPlotItem::attach()
- </dd></dl>
- \par Example:
- see examples/bode
- \sa QwtPointSeriesData, QwtSymbol, QwtScaleMap
- */
- class QWT_EXPORT QwtPlotCurve:
- public QwtPlotSeriesItem, public QwtSeriesStore<QPointF>
- {
- public:
- /*!
- Curve styles.
- \sa setStyle(), style()
- */
- enum CurveStyle
- {
- /*!
- Don't draw a curve. Note: This doesn't affect the symbols.
- */
- NoCurve = -1,
- /*!
- Connect the points with straight lines. The lines might
- be interpolated depending on the 'Fitted' attribute. Curve
- fitting can be configured using setCurveFitter().
- */
- Lines,
- /*!
- Draw vertical or horizontal sticks ( depending on the
- orientation() ) from a baseline which is defined by setBaseline().
- */
- Sticks,
- /*!
- Connect the points with a step function. The step function
- is drawn from the left to the right or vice versa,
- depending on the QwtPlotCurve::Inverted attribute.
- */
- Steps,
- /*!
- Draw dots at the locations of the data points. Note:
- This is different from a dotted line (see setPen()), and faster
- as a curve in QwtPlotCurve::NoStyle style and a symbol
- painting a point.
- */
- Dots,
- /*!
- Styles >= QwtPlotCurve::UserCurve are reserved for derived
- classes of QwtPlotCurve that overload drawCurve() with
- additional application specific curve types.
- */
- UserCurve = 100
- };
- /*!
- Attribute for drawing the curve
- \sa setCurveAttribute(), testCurveAttribute(), curveFitter()
- */
- enum CurveAttribute
- {
- /*!
- For QwtPlotCurve::Steps only.
- Draws a step function from the right to the left.
- */
- Inverted = 0x01,
- /*!
- Only in combination with QwtPlotCurve::Lines
- A QwtCurveFitter tries to
- interpolate/smooth the curve, before it is painted.
- \note Curve fitting requires temporary memory
- for calculating coefficients and additional points.
- If painting in QwtPlotCurve::Fitted mode is slow it might be better
- to fit the points, before they are passed to QwtPlotCurve.
- */
- Fitted = 0x02
- };
- //! Curve attributes
- typedef QFlags<CurveAttribute> CurveAttributes;
- /*!
- Attributes how to represent the curve on the legend
- \sa setLegendAttribute(), testLegendAttribute(),
- QwtPlotItem::legendData(), legendIcon()
- */
- enum LegendAttribute
- {
- /*!
- QwtPlotCurve tries to find a color representing the curve
- and paints a rectangle with it.
- */
- LegendNoAttribute = 0x00,
- /*!
- If the style() is not QwtPlotCurve::NoCurve a line
- is painted with the curve pen().
- */
- LegendShowLine = 0x01,
- /*!
- If the curve has a valid symbol it is painted.
- */
- LegendShowSymbol = 0x02,
- /*!
- If the curve has a brush a rectangle filled with the
- curve brush() is painted.
- */
- LegendShowBrush = 0x04
- };
- //! Legend attributes
- typedef QFlags<LegendAttribute> LegendAttributes;
- /*!
- Attributes to modify the drawing algorithm.
- The default setting enables ClipPolygons | FilterPoints
- \sa setPaintAttribute(), testPaintAttribute()
- */
- enum PaintAttribute
- {
- /*!
- Clip polygons before painting them. In situations, where points
- are far outside the visible area (f.e when zooming deep) this
- might be a substantial improvement for the painting performance
- */
- ClipPolygons = 0x01,
- /*!
- Tries to reduce the data that has to be painted, by sorting out
- duplicates, or paintings outside the visible area. Might have a
- notable impact on curves with many close points.
- Only a couple of very basic filtering algorithms are implemented.
- */
- FilterPoints = 0x02,
- /*!
- Minimize memory usage that is temporarily needed for the
- translated points, before they get painted.
- This might slow down the performance of painting
- */
- MinimizeMemory = 0x04,
- /*!
- Render the points to a temporary image and paint the image.
- This is a very special optimization for Dots style, when
- having a huge amount of points.
- With a reasonable number of points QPainter::drawPoints()
- will be faster.
- */
- ImageBuffer = 0x08
- };
- //! Paint attributes
- typedef QFlags<PaintAttribute> PaintAttributes;
- explicit QwtPlotCurve( const QString &title = QString() );
- explicit QwtPlotCurve( const QwtText &title );
- virtual ~QwtPlotCurve();
- virtual int rtti() const;
- void setPaintAttribute( PaintAttribute, bool on = true );
- bool testPaintAttribute( PaintAttribute ) const;
- void setLegendAttribute( LegendAttribute, bool on = true );
- bool testLegendAttribute( LegendAttribute ) const;
- #ifndef QWT_NO_COMPAT
- void setRawSamples( const double *xData, const double *yData, int size );
- void setSamples( const double *xData, const double *yData, int size );
- void setSamples( const QVector<double> &xData, const QVector<double> &yData );
- #endif
- void setSamples( const QVector<QPointF> & );
- void setSamples( QwtSeriesData<QPointF> * );
- int closestPoint( const QPoint &pos, double *dist = NULL ) const;
- double minXValue() const;
- double maxXValue() const;
- double minYValue() const;
- double maxYValue() const;
- void setCurveAttribute( CurveAttribute, bool on = true );
- bool testCurveAttribute( CurveAttribute ) const;
- void setPen( const QColor &, qreal width = 0.0, Qt::PenStyle = Qt::SolidLine );
- void setPen( const QPen & );
- const QPen &pen() const;
- void setBrush( const QBrush & );
- const QBrush &brush() const;
- void setBaseline( double );
- double baseline() const;
- void setStyle( CurveStyle style );
- CurveStyle style() const;
- void setSymbol( QwtSymbol * );
- const QwtSymbol *symbol() const;
- void setCurveFitter( QwtCurveFitter * );
- QwtCurveFitter *curveFitter() const;
- virtual void drawSeries( QPainter *,
- const QwtScaleMap &xMap, const QwtScaleMap &yMap,
- const QRectF &canvasRect, int from, int to ) const;
- virtual QwtGraphic legendIcon( int index, const QSizeF & ) const;
- protected:
- void init();
- virtual void drawCurve( QPainter *, int style,
- const QwtScaleMap &xMap, const QwtScaleMap &yMap,
- const QRectF &canvasRect, int from, int to ) const;
- virtual void drawSymbols( QPainter *, const QwtSymbol &,
- const QwtScaleMap &xMap, const QwtScaleMap &yMap,
- const QRectF &canvasRect, int from, int to ) const;
- virtual void drawLines( QPainter *,
- const QwtScaleMap &xMap, const QwtScaleMap &yMap,
- const QRectF &canvasRect, int from, int to ) const;
- virtual void drawSticks( QPainter *,
- const QwtScaleMap &xMap, const QwtScaleMap &yMap,
- const QRectF &canvasRect, int from, int to ) const;
- virtual void drawDots( QPainter *,
- const QwtScaleMap &xMap, const QwtScaleMap &yMap,
- const QRectF &canvasRect, int from, int to ) const;
- virtual void drawSteps( QPainter *,
- const QwtScaleMap &xMap, const QwtScaleMap &yMap,
- const QRectF &canvasRect, int from, int to ) const;
- virtual void fillCurve( QPainter *,
- const QwtScaleMap &, const QwtScaleMap &,
- const QRectF &canvasRect, QPolygonF & ) const;
- void closePolyline( QPainter *,
- const QwtScaleMap &, const QwtScaleMap &, QPolygonF & ) const;
- private:
- class PrivateData;
- PrivateData *d_data;
- };
- //! boundingRect().left()
- inline double QwtPlotCurve::minXValue() const
- {
- return boundingRect().left();
- }
- //! boundingRect().right()
- inline double QwtPlotCurve::maxXValue() const
- {
- return boundingRect().right();
- }
- //! boundingRect().top()
- inline double QwtPlotCurve::minYValue() const
- {
- return boundingRect().top();
- }
- //! boundingRect().bottom()
- inline double QwtPlotCurve::maxYValue() const
- {
- return boundingRect().bottom();
- }
- Q_DECLARE_OPERATORS_FOR_FLAGS( QwtPlotCurve::PaintAttributes )
- Q_DECLARE_OPERATORS_FOR_FLAGS( QwtPlotCurve::LegendAttributes )
- Q_DECLARE_OPERATORS_FOR_FLAGS( QwtPlotCurve::CurveAttributes )
- #endif
|