Classes | Public Slots | Signals | Public Member Functions | Protected Member Functions | Private Member Functions | Private Attributes | List of all members
QwtPlotZoomer Class Reference

QwtPlotZoomer provides stacked zooming for a plot widget. More...

#include <qwt_plot_zoomer.h>

Inheritance diagram for QwtPlotZoomer:
Inheritance graph
[legend]

Classes

class  PrivateData
 

Public Slots

void moveBy (double dx, double dy)
 
virtual void moveTo (const QPointF &)
 
virtual void zoom (const QRectF &)
 Zoom in. More...
 
virtual void zoom (int offset)
 Zoom in or out. More...
 
- Public Slots inherited from QwtPicker
void setEnabled (bool)
 En/disable the picker. More...
 

Signals

void zoomed (const QRectF &rect)
 
- Signals inherited from QwtPlotPicker
void appended (const QPointF &pos)
 
void moved (const QPointF &pos)
 
void selected (const QPointF &pos)
 
void selected (const QRectF &rect)
 
void selected (const QVector< QPointF > &pa)
 
- Signals inherited from QwtPicker
void activated (bool on)
 
void appended (const QPoint &pos)
 
void changed (const QPolygon &selection)
 
void moved (const QPoint &pos)
 
void removed (const QPoint &pos)
 
void selected (const QPolygon &polygon)
 

Public Member Functions

int maxStackDepth () const
 
 QwtPlotZoomer (QWidget *, bool doReplot=true)
 Create a zoomer for a plot canvas. More...
 
 QwtPlotZoomer (QwtAxisId xAxis, QwtAxisId yAxis, QWidget *, bool doReplot=true)
 Create a zoomer for a plot canvas. More...
 
virtual void setAxes (QwtAxisId xAxis, QwtAxisId yAxis) QWT_OVERRIDE
 
void setMaxStackDepth (int)
 Limit the number of recursive zoom operations to depth. More...
 
virtual void setZoomBase (bool doReplot=true)
 
virtual void setZoomBase (const QRectF &)
 Set the initial size of the zoomer. More...
 
void setZoomStack (const QStack< QRectF > &, int zoomRectIndex=-1)
 Assign a zoom stack. More...
 
QRectF zoomBase () const
 
QRectF zoomRect () const
 
uint zoomRectIndex () const
 
const QStack< QRectF > & zoomStack () const
 
virtual ~QwtPlotZoomer ()
 
- Public Member Functions inherited from QwtPlotPicker
QWidget * canvas ()
 
const QWidget * canvas () const
 
QwtPlotplot ()
 
const QwtPlotplot () const
 
 QwtPlotPicker (QWidget *canvas)
 Create a plot picker. More...
 
 QwtPlotPicker (QwtAxisId xAxisId, QwtAxisId yAxisId, QWidget *)
 
 QwtPlotPicker (QwtAxisId xAxisId, QwtAxisId yAxisId, RubberBand rubberBand, DisplayMode trackerMode, QWidget *)
 
QwtAxisId xAxis () const
 Return x axis. More...
 
QwtAxisId yAxis () const
 Return y axis. More...
 
virtual ~QwtPlotPicker ()
 Destructor. More...
 
- Public Member Functions inherited from QwtPicker
virtual void drawRubberBand (QPainter *) const
 
virtual void drawTracker (QPainter *) const
 
virtual bool eventFilter (QObject *, QEvent *) QWT_OVERRIDE
 Event filter. More...
 
bool isActive () const
 
bool isEnabled () const
 
QWidget * parentWidget ()
 Return the parent widget, where the selection happens. More...
 
const QWidget * parentWidget () const
 
virtual QPainterPath pickArea () const
 
 QwtPicker (QWidget *parent)
 
 QwtPicker (RubberBand rubberBand, DisplayMode trackerMode, QWidget *)
 
ResizeMode resizeMode () const
 
RubberBand rubberBand () const
 
virtual QRegion rubberBandMask () const
 
