Qwt User's Guide
5.2.3
|
#include <qwt_plot.h>
Public Types | |
enum | Axis { yLeft, yRight, xBottom, xTop, axisCnt } |
enum | LegendPosition { LeftLegend, RightLegend, BottomLegend, TopLegend, ExternalLegend } |
Public Slots | |
void | autoRefresh () |
virtual void | clear () |
virtual void | replot () |
Signals | |
void | legendChecked (QwtPlotItem *plotItem, bool on) |
void | legendClicked (QwtPlotItem *plotItem) |
Public Member Functions | |
QwtPlot (QWidget *=NULL) | |
QwtPlot (const QwtText &title, QWidget *p=NULL) | |
virtual | ~QwtPlot () |
void | applyProperties (const QString &) |
bool | autoReplot () const |
bool | axisAutoScale (int axisId) const |
bool | axisEnabled (int axisId) const |
QFont | axisFont (int axisId) const |
int | axisMaxMajor (int axisId) const |
int | axisMaxMinor (int axisId) const |
const QwtScaleDiv * | axisScaleDiv (int axisId) const |
QwtScaleDiv * | axisScaleDiv (int axisId) |
const QwtScaleDraw * | axisScaleDraw (int axisId) const |
QwtScaleDraw * | axisScaleDraw (int axisId) |
QwtScaleEngine * | axisScaleEngine (int axisId) |
const QwtScaleEngine * | axisScaleEngine (int axisId) const |
double | axisStepSize (int axisId) const |
QwtText | axisTitle (int axisId) const |
const QwtScaleWidget * | axisWidget (int axisId) const |
QwtScaleWidget * | axisWidget (int axisId) |
QwtPlotCanvas * | canvas () |
const QwtPlotCanvas * | canvas () const |
const QColor & | canvasBackground () const |
int | canvasLineWidth () const |
virtual QwtScaleMap | canvasMap (int axisId) const |
virtual void | drawCanvas (QPainter *) |
void | enableAxis (int axisId, bool tf=true) |
virtual bool | event (QEvent *) |
QString | grabProperties () const |
void | insertLegend (QwtLegend *, LegendPosition=QwtPlot::RightLegend, double ratio=-1.0) |
double | invTransform (int axisId, int pos) const |
QwtLegend * | legend () |
const QwtLegend * | legend () const |
int | margin () const |
virtual QSize | minimumSizeHint () const |
QwtPlotLayout * | plotLayout () |
const QwtPlotLayout * | plotLayout () const |
virtual void | polish () |
void | print (QPaintDevice &p, const QwtPlotPrintFilter &=QwtPlotPrintFilter()) const |
virtual void | print (QPainter *, const QRect &rect, const QwtPlotPrintFilter &=QwtPlotPrintFilter()) const |
void | setAutoReplot (bool tf=true) |
void | setAxisAutoScale (int axisId) |
void | setAxisFont (int axisId, const QFont &f) |
void | setAxisLabelAlignment (int axisId, Qt::Alignment) |
void | setAxisLabelRotation (int axisId, double rotation) |
void | setAxisMaxMajor (int axisId, int maxMajor) |
void | setAxisMaxMinor (int axisId, int maxMinor) |
void | setAxisScale (int axisId, double min, double max, double step=0) |
void | setAxisScaleDiv (int axisId, const QwtScaleDiv &) |
void | setAxisScaleDraw (int axisId, QwtScaleDraw *) |
void | setAxisScaleEngine (int axisId, QwtScaleEngine *) |
void | setAxisTitle (int axisId, const QString &) |
void | setAxisTitle (int axisId, const QwtText &) |
void | setCanvasBackground (const QColor &c) |
void | setCanvasLineWidth (int w) |
void | setMargin (int margin) |
void | setTitle (const QString &) |
void | setTitle (const QwtText &t) |
virtual QSize | sizeHint () const |
QwtText | title () const |
QwtTextLabel * | titleLabel () |
const QwtTextLabel * | titleLabel () const |
int | transform (int axisId, double value) const |
void | updateAxes () |
virtual void | updateLayout () |
![]() | |
QwtPlotDict () | |
~QwtPlotDict () | |
bool | autoDelete () const |
void | detachItems (int rtti=QwtPlotItem::Rtti_PlotItem, bool autoDelete=true) |
const QwtPlotItemList & | itemList () const |
void | setAutoDelete (bool) |
Protected Slots | |
virtual void | legendItemChecked (bool) |
virtual void | legendItemClicked () |
Protected Member Functions | |
virtual void | drawItems (QPainter *, const QRect &, const QwtScaleMap maps[axisCnt], const QwtPlotPrintFilter &) const |
virtual void | printCanvas (QPainter *, const QRect &boundingRect, const QRect &canvasRect, const QwtScaleMap maps[axisCnt], const QwtPlotPrintFilter &) const |
virtual void | printLegend (QPainter *, const QRect &) const |
virtual void | printLegendItem (QPainter *, const QWidget *, const QRect &) const |
virtual void | printScale (QPainter *, int axisId, int startDist, int endDist, int baseDist, const QRect &) const |
virtual void | printTitle (QPainter *, const QRect &) const |
virtual void | resizeEvent (QResizeEvent *e) |
virtual void | updateTabOrder () |
Static Protected Member Functions | |
static bool | axisValid (int axisId) |
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 explicitely set (QwtScaleDiv), or are calculated from the plot items, using algorithms (QwtScaleEngine) which can be configured separately for each axis.
#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"); // copy the data into the curves curve1->setData(...); curve2->setData(...); curve1->attach(myPlot); curve2->attach(myPlot); // finally, refresh the plot myPlot->replot();
enum QwtPlot::Axis |
Axis index
Position of the legend, relative to the canvas.
|
explicit |
Constructor.
parent | Parent widget |
|
explicit |
Constructor.
title | Title text |
parent | Parent widget |
void QwtPlot::applyProperties | ( | const QString & | ) |
This method is intended for manipulating the plot widget from a specific editor in the Qwt designer plugin.
bool QwtPlot::autoReplot | ( | ) | const |
bool QwtPlot::axisAutoScale | ( | int | axisId | ) | const |
true
if autoscaling is enabled axisId | axis index |
bool QwtPlot::axisEnabled | ( | int | axisId | ) | const |
true
if a specified axis is enabled axisId | axis index |
QFont QwtPlot::axisFont | ( | int | axisId | ) | const |
axisId | axis index |
int QwtPlot::axisMaxMajor | ( | int | axisId | ) | const |
axisId | axis index sa setAxisMaxMajor() |
int QwtPlot::axisMaxMinor | ( | int | axisId | ) | const |
axisId | axis index sa setAxisMaxMinor() |
const QwtScaleDiv * QwtPlot::axisScaleDiv | ( | int | axisId | ) | const |
Return the scale division of a specified axis.
axisScaleDiv(axisId)->lowerBound(), axisScaleDiv(axisId)->upperBound() are the current limits of the axis scale.
axisId | axis index |
QwtScaleDiv * QwtPlot::axisScaleDiv | ( | int | axisId | ) |
Return the scale division of a specified axis.
axisScaleDiv(axisId)->lowerBound(), axisScaleDiv(axisId)->upperBound() are the current limits of the axis scale.
axisId | axis index |
const QwtScaleDraw * QwtPlot::axisScaleDraw | ( | int | axisId | ) | const |
axisId | axis index |
QwtScaleDraw * QwtPlot::axisScaleDraw | ( | int | axisId | ) |
axisId | axis index |
QwtScaleEngine * QwtPlot::axisScaleEngine | ( | int | axisId | ) |
axisId | axis index |
const QwtScaleEngine * QwtPlot::axisScaleEngine | ( | int | axisId | ) | const |
axisId | axis index |
double QwtPlot::axisStepSize | ( | int | axisId | ) | 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.
axisId | axis index |
QwtText QwtPlot::axisTitle | ( | int | axisId | ) | const |
axisId | axis index |
|
staticprotected |
true
if the specified axis exists, otherwise false
axisId | axis index |
const QwtScaleWidget * QwtPlot::axisWidget | ( | int | axisId | ) | const |
axisId | axis index |
QwtScaleWidget * QwtPlot::axisWidget | ( | int | axisId | ) |
axisId | axis index |
QwtPlotCanvas * QwtPlot::canvas | ( | ) |
const QwtPlotCanvas * QwtPlot::canvas | ( | ) | const |
const QColor & QwtPlot::canvasBackground | ( | ) | const |
Nothing else than: canvas()->palette().color( QPalette::Normal, QColorGroup::Background);
int QwtPlot::canvasLineWidth | ( | ) | const |
Nothing else than: canvas()->lineWidth(), left for compatibility only.
|
virtual |
axisId | Axis |
|
virtualslot |
Remove all curves and markers
|
virtual |
Redraw the canvas.
painter | Painter used for drawing |
|
protectedvirtual |
Redraw the canvas items.
painter | Painter used for drawing |
rect | Bounding rectangle where to paint |
map | QwtPlot::axisCnt maps, mapping between plot and paint device coordinates |
pfilter | Plot print filter |
void QwtPlot::enableAxis | ( | int | axisId, |
bool | tf = 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.
axisId | axis index |
tf | true (enabled) or false (disabled) |
QString QwtPlot::grabProperties | ( | ) | const |
This method is intended for manipulating the plot widget from a specific editor in the Qwt designer plugin.
void QwtPlot::insertLegend | ( | QwtLegend * | legend, |
QwtPlot::LegendPosition | pos = QwtPlot::RightLegend , |
||
double | ratio = -1.0 |
||
) |
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.
If pos != QwtPlot::ExternalLegend the plot widget will become parent of the legend. It will be deleted when the plot is deleted, or another legend is set with insertLegend().
legend | Legend |
pos | The legend's position. For top/left position the number of colums will be limited to 1, otherwise it will be set to unlimited. |
ratio | Ratio between legend and the bounding rect of title, canvas and axes. The legend will be shrinked 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 | ( | int | axisId, |
int | pos | ||
) | const |
Transform the x or y coordinate of a position in the drawing region into a value.
axisId | axis index |
pos | position |
QwtLegend * QwtPlot::legend | ( | ) |
const QwtLegend * QwtPlot::legend | ( | ) | const |
|
signal |
A signal which is emitted when the user has clicked on a legend item, which is in QwtLegend::CheckableItem mode
plotItem | Corresponding plot item of the selected legend item |
on | True when the legen item is checked |
|
signal |
A signal which is emitted when the user has clicked on a legend item, which is in QwtLegend::ClickableItem mode.
plotItem | Corresponding plot item of the selected legend item |
|
protectedvirtualslot |
Called internally when the legend has been checked Emits a legendClicked() signal.
|
protectedvirtualslot |
Called internally when the legend has been clicked on. Emits a legendClicked() signal.
int QwtPlot::margin | ( | ) | const |
QwtPlotLayout * QwtPlot::plotLayout | ( | ) |
const QwtPlotLayout * QwtPlot::plotLayout | ( | ) | const |
void QwtPlot::print | ( | QPaintDevice & | paintDev, |
const QwtPlotPrintFilter & | pfilter = QwtPlotPrintFilter() |
||
) | const |
Print the plot to a QPaintDevice
(QPrinter
) This function prints the contents of a QwtPlot instance to QPaintDevice
object. The size is derived from its device metrics.
paintDev | device to paint on, often a printer |
pfilter | print filter |
|
virtual |
Paint the plot into a given rectangle. Paint the contents of a QwtPlot instance into a given rectangle.
painter | Painter |
plotRect | Bounding rectangle |
pfilter | Print filter |
|
protectedvirtual |
Print the canvas into a given rectangle.
painter | Painter |
map | Maps mapping between plot and paint device coordinates |
boundingRect | Bounding rectangle |
canvasRect | Canvas rectangle |
pfilter | Print filter |
|
protectedvirtual |
Print the legend into a given rectangle.
painter | Painter |
rect | Bounding rectangle |
|
protectedvirtual |
Print the legend item into a given rectangle.
painter | Painter |
w | Widget representing a legend item |
rect | Bounding rectangle |
|
protectedvirtual |
Paint a scale into a given rectangle. Paint the scale into a given rectangle.
painter | Painter |
axisId | Axis |
startDist | Start border distance |
endDist | End border distance |
baseDist | Base distance |
rect | Bounding rectangle |
|
protectedvirtual |
Print the title into a given rectangle.
painter | Painter |
rect | Bounding rectangle |
|
virtualslot |
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.
|
protectedvirtual |
Resize and update internal layout
e | Resize event |
void QwtPlot::setAutoReplot | ( | bool | tf = true | ) |
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.
tf | true or false . Defaults to true . |
void QwtPlot::setAxisAutoScale | ( | int | axisId | ) |
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.
axisId | axis index |
void QwtPlot::setAxisFont | ( | int | axisId, |
const QFont & | f | ||
) |
Change the font of an axis.
axisId | axis index |
f | font |
void QwtPlot::setAxisLabelAlignment | ( | int | axisId, |
Qt::Alignment | alignment | ||
) |
Change the alignment of the tick labels
axisId | axis index |
alignment | Or'd Qt::AlignmentFlags <see qnamespace.h> |
void QwtPlot::setAxisLabelRotation | ( | int | axisId, |
double | rotation | ||
) |
Rotate all tick labels
axisId | axis index |
rotation | Angle in degrees. When changing the label rotation, the label alignment might be adjusted too. |
void QwtPlot::setAxisMaxMajor | ( | int | axisId, |
int | maxMajor | ||
) |
Set the maximum number of major scale intervals for a specified axis
axisId | axis index |
maxMajor | maximum number of major steps |
void QwtPlot::setAxisMaxMinor | ( | int | axisId, |
int | maxMinor | ||
) |
Set the maximum number of minor scale intervals for a specified axis
axisId | axis index |
maxMinor | maximum number of minor steps |
void QwtPlot::setAxisScale | ( | int | axisId, |
double | min, | ||
double | max, | ||
double | stepSize = 0 |
||
) |
Disable autoscaling and specify a fixed scale for a selected axis.
axisId | axis index |
min | |
max | minimum and maximum of the scale |
stepSize | Major step size. If step == 0 , the step size is calculated automatically using the maxMajor setting. |
void QwtPlot::setAxisScaleDiv | ( | int | axisId, |
const QwtScaleDiv & | scaleDiv | ||
) |
Disable autoscaling and specify a fixed scale for a selected axis.
axisId | axis index |
scaleDiv | Scale division |
void QwtPlot::setAxisScaleDraw | ( | int | axisId, |
QwtScaleDraw * | scaleDraw | ||
) |
Set a scale draw.
axisId | axis index |
scaleDraw | object responsible for drawing scales. |
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 ).
void QwtPlot::setAxisScaleEngine | ( | int | axisId, |
QwtScaleEngine * | scaleEngine | ||
) |
Change the scale engine for an axis
axisId | axis index |
scaleEngine | Scale engine |
void QwtPlot::setAxisTitle | ( | int | axisId, |
const QString & | title | ||
) |
Change the title of a specified axis.
axisId | axis index |
title | axis title |
void QwtPlot::setAxisTitle | ( | int | axisId, |
const QwtText & | title | ||
) |
Change the title of a specified axis.
axisId | axis index |
title | axis title |
void QwtPlot::setCanvasBackground | ( | const QColor & | c | ) |
Change the background of the plotting area.
Sets c to QColorGroup::Background of all colorgroups of the palette of the canvas. Using canvas()->setPalette() is a more powerful way to set these colors.
c | new background color |
void QwtPlot::setCanvasLineWidth | ( | int | w | ) |
Change the border width of the plotting area Nothing else than canvas()->setLineWidth(w), left for compatibility only.
w | new border width |
void QwtPlot::setMargin | ( | int | margin | ) |
Change the margin of the plot. The margin is the space around all components.
margin | new margin |
void QwtPlot::setTitle | ( | const QString & | title | ) |
Change the plot's title
title | New title |
void QwtPlot::setTitle | ( | const QwtText & | title | ) |
Change the plot's title
title | New title |
|
virtual |
Return sizeHint
QwtText QwtPlot::title | ( | ) | const |
QwtTextLabel * QwtPlot::titleLabel | ( | ) |
const QwtTextLabel * QwtPlot::titleLabel | ( | ) | const |
int QwtPlot::transform | ( | int | axisId, |
double | value | ||
) | const |
Transform a value into a coordinate in the plotting region.
axisId | axis index |
value | value |
|
virtual |
Adjust plot content to its current size.
|
protectedvirtual |
Update the focus tab order
The order is changed so that the canvas will be in front of the first legend item, or behind the last legend item - depending on the position of the legend.