Qwt User's Guide
svn
|
#include <qwt_slider.h>
Inherits QwtAbstractSlider, and QwtAbstractScale.
Public Types | |
enum | BackgroundStyle { Trough = 0x01, Groove = 0x02 } |
typedef QFlags< BackgroundStyle > | BackgroundStyles |
enum | ScalePos { NoScale, LeftScale, RightScale, TopScale, BottomScale } |
enum | ScrollMode { ScrNone, ScrMouse, ScrTimer, ScrDirect, ScrPage } |
Public Slots | |
virtual void | fitValue (double val) |
virtual void | incValue (int steps) |
virtual void | setReadOnly (bool) |
virtual void | setValue (double val) |
Signals | |
void | sliderMoved (double value) |
void | sliderPressed () |
void | sliderReleased () |
void | valueChanged (double value) |
Public Member Functions | |
bool | autoScale () const |
BackgroundStyles | backgroundStyle () const |
int | borderWidth () const |
QSize | handleSize () const |
virtual void | incPages (int) |
bool | isReadOnly () const |
bool | isValid () const |
virtual double | mass () const |
double | maxValue () const |
virtual QSize | minimumSizeHint () const |
double | minValue () const |
Qt::Orientation | orientation () const |
int | pageSize () const |
bool | periodic () const |
QwtSlider (QWidget *parent, Qt::Orientation=Qt::Horizontal, ScalePos=NoScale, BackgroundStyles=Trough) | |
const QwtScaleDraw * | scaleDraw () const |
const QwtScaleEngine * | scaleEngine () const |
QwtScaleEngine * | scaleEngine () |
const QwtScaleMap & | scaleMap () const |
int | scaleMaxMajor () const |
int | scaleMaxMinor () const |
ScalePos | scalePosition () const |
void | setAutoScale () |
void | setBackgroundStyle (BackgroundStyles) |
void | setBorderWidth (int bw) |
void | setHandleSize (int width, int height) |
void | setHandleSize (const QSize &) |
virtual void | setMass (double val) |
virtual void | setOrientation (Qt::Orientation) |
void | setPeriodic (bool tf) |
void | setRange (double vmin, double vmax, double vstep=0.0, int pagesize=1) |
void | setScale (double vmin, double vmax, double step=0.0) |
void | setScale (const QwtInterval &, double step=0.0) |
void | setScale (const QwtScaleDiv &) |
void | setScaleDraw (QwtScaleDraw *) |
void | setScaleEngine (QwtScaleEngine *) |
void | setScaleMaxMajor (int ticks) |
void | setScaleMaxMinor (int ticks) |
void | setScalePosition (ScalePos s) |
void | setSpacing (int) |
void | setStep (double) |
void | setTracking (bool enable) |
void | setUpdateTime (int t) |
void | setValid (bool valid) |
virtual QSize | sizeHint () const |
int | spacing () const |
double | step () const |
void | stopMoving () |
double | value () const |
Protected Member Functions | |
const QwtAbstractScaleDraw * | abstractScaleDraw () const |
QwtAbstractScaleDraw * | abstractScaleDraw () |
virtual void | changeEvent (QEvent *) |
virtual void | drawHandle (QPainter *, const QRect &, int pos) const |
virtual void | drawSlider (QPainter *, const QRect &) const |
double | exactPrevValue () const |
double | exactValue () const |
virtual void | getScrollMode (const QPoint &p, QwtAbstractSlider::ScrollMode &, int &direction) const |
virtual double | getValue (const QPoint &p) |
virtual void | keyPressEvent (QKeyEvent *e) |
virtual void | mouseMoveEvent (QMouseEvent *e) |
double | mouseOffset () const |
virtual void | mousePressEvent (QMouseEvent *e) |
virtual void | mouseReleaseEvent (QMouseEvent *e) |
virtual void | paintEvent (QPaintEvent *) |
double | prevValue () const |
virtual void | rangeChange () |
void | rescale (double vmin, double vmax, double step=0.0) |
virtual void | resizeEvent (QResizeEvent *) |
virtual void | scaleChange () |
QwtScaleDraw * | scaleDraw () |
int | scrollMode () const |
void | setAbstractScaleDraw (QwtAbstractScaleDraw *) |
void | setMouseOffset (double) |
virtual void | setPosition (const QPoint &) |
virtual void | stepChange () |
virtual void | timerEvent (QTimerEvent *e) |
int | transform (double v) const |
virtual void | valueChange () |
virtual void | wheelEvent (QWheelEvent *e) |
The Slider Widget.
QwtSlider is a slider widget which operates on an interval of type double. QwtSlider supports different layouts as well as a scale.
typedef QFlags<BackgroundStyle> QwtSlider::BackgroundStyles |
Background styles.
enum QwtSlider::ScalePos |
Scale position. QwtSlider tries to enforce valid combinations of its orientation and scale position:
enum QwtAbstractSlider::ScrollMode [inherited] |
Scroll mode
QwtSlider::QwtSlider | ( | QWidget * | parent, |
Qt::Orientation | orientation = Qt::Horizontal , |
||
ScalePos | scalePos = NoScale , |
||
BackgroundStyles | bgStyle = Trough |
||
) | [explicit] |
Constructor.
parent | parent widget |
orientation | Orientation of the slider. Can be Qt::Horizontal or Qt::Vertical. Defaults to Qt::Horizontal. |
scalePos | Position of the scale. Defaults to QwtSlider::NoScale. |
bgStyle | Background style. QwtSlider::Trough draws the slider button in a trough, QwtSlider::Slot draws a slot underneath the button. An or-combination of both may also be used. The default is QwtSlider::Trough. |
QwtSlider enforces valid combinations of its orientation and scale position. If the combination is invalid, the scale position will be set to NoScale. Valid combinations are:
const QwtAbstractScaleDraw * QwtAbstractScale::abstractScaleDraw | ( | ) | const [protected, inherited] |
QwtAbstractScaleDraw * QwtAbstractScale::abstractScaleDraw | ( | ) | [protected, inherited] |
bool QwtAbstractScale::autoScale | ( | ) | const [inherited] |
true
if autoscaling is enabled QwtSlider::BackgroundStyles QwtSlider::backgroundStyle | ( | ) | const |
int QwtSlider::borderWidth | ( | ) | const |
void QwtSlider::changeEvent | ( | QEvent * | event | ) | [protected, virtual] |
Qt change event handler.
void QwtSlider::drawHandle | ( | QPainter * | painter, |
const QRect & | sliderRect, | ||
int | pos | ||
) | const [protected, virtual] |
Draw the thumb at a position
painter | Painter |
sliderRect | Bounding rectangle of the slider |
pos | Position of the slider thumb |
void QwtSlider::drawSlider | ( | QPainter * | painter, |
const QRect & | sliderRect | ||
) | const [protected, virtual] |
Draw the slider into the specified rectangle.
painter | Painter |
sliderRect | Bounding rectangle of the slider |
double QwtDoubleRange::exactPrevValue | ( | ) | const [protected, inherited] |
Returns the exact previous value.
double QwtDoubleRange::exactValue | ( | ) | const [protected, inherited] |
Returns the exact value.
The exact value is the value which QwtDoubleRange::value would return if the value were not adjusted to the step raster. It differs from the current value only if fitValue() or incValue() have been used before. This function is intended for internal use in derived classes.
void QwtAbstractSlider::fitValue | ( | double | value | ) | [virtual, slot, inherited] |
Set the slider's value to the nearest integer multiple of the step size.
value | Value |
Reimplemented from QwtDoubleRange.
void QwtSlider::getScrollMode | ( | const QPoint & | p, |
QwtAbstractSlider::ScrollMode & | scrollMode, | ||
int & | direction | ||
) | const [protected, virtual] |
Determine scrolling mode and direction.
p | point |
scrollMode | Scrolling mode |
direction | Direction |
Implements QwtAbstractSlider.
double QwtSlider::getValue | ( | const QPoint & | pos | ) | [protected, virtual] |
Determine the value corresponding to a specified mouse location.
pos | Mouse position |
Implements QwtAbstractSlider.
QSize QwtSlider::handleSize | ( | ) | const |
void QwtDoubleRange::incPages | ( | int | nPages | ) | [virtual, inherited] |
Increment the value by a specified number of pages.
nPages | Number of pages to increment. A negative number decrements the value. |
void QwtAbstractSlider::incValue | ( | int | steps | ) | [virtual, slot, inherited] |
Increment the value by a specified number of steps.
steps | number of steps |
Reimplemented from QwtDoubleRange.
bool QwtAbstractSlider::isReadOnly | ( | ) | const [inherited] |
In read only mode the slider can't be controlled by mouse or keyboard.
bool QwtAbstractSlider::isValid | ( | ) | const [inline, inherited] |
Reimplemented from QwtDoubleRange.
void QwtAbstractSlider::keyPressEvent | ( | QKeyEvent * | e | ) | [protected, virtual, inherited] |
Handles key events
e | Key event |
Reimplemented in QwtDial, and QwtCompass.
double QwtAbstractSlider::mass | ( | ) | const [virtual, inherited] |
double QwtDoubleRange::maxValue | ( | ) | const [inherited] |
Returns the value of the second border of the range.
maxValue returns the value which has been specified as the second parameter in QwtDoubleRange::setRange.
Reimplemented in QwtCounter.
QSize QwtSlider::minimumSizeHint | ( | ) | const [virtual] |
Return a minimum size hint.
double QwtDoubleRange::minValue | ( | ) | const [inherited] |
Returns the value at the first border of the range.
minValue returns the value which has been specified as the first parameter in setRange().
Reimplemented in QwtCounter.
void QwtAbstractSlider::mouseMoveEvent | ( | QMouseEvent * | e | ) | [protected, virtual, inherited] |
Mouse Move Event handler
e | Mouse event |
double QwtAbstractSlider::mouseOffset | ( | ) | const [protected, inherited] |
void QwtAbstractSlider::mousePressEvent | ( | QMouseEvent * | e | ) | [protected, virtual, inherited] |
Mouse press event handler
e | Mouse event |
void QwtAbstractSlider::mouseReleaseEvent | ( | QMouseEvent * | e | ) | [protected, virtual, inherited] |
Mouse Release Event handler
e | Mouse event |
Qt::Orientation QwtAbstractSlider::orientation | ( | ) | const [inherited] |
int QwtDoubleRange::pageSize | ( | ) | const [inherited] |
Returns the page size in steps.
void QwtSlider::paintEvent | ( | QPaintEvent * | event | ) | [protected, virtual] |
Qt paint event
event | Paint event |
bool QwtDoubleRange::periodic | ( | ) | const [inherited] |
Returns true if the range is periodic.
double QwtDoubleRange::prevValue | ( | ) | const [protected, inherited] |
Returns the previous value.
void QwtSlider::rangeChange | ( | ) | [protected, virtual] |
Notify change of range.
Reimplemented from QwtDoubleRange.
void QwtAbstractScale::rescale | ( | double | vmin, |
double | vmax, | ||
double | stepSize = 0.0 |
||
) | [protected, inherited] |
Recalculate the scale division and update the scale draw.
vmin | Lower limit of the scale interval |
vmax | Upper limit of the scale interval |
stepSize | Major step size |
void QwtSlider::resizeEvent | ( | QResizeEvent * | ) | [protected, virtual] |
Qt resize event.
void QwtSlider::scaleChange | ( | ) | [protected, virtual] |
Notify changed scale.
Reimplemented from QwtAbstractScale.
const QwtScaleDraw * QwtSlider::scaleDraw | ( | ) | const |
QwtScaleDraw * QwtSlider::scaleDraw | ( | ) | [protected] |
const QwtScaleEngine * QwtAbstractScale::scaleEngine | ( | ) | const [inherited] |
QwtScaleEngine * QwtAbstractScale::scaleEngine | ( | ) | [inherited] |
const QwtScaleMap & QwtAbstractScale::scaleMap | ( | ) | const [inherited] |
int QwtAbstractScale::scaleMaxMajor | ( | ) | const [inherited] |
int QwtAbstractScale::scaleMaxMinor | ( | ) | const [inherited] |
QwtSlider::ScalePos QwtSlider::scalePosition | ( | ) | const |
Return the scale position.
int QwtAbstractSlider::scrollMode | ( | ) | const [protected, inherited] |
sa ScrollMode
void QwtAbstractScale::setAbstractScaleDraw | ( | QwtAbstractScaleDraw * | scaleDraw | ) | [protected, inherited] |
Set a scale draw.
scaleDraw has to be created with new and will be deleted in ~QwtAbstractScale or the next call of setAbstractScaleDraw.
void QwtAbstractScale::setAutoScale | ( | ) | [inherited] |
Advise the widget to control the scale range internally.
Autoscaling is on by default.
void QwtSlider::setBackgroundStyle | ( | BackgroundStyles | style | ) |
Set the background style.
void QwtSlider::setBorderWidth | ( | int | width | ) |
Change the slider's border width.
width | Border width |
void QwtSlider::setHandleSize | ( | int | width, |
int | height | ||
) |
void QwtSlider::setHandleSize | ( | const QSize & | size | ) |
void QwtAbstractSlider::setMass | ( | double | val | ) | [virtual, inherited] |
Set the slider's mass for flywheel effect.
If the slider's mass is greater then 0, it will continue to move after the mouse button has been released. Its speed decreases with time at a rate depending on the slider's mass. A large mass means that it will continue to move for a long time.
Derived widgets may overload this function to make it public.
val | New mass in kg |
Reimplemented in QwtWheel.
void QwtAbstractSlider::setMouseOffset | ( | double | offset | ) | [protected, inherited] |
void QwtSlider::setOrientation | ( | Qt::Orientation | o | ) | [virtual] |
Set the orientation.
o | Orientation. Allowed values are Qt::Horizontal and Qt::Vertical. |
If the new orientation and the old scale position are an invalid combination, the scale position will be set to QwtSlider::NoScale.
Reimplemented from QwtAbstractSlider.
void QwtDoubleRange::setPeriodic | ( | bool | tf | ) | [inherited] |
Make the range periodic.
When the range is periodic, the value will be set to a point inside the interval such that
point = value + n * width
if the user tries to set a new value which is outside the range. If the range is nonperiodic (the default), values outside the range will be clipped.
tf | true for a periodic range |
void QwtAbstractSlider::setPosition | ( | const QPoint & | p | ) | [protected, virtual, inherited] |
Move the slider to a specified point, adjust the value and emit signals if necessary.
void QwtDoubleRange::setRange | ( | double | vmin, |
double | vmax, | ||
double | vstep = 0.0 , |
||
int | pageSize = 1 |
||
) | [inherited] |
Specify range and step size.
vmin | lower boundary of the interval |
vmax | higher boundary of the interval |
vstep | step width |
pageSize | page size in steps |
void QwtAbstractSlider::setReadOnly | ( | bool | readOnly | ) | [virtual, slot, inherited] |
En/Disable read only mode
In read only mode the slider can't be controlled by mouse or keyboard.
readOnly | Enables in case of true |
void QwtAbstractScale::setScale | ( | double | vmin, |
double | vmax, | ||
double | stepSize = 0.0 |
||
) | [inherited] |
Specify a scale.
Disable autoscaling and define a scale by an interval and a step size
vmin | lower limit of the scale interval |
vmax | upper limit of the scale interval |
stepSize | major step size |
d_data->autoScale = false; d_data->stepSize = stepSize; rescale( vmin, vmax, stepSize ); QwtAbstractScale *xx = new QwtAbstractScale(12, "hello", this);
void QwtAbstractScale::setScale | ( | const QwtInterval & | interval, |
double | stepSize = 0.0 |
||
) | [inherited] |
Specify a scale.
Disable autoscaling and define a scale by an interval and a step size
interval | Interval |
stepSize | major step size |
void QwtAbstractScale::setScale | ( | const QwtScaleDiv & | scaleDiv | ) | [inherited] |
Specify a scale.
Disable autoscaling and define a scale by a scale division
scaleDiv | Scale division |
void QwtSlider::setScaleDraw | ( | QwtScaleDraw * | scaleDraw | ) |
Set a scale draw.
For changing the labels of the scales, it is necessary to derive from QwtScaleDraw and overload QwtScaleDraw::label().
scaleDraw | ScaleDraw object, that has to be created with new and will be deleted in ~QwtSlider or the next call of setScaleDraw(). |
void QwtAbstractScale::setScaleEngine | ( | QwtScaleEngine * | scaleEngine | ) | [inherited] |
Set a scale engine.
The scale engine is responsible for calculating the scale division, and in case of auto scaling how to align the scale.
scaleEngine has to be created with new and will be deleted in ~QwtAbstractScale or the next call of setScaleEngine.
void QwtAbstractScale::setScaleMaxMajor | ( | int | ticks | ) | [inherited] |
Set the maximum number of major tick intervals.
The scale's major ticks are calculated automatically such that the number of major intervals does not exceed ticks. The default value is 5.
ticks | maximal number of major ticks. |
void QwtAbstractScale::setScaleMaxMinor | ( | int | ticks | ) | [inherited] |
Set the maximum number of minor tick intervals.
The scale's minor ticks are calculated automatically such that the number of minor intervals does not exceed ticks. The default value is 3.
ticks |
void QwtSlider::setScalePosition | ( | ScalePos | scalePos | ) |
Change the scale position (and slider orientation).
scalePos | Position of the scale. |
A valid combination of scale position and orientation is enforced:
void QwtSlider::setSpacing | ( | int | spacing | ) |
Change the spacing between pipe and scale.
A spacing of 0 means, that the backbone of the scale is below the trough.
The default setting is 4 pixels.
spacing | Number of pixels |
void QwtDoubleRange::setStep | ( | double | vstep | ) | [inherited] |
Change the step raster.
vstep | new step width |
Reimplemented in QwtCounter.
void QwtAbstractSlider::setTracking | ( | bool | enable | ) | [inherited] |
Enables or disables tracking.
If tracking is enabled, the slider emits a valueChanged() signal whenever its value changes (the default behaviour). If tracking is disabled, the value changed() signal will only be emitted if:
Tracking is enabled by default.
enable | true (enable) or false (disable) tracking. |
void QwtAbstractSlider::setUpdateTime | ( | int | t | ) | [inherited] |
Specify the update interval for automatic scrolling.
t | update interval in milliseconds |
void QwtAbstractSlider::setValid | ( | bool | valid | ) | [inline, inherited] |
void QwtAbstractSlider::setValue | ( | double | val | ) | [virtual, slot, inherited] |
Move the slider to a specified value.
This function can be used to move the slider to a value which is not an integer multiple of the step size.
val | new value |
Reimplemented from QwtDoubleRange.
QSize QwtSlider::sizeHint | ( | ) | const [virtual] |
void QwtAbstractSlider::sliderMoved | ( | double | value | ) | [signal, inherited] |
This signal is emitted when the user moves the slider with the mouse.
value | new value |
void QwtAbstractSlider::sliderPressed | ( | ) | [signal, inherited] |
This signal is emitted when the user presses the movable part of the slider (start ScrMouse Mode).
void QwtAbstractSlider::sliderReleased | ( | ) | [signal, inherited] |
This signal is emitted when the user releases the movable part of the slider.
int QwtSlider::spacing | ( | ) | const |
double QwtDoubleRange::step | ( | ) | const [inherited] |
void QwtDoubleRange::stepChange | ( | ) | [protected, virtual, inherited] |
Notify a change of the step size.
This virtual function is called whenever the step size changes. The default implementation does nothing.
void QwtAbstractSlider::stopMoving | ( | ) | [inherited] |
Stop updating if automatic scrolling is active.
void QwtAbstractSlider::timerEvent | ( | QTimerEvent * | e | ) | [protected, virtual, inherited] |
Qt timer event
e | Timer event |
int QwtSlider::transform | ( | double | value | ) | const [protected] |
Map and round a value into widget coordinates
value | Value |
double QwtDoubleRange::value | ( | ) | const [inherited] |
Returns the current value.
Reimplemented in QwtCounter.
void QwtSlider::valueChange | ( | ) | [protected, virtual] |
Notify change of value.
Reimplemented from QwtAbstractSlider.
void QwtAbstractSlider::valueChanged | ( | double | value | ) | [signal, inherited] |
Notify a change of value.
In the default setting (tracking enabled), this signal will be emitted every time the value changes ( see setTracking() ).
value | new value |
void QwtAbstractSlider::wheelEvent | ( | QWheelEvent * | e | ) | [protected, virtual, inherited] |
Wheel Event handler
e | Whell event |