QPen rubberBandPen () const
 
QPolygon selection () const
 
void setResizeMode (ResizeMode)
 Set the resize mode. More...
 
void setRubberBand (RubberBand)
 
void setRubberBandPen (const QPen &)
 
void setStateMachine (QwtPickerMachine *)
 
void setTrackerFont (const QFont &)
 
void setTrackerMode (DisplayMode)
 Set the display mode of the tracker. More...
 
void setTrackerPen (const QPen &)
 
QwtPickerMachinestateMachine ()
 
const QwtPickerMachinestateMachine () const
 
QFont trackerFont () const
 
virtual QRegion trackerMask () const
 
DisplayMode trackerMode () const
 
QPen trackerPen () const
 
QPoint trackerPosition () const
 
virtual QRect trackerRect (const QFont &) const
 
virtual ~QwtPicker ()
 Destructor. More...
 
- Public Member Functions inherited from QwtEventPattern
void initKeyPattern ()
 
void initMousePattern (int numButtons)
 
bool keyMatch (KeyPatternCode, const QKeyEvent *) const
 Compare a key event with an event pattern. More...
 
QVector< KeyPattern > & keyPattern ()
 
const QVector< KeyPattern > & keyPattern () const
 
bool mouseMatch (MousePatternCode, const QMouseEvent *) const
 Compare a mouse event with an event pattern. More...
 
QVector< MousePattern > & mousePattern ()
 
const QVector< MousePattern > & mousePattern () const
 
 QwtEventPattern ()
 
void setKeyPattern (const QVector< KeyPattern > &)
 Change the key event patterns. More...
 
void setKeyPattern (KeyPatternCode, int key, Qt::KeyboardModifiers modifiers=Qt::NoModifier)
 
void setMousePattern (const QVector< MousePattern > &)
 Change the mouse event patterns. More...
 
void setMousePattern (MousePatternCode, Qt::MouseButton button, Qt::KeyboardModifiers=Qt::NoModifier)
 
virtual ~QwtEventPattern ()
 Destructor. More...
 

Protected Member Functions

virtual bool accept (QPolygon &) const QWT_OVERRIDE
 Check and correct a selected rectangle. More...
 
virtual void begin () QWT_OVERRIDE
 
virtual bool end (bool ok=true) QWT_OVERRIDE
 
virtual QSizeF minZoomSize () const
 Limit zooming by a minimum rectangle. More...
 
virtual void rescale ()
 
virtual void widgetKeyPressEvent (QKeyEvent *) QWT_OVERRIDE
 
virtual void widgetMouseReleaseEvent (QMouseEvent *) QWT_OVERRIDE
 
- Protected Member Functions inherited from QwtPlotPicker
virtual void append (const QPoint &) QWT_OVERRIDE
 
QPointF invTransform (const QPoint &) const
 
QRectF invTransform (const QRect &) const
 
virtual void move (const QPoint &) QWT_OVERRIDE
 
QRectF scaleRect () const
 
virtual QwtText trackerText (const QPoint &) const QWT_OVERRIDE
 
virtual QwtText trackerTextF (const QPointF &) const
 Translate a position into a position string. More...
 
QPoint transform (const QPointF &) const
 
QRect transform (const QRectF &) const
 
- Protected Member Functions inherited from QwtPicker
virtual QPolygon adjustedPoints (const QPolygon &) const
 Map the pickedPoints() into a selection() More...
 
const QPolygon & pickedPoints () const
 
virtual void remove ()
 
virtual void reset ()
 
const QwtWidgetOverlayrubberBandOverlay () const
 
virtual void stretchSelection (const QSize &oldSize, const QSize &newSize)
 
const QwtWidgetOverlaytrackerOverlay () const
 
QRect trackerRect (const QSize &) const
 
virtual void transition (const QEvent *)
 
virtual void updateDisplay ()
 Update the state of rubber band and tracker label. More...
 
virtual void widgetEnterEvent (QEvent *)
 
