Qwt User's Guide 6.3.0
|
QwtPanner provides panning of a widget. More...
#include <qwt_panner.h>
Signals | |
void | panned (int dx, int dy) |
void | moved (int dx, int dy) |
Public Member Functions | |
QwtPanner (QWidget *parent) | |
virtual | ~QwtPanner () |
Destructor. | |
void | setEnabled (bool) |
En/disable the panner. | |
bool | isEnabled () const |
void | setMouseButton (Qt::MouseButton, Qt::KeyboardModifiers=Qt::NoModifier) |
void | getMouseButton (Qt::MouseButton &button, Qt::KeyboardModifiers &) const |
Get mouse button and modifiers used for panning. | |
void | setAbortKey (int key, Qt::KeyboardModifiers=Qt::NoModifier) |
void | getAbortKey (int &key, Qt::KeyboardModifiers &) const |
Get the abort key and modifiers. | |
void | setCursor (const QCursor &) |
const QCursor | cursor () const |
void | setOrientations (Qt::Orientations) |
Qt::Orientations | orientations () const |
Return the orientation, where panning is enabled. | |
bool | isOrientationEnabled (Qt::Orientation) const |
virtual bool | eventFilter (QObject *, QEvent *) override |
Event filter. | |
Protected Member Functions | |
virtual void | widgetMousePressEvent (QMouseEvent *) |
virtual void | widgetMouseReleaseEvent (QMouseEvent *) |
virtual void | widgetMouseMoveEvent (QMouseEvent *) |
virtual void | widgetKeyPressEvent (QKeyEvent *) |
virtual void | widgetKeyReleaseEvent (QKeyEvent *) |
virtual void | paintEvent (QPaintEvent *) override |
Paint event. | |
virtual QBitmap | contentsMask () const |
Calculate a mask for the contents of the panned widget. | |
virtual QPixmap | grab () const |
QwtPanner provides panning of a widget.
QwtPanner grabs the contents of a widget, that can be dragged in all directions. The offset between the start and the end position is emitted by the panned signal.
QwtPanner grabs the content of the widget into a pixmap and moves the pixmap around, without initiating any repaint events for the widget. Areas, that are not part of content are not painted while panning. This makes panning fast enough for widgets, where repaints are too slow for mouse movements.
For widgets, where repaints are very fast it might be better to implement panning manually by mapping mouse events into paint events.
Definition at line 35 of file qwt_panner.h.
|
explicit |
Creates an panner that is enabled for the left mouse button.
parent | Parent widget to be panned |
Definition at line 87 of file qwt_panner.cpp.
|
virtual |
Destructor.
Definition at line 101 of file qwt_panner.cpp.
|
protectedvirtual |
Calculate a mask for the contents of the panned widget.
Sometimes only parts of the contents of a widget should be panned. F.e. for a widget with a styled background with rounded borders only the area inside of the border should be panned.
Reimplemented in QwtPlotPanner.
Definition at line 297 of file qwt_panner.cpp.
const QCursor QwtPanner::cursor | ( | ) | const |
Definition at line 167 of file qwt_panner.cpp.
|
overridevirtual |
Event filter.
When isEnabled() is true mouse events of the observed widget are filtered.
object | Object to be filtered |
event | Event |
Definition at line 330 of file qwt_panner.cpp.
void QwtPanner::getAbortKey | ( | int & | key, |
Qt::KeyboardModifiers & | modifiers ) const |
Get the abort key and modifiers.
Definition at line 140 of file qwt_panner.cpp.
void QwtPanner::getMouseButton | ( | Qt::MouseButton & | button, |
Qt::KeyboardModifiers & | modifiers ) const |
Get mouse button and modifiers used for panning.
Definition at line 118 of file qwt_panner.cpp.
|
protectedvirtual |
Grab the widget into a pixmap.
Reimplemented in QwtPlotPanner.
Definition at line 306 of file qwt_panner.cpp.
bool QwtPanner::isEnabled | ( | ) | const |
Definition at line 240 of file qwt_panner.cpp.
bool QwtPanner::isOrientationEnabled | ( | Qt::Orientation | o | ) | const |
Definition at line 231 of file qwt_panner.cpp.
|
signal |
Signal emitted, while the widget moved, but panning is not finished.
dx | Offset in horizontal direction |
dy | Offset in vertical direction |
Qt::Orientations QwtPanner::orientations | ( | ) | const |
Return the orientation, where panning is enabled.
Definition at line 222 of file qwt_panner.cpp.
|
overrideprotectedvirtual |
Paint event.
Repaint the grabbed pixmap on its current position and fill the empty spaces by the background of the parent widget.
event | Paint event |
Definition at line 253 of file qwt_panner.cpp.
|
signal |
Signal emitted, when panning is done
dx | Offset in horizontal direction |
dy | Offset in vertical direction |
void QwtPanner::setAbortKey | ( | int | key, |
Qt::KeyboardModifiers | modifiers = Qt::NoModifier ) |
Change the abort key The defaults are Qt::Key_Escape and Qt::NoModifiers
key | Key ( See Qt::Keycode ) |
modifiers | Keyboard modifiers |
Definition at line 132 of file qwt_panner.cpp.
void QwtPanner::setCursor | ( | const QCursor & | cursor | ) |
Change the cursor, that is active while panning The default is the cursor of the parent widget.
cursor | New cursor |
Definition at line 156 of file qwt_panner.cpp.
void QwtPanner::setEnabled | ( | bool | on | ) |
En/disable the panner.
When enabled is true an event filter is installed for the observed widget, otherwise the event filter is removed.
on | true or false |
Definition at line 188 of file qwt_panner.cpp.
void QwtPanner::setMouseButton | ( | Qt::MouseButton | button, |
Qt::KeyboardModifiers | modifiers = Qt::NoModifier ) |
Change the mouse button and modifiers used for panning The defaults are Qt::LeftButton and Qt::NoModifier
Definition at line 110 of file qwt_panner.cpp.
void QwtPanner::setOrientations | ( | Qt::Orientations | o | ) |
Set the orientations, where panning is enabled The default value is in both directions: Qt::Horizontal | Qt::Vertical
/param o Orientation
Definition at line 216 of file qwt_panner.cpp.
|
protectedvirtual |
Handle a key press event for the observed widget.
keyEvent | Key event |
Definition at line 482 of file qwt_panner.cpp.
|
protectedvirtual |
Handle a key release event for the observed widget.
keyEvent | Key event |
Definition at line 502 of file qwt_panner.cpp.
|
protectedvirtual |
Handle a mouse move event for the observed widget.
mouseEvent | Mouse event |
Definition at line 421 of file qwt_panner.cpp.
|
protectedvirtual |
Handle a mouse press event for the observed widget.
mouseEvent | Mouse event |
Reimplemented in QwtPolarPanner.
Definition at line 381 of file qwt_panner.cpp.
|
protectedvirtual |
Handle a mouse release event for the observed widget.
mouseEvent | Mouse event |
Definition at line 449 of file qwt_panner.cpp.