QwtPlot (3) - Linux Manuals
NAME
QwtPlot -
SYNOPSIS
#include <qwt_plot.h>
Inherits QFrame, and QwtPlotDict.
Public Types
enum Axis { yLeft, yRight, xBottom, xTop, axisCnt }
Axis index.
enum LegendPosition { LeftLegend, RightLegend, BottomLegend, TopLegend }
Public Slots
virtual void replot ()
Redraw the plot.
void autoRefresh ()
Replots the plot if autoReplot() is true.
Signals
void itemAttached (QwtPlotItem *plotItem, bool on)
void legendDataChanged (const QVariant &itemInfo, const QList< QwtLegendData > &data)
Public Member Functions
QwtPlot (QWidget *=NULL)
Constructor.
QwtPlot (const QwtText &title, QWidget *=NULL)
Constructor.
virtual ~QwtPlot ()
Destructor.
void applyProperties (const QString &)
QString grabProperties () const
void setAutoReplot (bool=true)
Set or reset the autoReplot option.
bool autoReplot () const
void setPlotLayout (QwtPlotLayout *)
Assign a new plot layout.
QwtPlotLayout * plotLayout ()
const QwtPlotLayout * plotLayout () const
void setTitle (const QString &)
void setTitle (const QwtText &t)
QwtText title () const
QwtTextLabel * titleLabel ()
const QwtTextLabel * titleLabel () const
void setFooter (const QString &)
void setFooter (const QwtText &t)
QwtText footer () const
QwtTextLabel * footerLabel ()
const QwtTextLabel * footerLabel () const
void setCanvas (QWidget *)
Set the drawing canvas of the plot widget.
QWidget * canvas ()
const QWidget * canvas () const
void setCanvasBackground (const QBrush &)
Change the background of the plotting area.
QBrush canvasBackground () const
virtual QwtScaleMap canvasMap (int axisId) const
double invTransform (int axisId, int pos) const
double transform (int axisId, double value) const
Transform a value into a coordinate in the plotting region.
QwtScaleEngine * axisScaleEngine (int axisId)
const QwtScaleEngine * axisScaleEngine (int axisId) const
void setAxisScaleEngine (int axisId, QwtScaleEngine *)
void setAxisAutoScale (int axisId, bool on=true)
Enable autoscaling for a specified axis.
bool axisAutoScale (int axisId) const
void enableAxis (int axisId, bool tf=true)
Enable or disable a specified axis.
bool axisEnabled (int axisId) const
void setAxisFont (int axisId, const QFont &f)
Change the font of an axis.
QFont axisFont (int axisId) const
void setAxisScale (int axisId, double min, double max, double step=0)
Disable autoscaling and specify a fixed scale for a selected axis.
void setAxisScaleDiv (int axisId, const QwtScaleDiv &)
Disable autoscaling and specify a fixed scale for a selected axis.
void setAxisScaleDraw (int axisId, QwtScaleDraw *)
Set a scale draw.
double axisStepSize (int axisId) const
Return the step size parameter that has been set in setAxisScale.
QwtInterval axisInterval (int axisId) const
Return the current interval of the specified axis.
const QwtScaleDiv & axisScaleDiv (int axisId) const
Return the scale division of a specified axis.
const QwtScaleDraw * axisScaleDraw (int axisId) const
Return the scale draw of a specified axis.
QwtScaleDraw * axisScaleDraw (int axisId)
Return the scale draw of a specified axis.
const QwtScaleWidget * axisWidget (int axisId) const
QwtScaleWidget * axisWidget (int axisId)
void setAxisLabelAlignment (int axisId, Qt::Alignment)
void setAxisLabelRotation (int axisId, double rotation)
void setAxisTitle (int axisId, const QString &)
Change the title of a specified axis.
void setAxisTitle (int axisId, const QwtText &)
Change the title of a specified axis.
QwtText axisTitle (int axisId) const
void setAxisMaxMinor (int axisId, int maxMinor)
int axisMaxMinor (int axisId) const
void setAxisMaxMajor (int axisId, int maxMajor)
int axisMaxMajor (int axisId) const
void insertLegend (QwtAbstractLegend *, LegendPosition=QwtPlot::RightLegend, double ratio=-1.0)
Insert a legend.
QwtAbstractLegend * legend ()
const QwtAbstractLegend * legend () const
void updateLegend ()
void updateLegend (const QwtPlotItem *)
virtual QSize sizeHint () const
virtual QSize minimumSizeHint () const
Return a minimum size hint.
virtual void updateLayout ()
Adjust plot content to its current size.
virtual void drawCanvas (QPainter *)
void updateAxes ()
Rebuild the axes scales.
void updateCanvasMargins ()
Update the canvas margins.
virtual void getCanvasMarginsHint (const QwtScaleMap maps[], const QRectF &canvasRect, double &left, double &top, double &right, double &bottom) const
Calculate the canvas margins.
virtual bool event (QEvent *)
Adds handling of layout requests.
virtual bool eventFilter (QObject *, QEvent *)
Event filter.
virtual void drawItems (QPainter *, const QRectF &, const QwtScaleMap maps[axisCnt]) const
virtual QVariant itemToInfo (QwtPlotItem *) const
Build an information, that can be used to identify a plot item on the legend.
virtual QwtPlotItem * infoToItem (const QVariant &) const
Identify the plot item according to an item info object, that has bee generated from itemToInfo().
Protected Member Functions
virtual void resizeEvent (QResizeEvent *e)
Static Protected Member Functions
static bool axisValid (int axisId)
Friends
Detailed Description
A 2-D plotting widget.
QwtPlot is a widget for plotting two-dimensional graphs. An unlimited number of plot items can be displayed on its canvas. Plot items might be curves (QwtPlotCurve), markers (QwtPlotMarker), the grid (QwtPlotGrid), or anything else derived from QwtPlotItem. A plot can have up to four axes, with each plot item attached to an x- and a y axis. The scales at the axes can be explicitly set (QwtScaleDiv), or are calculated from the plot items, using algorithms (QwtScaleEngine) which can be configured separately for each axis.
The simpleplot example is a good starting point to see how to set up a plot widget.
Example
-
The following example shows (schematically) the most simple way to use QwtPlot. By default, only the left and bottom axes are visible and their scales are computed automatically.
#include <qwt_plot.h> #include <qwt_plot_curve.h> QwtPlot *myPlot = new QwtPlot("Two Curves", parent); // add curves QwtPlotCurve *curve1 = new QwtPlotCurve("Curve 1"); QwtPlotCurve *curve2 = new QwtPlotCurve("Curve 2"); // connect or copy the data to the curves curve1->setData(...); curve2->setData(...); curve1->attach(myPlot); curve2->attach(myPlot); // finally, refresh the plot myPlot->replot();
Member Enumeration Documentation
enum QwtPlot::Axis
Axis index.
Enumerator
- yLeft
- Y axis left of the canvas.
- yRight
- Y axis right of the canvas.
- xBottom
- X axis below the canvas.
- xTop
- X axis above the canvas.
- axisCnt
- Number of axes.
enum QwtPlot::LegendPosition
Position of the legend, relative to the canvas.See Also:
- insertLegend()
Enumerator
- LeftLegend
- The legend will be left from the QwtPlot::yLeft axis.
- RightLegend
- The legend will be right from the QwtPlot::yRight axis.
- BottomLegend
- The legend will be below the footer.
- TopLegend
- The legend will be above the title.
Constructor & Destructor Documentation
QwtPlot::QwtPlot (QWidget *parent = NULL) [explicit]
Constructor.
Parameters:
- parent Parent widget
QwtPlot::QwtPlot (const QwtText &title, QWidget *parent = NULL) [explicit]
Constructor.
Parameters:
-
title Title text
parent Parent widget
Member Function Documentation
void QwtPlot::applyProperties (const QString &)
This method is intended for manipulating the plot widget from a specific editor in the Qwt designer plugin.Warning:
- The plot editor has never been implemented.
bool QwtPlot::autoReplot () const
Returns:
- true if the autoReplot option is set.
See Also:
- setAutoReplot()
bool QwtPlot::axisAutoScale (intaxisId) const
Returns:
- True, if autoscaling is enabled
Parameters:
- axisId Axis index
bool QwtPlot::axisEnabled (intaxisId) const
Returns:
- True, if a specified axis is enabled
Parameters:
- axisId Axis index
QFont QwtPlot::axisFont (intaxisId) const
Returns:
- The font of the scale labels for a specified axis
Parameters:
- axisId Axis index
QwtInterval QwtPlot::axisInterval (intaxisId) const
Return the current interval of the specified axis. This is only a convenience function for axisScaleDiv( axisId )->interval();
Parameters:
- axisId Axis index
Returns:
- Scale interval
See Also:
- QwtScaleDiv, axisScaleDiv()
int QwtPlot::axisMaxMajor (intaxisId) const
Returns:
- The maximum number of major ticks for a specified axis
Parameters:
- axisId Axis index
See Also:
- setAxisMaxMajor(), QwtScaleEngine::divideScale()
int QwtPlot::axisMaxMinor (intaxisId) const
Returns:
- the maximum number of minor ticks for a specified axis
Parameters:
- axisId Axis index
See Also:
- setAxisMaxMinor(), QwtScaleEngine::divideScale()
const QwtScaleDiv & QwtPlot::axisScaleDiv (intaxisId) const
Return the scale division of a specified axis. axisScaleDiv(axisId).lowerBound(), axisScaleDiv(axisId).upperBound() are the current limits of the axis scale.
Parameters:
- axisId Axis index
Returns:
- Scale division
See Also:
- QwtScaleDiv, setAxisScaleDiv(), QwtScaleEngine::divideScale()
const QwtScaleDraw * QwtPlot::axisScaleDraw (intaxisId) const
Return the scale draw of a specified axis.
Parameters:
- axisId Axis index
Returns:
- Specified scaleDraw for axis, or NULL if axis is invalid.
QwtScaleDraw * QwtPlot::axisScaleDraw (intaxisId)
Return the scale draw of a specified axis.
Parameters:
- axisId Axis index
Returns:
- Specified scaleDraw for axis, or NULL if axis is invalid.
QwtScaleEngine * QwtPlot::axisScaleEngine (intaxisId)
Parameters:
- axisId Axis index
Returns:
- Scale engine for a specific axis
const QwtScaleEngine * QwtPlot::axisScaleEngine (intaxisId) const
Parameters:
- axisId Axis index
Returns:
- Scale engine for a specific axis
double QwtPlot::axisStepSize (intaxisId) const
Return the step size parameter that has been set in setAxisScale. This doesn't need to be the step size of the current scale.
Parameters:
- axisId Axis index
Returns:
- step size parameter value
See Also:
- setAxisScale(), QwtScaleEngine::divideScale()
QwtText QwtPlot::axisTitle (intaxisId) const
Returns:
- Title of a specified axis
Parameters:
- axisId Axis index
bool QwtPlot::axisValid (intaxisId) [static], [protected]
Returns:
- true if the specified axis exists, otherwise false
Parameters:
- axisId axis index
const QwtScaleWidget * QwtPlot::axisWidget (intaxisId) const
Returns:
- Scale widget of the specified axis, or NULL if axisId is invalid.
Parameters:
- axisId Axis index
QwtScaleWidget * QwtPlot::axisWidget (intaxisId)
Returns:
- Scale widget of the specified axis, or NULL if axisId is invalid.
Parameters:
- axisId Axis index
QWidget * QwtPlot::canvas ()
Returns:
- the plot's canvas
const QWidget * QwtPlot::canvas () const
Returns:
- the plot's canvas
QBrush QwtPlot::canvasBackground () const
Nothing else than: canvas()->palette().brush( QPalette::Normal, QPalette::Window);Returns:
- Background brush of the plotting area.
See Also:
- setCanvasBackground()
QwtScaleMap QwtPlot::canvasMap (intaxisId) const [virtual]
Parameters:
- axisId Axis
Returns:
- Map for the axis on the canvas. With this map pixel coordinates can translated to plot coordinates and vice versa.
See Also:
- QwtScaleMap, transform(), invTransform()
void QwtPlot::drawCanvas (QPainter *painter) [virtual]
Redraw the canvas.Parameters:
- painter Painter used for drawing
Warning:
- drawCanvas calls drawItems what is also used for printing. Applications that like to add individual plot items better overload drawItems()
See Also:
- drawItems()
void QwtPlot::drawItems (QPainter *painter, const QRectF &canvasRect, const QwtScaleMapmaps[axisCnt]) const [virtual]
Redraw the canvas items.Parameters:
-
painter Painter used for drawing
canvasRect Bounding rectangle where to paint
maps QwtPlot::axisCnt maps, mapping between plot and paint device coordinates
Note:
- Usually canvasRect is contentsRect() of the plot canvas. Due to a bug in Qt this rectangle might be wrong for certain frame styles ( f.e QFrame::Box ) and it might be necessary to fix the margins manually using QWidget::setContentsMargins()
void QwtPlot::enableAxis (intaxisId, booltf = true)
Enable or disable a specified axis. When an axis is disabled, this only means that it is not visible on the screen. Curves, markers and can be attached to disabled axes, and transformation of screen coordinates into values works as normal.
Only xBottom and yLeft are enabled by default.
Parameters:
-
axisId Axis index
tf true (enabled) or false (disabled)
bool QwtPlot::event (QEvent *event) [virtual]
Adds handling of layout requests.
Parameters:
- event Event
Returns:
- See QFrame::event()
bool QwtPlot::eventFilter (QObject *object, QEvent *event) [virtual]
Event filter. The plot handles the following events for the canvas:
- •
- QEvent::Resize The canvas margins might depend on its size
- •
- QEvent::ContentsRectChange The layout needs to be recalculated
Parameters:
-
object Object to be filtered
event Event
Returns:
- See QFrame::eventFilter()
See Also:
- updateCanvasMargins(), updateLayout()
QwtText QwtPlot::footer () const
Returns:
- Text of the footer
QwtTextLabel * QwtPlot::footerLabel ()
Returns:
- Footer label widget.
const QwtTextLabel * QwtPlot::footerLabel () const
Returns:
- Footer label widget.
void QwtPlot::getCanvasMarginsHint (const QwtScaleMapmaps[], const QRectF &canvasRect, double &left, double &top, double &right, double &bottom) const [virtual]
Calculate the canvas margins.
Parameters:
-
maps QwtPlot::axisCnt maps, mapping between plot and paint device coordinates
canvasRect Bounding rectangle where to paint
left Return parameter for the left margin
top Return parameter for the top margin
right Return parameter for the right margin
bottom Return parameter for the bottom margin
Plot items might indicate, that they need some extra space at the borders of the canvas by the QwtPlotItem::Margins flag.
updateCanvasMargins(), QwtPlotItem::getCanvasMarginHint()
QString QwtPlot::grabProperties () const
This method is intended for manipulating the plot widget from a specific editor in the Qwt designer plugin.Returns:
- QString::null
Warning:
- The plot editor has never been implemented.
QwtPlotItem * QwtPlot::infoToItem (const QVariant &itemInfo) const [virtual]
Identify the plot item according to an item info object, that has bee generated from itemToInfo(). The default implementation simply tries to unwrap a QwtPlotItem pointer:
if ( itemInfo.canConvert<QwtPlotItem *>() ) return qvariant_cast<QwtPlotItem *>( itemInfo );
Parameters:
Returns:
See Also:
Insert a legend. If the position legend is QwtPlot::LeftLegend or QwtPlot::RightLegend the legend will be organized in one column from top to down. Otherwise the legend items will be placed in a table with a best fit number of columns from left to right.
insertLegend() will set the plot widget as parent for the legend. The legend will be deleted in the destructor of the plot or when another legend is inserted.
Legends, that are not inserted into the layout of the plot widget need to connect to the legendDataChanged() signal. Calling updateLegend() initiates this signal for an initial update. When the application code wants to implement its own layout this also needs to be done for rendering plots to a document ( see QwtPlotRenderer ).
Parameters:
See Also:
Parameters:
Returns:
Warning:
Parameters:
Build an information, that can be used to identify a plot item on the legend. The default implementation simply wraps the plot item into a QVariant object. When overloading itemToInfo() usually infoToItem() needs to reimplemeted too.
Parameters:
Returns:
See Also:
Returns:
See Also:
Returns:
See Also:
Parameters:
See Also:
Returns:
Returns:
Redraw the plot. If the autoReplot option is not set (which is the default) or if any curves are attached to raw data, the plot has to be refreshed explicitly in order to make changes visible.
See Also:
Parameters:
Set or reset the autoReplot option. If the autoReplot option is set, the plot will be updated implicitly by manipulating member functions. Since this may be time-consuming, it is recommended to leave this option switched off and call replot() explicitly if necessary.
The autoReplot option is set to false by default, which means that the user has to call replot() in order to make changes visible.
Parameters:
See Also:
Enable autoscaling for a specified axis. This member function is used to switch back to autoscaling mode after a fixed scale has been set. Autoscaling is enabled by default.
Parameters:
See Also:
Note:
Change the font of an axis.
Parameters:
Warning:
Parameters:
See Also:
Parameters:
See Also:
Parameters:
See Also:
Parameters:
See Also:
Disable autoscaling and specify a fixed scale for a selected axis. In updateAxes() the scale engine calculates a scale division from the specified parameters, that will be assigned to the scale widget. So updates of the scale widget usually happen delayed with the next replot.
Parameters:
See Also:
Disable autoscaling and specify a fixed scale for a selected axis. The scale division will be stored locally only until the next call of updateAxes(). So updates of the scale widget usually happen delayed with the next replot.
Parameters:
See Also:
Set a scale draw.
Parameters:
By passing scaleDraw it is possible to extend QwtScaleDraw functionality and let it take place in QwtPlot. Please note that scaleDraw has to be created with new and will be deleted by the corresponding QwtScale member ( like a child object ).
See Also:
Warning:
Parameters:
See Also:
Change the title of a specified axis.
Parameters:
Change the title of a specified axis.
Parameters:
Set the drawing canvas of the plot widget. QwtPlot invokes methods of the canvas as meta methods ( see QMetaObject ). In opposite to using conventional C++ techniques like virtual methods they allow to use canvas implementations that are derived from QWidget or QGLWidget.
The following meta methods could be implemented:
The default canvas is a QwtPlotCanvas
Parameters:
See Also:
Change the background of the plotting area. Sets brush to QPalette::Window of all color groups of the palette of the canvas. Using canvas()->setPalette() is a more powerful way to set these colors.
Parameters:
See Also:
Parameters:
Parameters:
Assign a new plot layout.
Parameters:
See Also:
Parameters:
Parameters:
Returns:
See Also:
Returns:
Returns:
Returns:
Transform a value into a coordinate in the plotting region.
Parameters:
Returns:
Rebuild the axes scales. In case of autoscaling the boundaries of a scale are calculated from the bounding rectangles of all plot items, having the QwtPlotItem::AutoScale flag enabled ( QwtScaleEngine::autoScale() ). Then a scale division is calculated ( QwtScaleEngine::didvideScale() ) and assigned to scale widget.
When the scale boundaries have been assigned with setAxisScale() a scale division is calculated ( QwtScaleEngine::didvideScale() ) for this interval and assigned to the scale widget.
When the scale has been set explicitly by setAxisScaleDiv() the locally stored scale division gets assigned to the scale widget.
The scale widget indicates modifications by emitting a QwtScaleWidget::scaleDivChanged() signal.
updateAxes() is usually called by replot().
See Also:
Update the canvas margins. Plot items might indicate, that they need some extra space at the borders of the canvas by the QwtPlotItem::Margins flag.
getCanvasMarginsHint(), QwtPlotItem::getCanvasMarginHint()
Adjust plot content to its current size.
See Also:
See Also:
Parameters:
See Also:
Generated automatically by Doxygen for Qwt User's Guide from the source code.
void QwtPlot::insertLegend (QwtAbstractLegend *legend, QwtPlot::LegendPositionpos = QwtPlot::RightLegend, doubleratio = -1.0)
pos The legend's position. For top/left position the number of columns will be limited to 1, otherwise it will be set to unlimited.
ratio Ratio between legend and the bounding rectangle of title, canvas and axes. The legend will be shrunk if it would need more space than the given ratio. The ratio is limited to ]0.0 .. 1.0]. In case of <= 0.0 it will be reset to the default ratio. The default vertical/horizontal ratio is 0.33/0.5.
double QwtPlot::invTransform (intaxisId, intpos) const
Transform the x or y coordinate of a position in the drawing region into a value.
pos position
void QwtPlot::itemAttached (QwtPlotItem *plotItem, boolon) [signal]
A signal indicating, that an item has been attached/detached
on Attached/Detached
QVariant QwtPlot::itemToInfo (QwtPlotItem *plotItem) const [virtual]
QVariant itemInfo;
qVariantSetValue( itemInfo, plotItem );
QwtAbstractLegend * QwtPlot::legend ()
const QwtAbstractLegend * QwtPlot::legend () const
void QwtPlot::legendDataChanged (const QVariant &itemInfo, const QList< QwtLegendData > &data) [signal]
A signal with the attributes how to update the legend entries for a plot item.
data Attributes of the entries ( usually <= 1 ) for the plot item.
QwtPlotLayout * QwtPlot::plotLayout ()
const QwtPlotLayout * QwtPlot::plotLayout () const
void QwtPlot::replot () [virtual], [slot]
void QwtPlot::resizeEvent (QResizeEvent *e) [protected], [virtual]
Resize and update internal layout
void QwtPlot::setAutoReplot (booltf = true)
void QwtPlot::setAxisAutoScale (intaxisId, boolon = true)
on On/Off
void QwtPlot::setAxisFont (intaxisId, const QFont &font)
font Font
void QwtPlot::setAxisLabelAlignment (intaxisId, Qt::Alignmentalignment)
Change the alignment of the tick labels
alignment Or'd Qt::AlignmentFlags see <qnamespace.h>
void QwtPlot::setAxisLabelRotation (intaxisId, doublerotation)
Rotate all tick labels
rotation Angle in degrees. When changing the label rotation, the label alignment might be adjusted too.
void QwtPlot::setAxisMaxMajor (intaxisId, intmaxMajor)
Set the maximum number of major scale intervals for a specified axis
maxMajor Maximum number of major steps
void QwtPlot::setAxisMaxMinor (intaxisId, intmaxMinor)
Set the maximum number of minor scale intervals for a specified axis
maxMinor Maximum number of minor steps
void QwtPlot::setAxisScale (intaxisId, doublemin, doublemax, doublestepSize = 0)
min Minimum of the scale
max Maximum of the scale
stepSize Major step size. If step == 0, the step size is calculated automatically using the maxMajor setting.
void QwtPlot::setAxisScaleDiv (intaxisId, const QwtScaleDiv &scaleDiv)
scaleDiv Scale division
void QwtPlot::setAxisScaleDraw (intaxisId, QwtScaleDraw *scaleDraw)
scaleDraw Object responsible for drawing scales.
void QwtPlot::setAxisScaleEngine (intaxisId, QwtScaleEngine *scaleEngine)
Change the scale engine for an axis
scaleEngine Scale engine
void QwtPlot::setAxisTitle (intaxisId, const QString &title)
title axis title
void QwtPlot::setAxisTitle (intaxisId, const QwtText &title)
title Axis title
void QwtPlot::setCanvas (QWidget *canvas)
void QwtPlot::setCanvasBackground (const QBrush &brush)
void QwtPlot::setFooter (const QString &text)
Change the text the footer
void QwtPlot::setFooter (const QwtText &text)
Change the text the footer
void QwtPlot::setPlotLayout (QwtPlotLayout *layout)
void QwtPlot::setTitle (const QString &title)
Change the plot's title
void QwtPlot::setTitle (const QwtText &title)
Change the plot's title
QSize QwtPlot::sizeHint () const [virtual]
QwtText QwtPlot::title () const
QwtTextLabel * QwtPlot::titleLabel ()
const QwtTextLabel * QwtPlot::titleLabel () const
double QwtPlot::transform (intaxisId, doublevalue) const
value value
void QwtPlot::updateAxes ()
void QwtPlot::updateCanvasMargins ()
void QwtPlot::updateLayout () [virtual]
void QwtPlot::updateLegend ()
Emit legendDataChanged() for all plot item
void QwtPlot::updateLegend (const QwtPlotItem *plotItem)
Emit legendDataChanged() for a plot item
Author