virtual void widgetKeyReleaseEvent (QKeyEvent *)
 
virtual void widgetLeaveEvent (QEvent *)
 
virtual void widgetMouseDoubleClickEvent (QMouseEvent *)
 
virtual void widgetMouseMoveEvent (QMouseEvent *)
 
virtual void widgetMousePressEvent (QMouseEvent *)
 
virtual void widgetWheelEvent (QWheelEvent *)
 
- Protected Member Functions inherited from QwtEventPattern
virtual bool keyMatch (const KeyPattern &, const QKeyEvent *) const
 Compare a key event with an event pattern. More...
 
virtual bool mouseMatch (const MousePattern &, const QMouseEvent *) const
 Compare a mouse event with an event pattern. More...
 

Private Member Functions

void init (bool doReplot)
 Init the zoomer, used by the constructors. More...
 

Private Attributes

PrivateDatam_data
 

Additional Inherited Members

- Public Types inherited from QwtPicker
enum  DisplayMode { AlwaysOff, AlwaysOn, ActiveOnly }
 Display mode. More...
 
enum  ResizeMode { Stretch, KeepSize }
 
enum  RubberBand {
  NoRubberBand = 0, HLineRubberBand, VLineRubberBand, CrossRubberBand,
  RectRubberBand, EllipseRubberBand, PolygonRubberBand, UserRubberBand = 100
}
 
- Public Types inherited from QwtEventPattern
enum  KeyPatternCode {
  KeySelect1, KeySelect2, KeyAbort, KeyLeft,
  KeyRight, KeyUp, KeyDown, KeyRedo,
  KeyUndo, KeyHome, KeyPatternCount
}
 Symbolic keyboard input codes. More...
 
enum  MousePatternCode {
  MouseSelect1, MouseSelect2, MouseSelect3, MouseSelect4,
  MouseSelect5, MouseSelect6, MousePatternCount
}
 Symbolic mouse input codes. More...
 
- Properties inherited from QwtPicker
bool isEnabled
 
ResizeMode resizeMode
 
RubberBand rubberBand
 
QPen rubberBandPen
 
QFont trackerFont
 
DisplayMode trackerMode
 
QPen trackerPen
 

Detailed Description

QwtPlotZoomer provides stacked zooming for a plot widget.

QwtPlotZoomer selects rectangles from user inputs ( mouse or keyboard ) translates them into plot coordinates and adjusts the axes to them. The selection is supported by a rubber band and optionally by displaying the coordinates of the current mouse position.

Zooming can be repeated as often as possible, limited only by maxStackDepth() or minZoomSize(). Each rectangle is pushed on a stack.

The default setting how to select rectangles is a QwtPickerDragRectMachine with the following bindings:

To traverse the zoom stack the following bindings are used:

The setKeyPattern() and setMousePattern() functions can be used to configure the zoomer actions. The following example shows, how to configure the 'I' and 'O' keys for zooming in and out one position on the zoom stack. The "Home" key is used to "unzoom" the plot.

zoomer = new QwtPlotZoomer( plot );
zoomer->setKeyPattern( QwtEventPattern::KeyRedo, Qt::Key_I, Qt::ShiftModifier );
zoomer->setKeyPattern( QwtEventPattern::KeyUndo, Qt::Key_O, Qt::ShiftModifier );
zoomer->setKeyPattern( QwtEventPattern::KeyHome, Qt::Key_Home );

QwtPlotZoomer is tailored for plots with one x and y axis, but it is allowed to attach a second QwtPlotZoomer ( without rubber band and tracker ) for the other axes.

Note
The realtime example includes an derived zoomer class that adds scrollbars to the plot canvas.
See also
QwtPlotPanner, QwtPlotMagnifier

Definition at line 79 of file qwt_plot_zoomer.h.

Constructor & Destructor Documentation

◆ QwtPlotZoomer() [1/2]

QwtPlotZoomer::QwtPlotZoomer ( QWidget *  canvas,
bool  doReplot = true 
)
explicit

Create a zoomer for a plot canvas.

The zoomer is set to those x- and y-axis of the parent plot of the canvas that are enabled. If both or no x-axis are enabled, the picker is set to QwtAxis::XBottom. If both or no y-axis are enabled, it is set to QwtAxis::YLeft.

The zoomer is initialized with a QwtPickerDragRectMachine, the tracker mode is set to QwtPicker::ActiveOnly and the rubber band is set to QwtPicker::RectRubberBand

Parameters
canvasPlot canvas to observe, also the parent object
doReplotCall QwtPlot::replot() for the attached plot before initializing the zoomer with its scales. This might be necessary, when the plot is in a state with pending scale changes.
See also
QwtPlot::autoReplot(), QwtPlot::replot(), setZoomBase()

Definition at line 109 of file qwt_plot_zoomer.cpp.

◆ QwtPlotZoomer() [2/2]

QwtPlotZoomer::QwtPlotZoomer ( QwtAxisId  xAxisId,
QwtAxisId  yAxisId,
QWidget *  canvas,
bool  doReplot = true 
)
explicit

Create a zoomer for a plot canvas.

The zoomer is initialized with a QwtPickerDragRectMachine, the tracker mode is set to QwtPicker::ActiveOnly and the rubber band is set to QwtPicker::RectRubberBand

Parameters
xAxisIdX axis of the zoomer
yAxisIdY axis of the zoomer
canvasPlot canvas to observe, also the parent object
doReplotCall QwtPlot::replot() for the attached plot before initializing the zoomer with its scales. This might be necessary, when the plot is in a state with pending scale changes.
See also
QwtPlot::autoReplot(), QwtPlot::replot(), setZoomBase()

Definition at line 133 of file qwt_plot_zoomer.cpp.

◆ ~QwtPlotZoomer()

QwtPlotZoomer::~QwtPlotZoomer ( )
virtual

Definition at line 158 of file qwt_plot_zoomer.cpp.

Member Function Documentation

◆ accept()

bool QwtPlotZoomer::accept ( QPolygon &  pa) const
protectedvirtual

Check and correct a selected rectangle.

Reject rectangles with a height or width < 2, otherwise expand the selected rectangle to a minimum size of 11x11 and accept it.

Returns
true If the rectangle is accepted, or has been changed to an accepted one.

Reimplemented from QwtPicker.

Reimplemented in PlotZoomer.

Definition at line 567 of file qwt_plot_zoomer.cpp.

◆ begin()

void QwtPlotZoomer::begin ( )
protectedvirtual

Rejects selections, when the stack depth is too deep, or the zoomed rectangle is minZoomSize().

See also
minZoomSize(), maxStackDepth()

Reimplemented from QwtPicker.

Definition at line 609 of file qwt_plot_zoomer.cpp.

◆ end()

bool QwtPlotZoomer::end ( bool  ok = true)
protectedvirtual

Expand the selected rectangle to minZoomSize() and zoom in if accepted.

Parameters
okIf true, complete the selection and emit selected signals otherwise discard the selection.
See also
accept(), minZoomSize()
Returns
True if the selection has been accepted, false otherwise

Reimplemented from QwtPlotPicker.

Definition at line 643 of file qwt_plot_zoomer.cpp.

◆ init()

void QwtPlotZoomer::init ( bool  doReplot)
private

Init the zoomer, used by the constructors.

Definition at line 142 of file qwt_plot_zoomer.cpp.

◆ maxStackDepth()

int QwtPlotZoomer::maxStackDepth ( ) const
Returns
Maximal depth of the zoom stack.
See also
setMaxStackDepth()

Definition at line 201 of file qwt_plot_zoomer.cpp.

◆ minZoomSize()

QSizeF QwtPlotZoomer::minZoomSize ( ) const
protectedvirtual

Limit zooming by a minimum rectangle.

Returns
zoomBase().width() / 10e4, zoomBase().height() / 10e4

Reimplemented in PlotZoomer.

Definition at line 597 of file qwt_plot_zoomer.cpp.

◆ moveBy

void QwtPlotZoomer::moveBy ( double  dx,
double  dy 
)
slot

Move the current zoom rectangle.

Parameters
dxX offset
dyY offset
Note
The changed rectangle is limited by the zoom base

Definition at line 520 of file qwt_plot_zoomer.cpp.

◆ moveTo

void QwtPlotZoomer::moveTo ( const QPointF &  pos)
virtualslot

Move the the current zoom rectangle.

Parameters
posNew position
See also
QRectF::moveTo()
Note
The changed rectangle is limited by the zoom base

Definition at line 534 of file qwt_plot_zoomer.cpp.

◆ rescale()

void QwtPlotZoomer::rescale ( )
protectedvirtual

Adjust the observed plot to zoomRect()

Note
Initiates QwtPlot::replot()

Definition at line 416 of file qwt_plot_zoomer.cpp.

◆ setAxes()

void QwtPlotZoomer::setAxes ( QwtAxisId  xAxisId,
QwtAxisId  yAxisId 
)
virtual

Reinitialize the axes, and set the zoom base to their scales.

Parameters
xAxisIdX axis
yAxisIdY axis

Reimplemented from QwtPlotPicker.

Definition at line 455 of file qwt_plot_zoomer.cpp.

◆ setMaxStackDepth()

void QwtPlotZoomer::setMaxStackDepth ( int  depth)

Limit the number of recursive zoom operations to depth.

A value of -1 set the depth to unlimited, 0 disables zooming. If the current zoom rectangle is below depth, the plot is unzoomed.

Parameters
depthMaximum for the stack depth
See also
maxStackDepth()
Note
depth doesn't include the zoom base, so zoomStack().count() might be maxStackDepth() + 1.

Definition at line 174 of file qwt_plot_zoomer.cpp.

◆ setZoomBase() [1/2]

void QwtPlotZoomer::setZoomBase ( bool  doReplot = true)
virtual

Reinitialized the zoom stack with scaleRect() as base.

Parameters
doReplotCall QwtPlot::replot() for the attached plot before initializing the zoomer with its scales. This might be necessary, when the plot is in a state with pending scale changes.
See also
zoomBase(), scaleRect() QwtPlot::autoReplot(), QwtPlot::replot().

Definition at line 235 of file qwt_plot_zoomer.cpp.

◆ setZoomBase() [2/2]

void QwtPlotZoomer::setZoomBase ( const QRectF &  base)
virtual

Set the initial size of the zoomer.

base is united with the current scaleRect() and the zoom stack is reinitialized with it as zoom base. plot is zoomed to scaleRect().

Parameters
baseZoom base
See also
zoomBase(), scaleRect()

Definition at line 261 of file qwt_plot_zoomer.cpp.

◆ setZoomStack()

void QwtPlotZoomer::setZoomStack ( const QStack< QRectF > &  zoomStack,
int  zoomRectIndex = -1 
)

Assign a zoom stack.

In combination with other types of navigation it might be useful to modify to manipulate the complete zoom stack.

Parameters
zoomStackNew zoom stack
zoomRectIndexIndex of the current position of zoom stack. In case of -1 the current position is at the top of the stack.
Note
The zoomed signal might be emitted.
See also
zoomStack(), zoomRectIndex()

Definition at line 383 of file qwt_plot_zoomer.cpp.

◆ widgetKeyPressEvent()

void QwtPlotZoomer::widgetKeyPressEvent ( QKeyEvent *  ke)
protectedvirtual

Qt::Key_Plus zooms in, Qt::Key_Minus zooms out one position on the zoom stack, Qt::Key_Escape zooms out to the zoom base.

Changes the current position on the stack, but doesn't pop any rectangle.

Note
The keys codes can be changed, using QwtEventPattern::setKeyPattern: 3, 4, 5

Reimplemented from QwtPicker.

Definition at line 497 of file qwt_plot_zoomer.cpp.

◆ widgetMouseReleaseEvent()

void QwtPlotZoomer::widgetMouseReleaseEvent ( QMouseEvent *  me)
protectedvirtual

Qt::MidButton zooms out one position on the zoom stack, Qt::RightButton to the zoom base.

Changes the current position on the stack, but doesn't pop any rectangle.

Note
The mouse events can be changed, using QwtEventPattern::setMousePattern: 2, 1

Reimplemented from QwtPicker.

Reimplemented in PlotZoomer.

Definition at line 474 of file qwt_plot_zoomer.cpp.

◆ zoom [1/2]

void QwtPlotZoomer::zoom ( const QRectF &  rect)
virtualslot

Zoom in.

Clears all rectangles above the current position of the zoom stack and pushes the normalized rectangle on it.

Note
If the maximal stack depth is reached, zoom is ignored.
The zoomed signal is emitted.

Reimplemented in PlotZoomer.

Definition at line 310 of file qwt_plot_zoomer.cpp.

◆ zoom [2/2]

void QwtPlotZoomer::zoom ( int  offset)
virtualslot

Zoom in or out.

Activate a rectangle on the zoom stack with an offset relative to the current position. Negative values of offset will zoom out, positive zoom in. A value of 0 zooms out to the zoom base.

Parameters
offsetOffset relative to the current position of the zoom stack.
Note
The zoomed signal is emitted.
See also
zoomRectIndex()

Definition at line 347 of file qwt_plot_zoomer.cpp.

◆ zoomBase()

QRectF QwtPlotZoomer::zoomBase ( ) const
Returns
Initial rectangle of the zoomer
See also
setZoomBase(), zoomRect()

Definition at line 221 of file qwt_plot_zoomer.cpp.

◆ zoomed

void QwtPlotZoomer::zoomed ( const QRectF &  rect)
signal

A signal emitting the zoomRect(), when the plot has been zoomed in or out.

Parameters
rectCurrent zoom rectangle.

◆ zoomRect()

QRectF QwtPlotZoomer::zoomRect ( ) const
Returns
Rectangle at the current position on the zoom stack.
See also
zoomRectIndex(), scaleRect().

Definition at line 287 of file qwt_plot_zoomer.cpp.

◆ zoomRectIndex()

uint QwtPlotZoomer::zoomRectIndex ( ) const
Returns
Index of current position of zoom stack.

Definition at line 295 of file qwt_plot_zoomer.cpp.

◆ zoomStack()

const QStack< QRectF > & QwtPlotZoomer::zoomStack ( ) const
Returns
The zoom stack. zoomStack()[0] is the zoom base, zoomStack()[1] the first zoomed rectangle.
See also
setZoomStack(), zoomRectIndex()

Definition at line 212 of file qwt_plot_zoomer.cpp.

Member Data Documentation

◆ m_data

PrivateData* QwtPlotZoomer::m_data
private

Definition at line 138 of file qwt_plot_zoomer.h.


The documentation for this class was generated from the following files:
QwtEventPattern::KeyRedo
@ KeyRedo
Qt::Key_Plus.
Definition: qwt_event_pattern.h:136
QwtPlotPicker::plot
QwtPlot * plot()
Definition: qwt_plot_picker.cpp:126
QwtEventPattern::KeyHome
@ KeyHome
Qt::Key_Escape.
Definition: qwt_event_pattern.h:142
QwtPlotZoomer::QwtPlotZoomer
QwtPlotZoomer(QWidget *, bool doReplot=true)
Create a zoomer for a plot canvas.
Definition: qwt_plot_zoomer.cpp:109
QwtEventPattern::KeyUndo
@ KeyUndo
Qt::Key_Minus.
Definition: qwt_event_pattern.h:139


plotjuggler
Author(s): Davide Faconti
autogenerated on Mon Nov 11 2024 03:23:51