123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- /*=========================================================================
- Library: CTK
- Copyright (c) Kitware Inc.
- Licensed under the Apache License, Version 2.0 (the "License");
- you may not use this file except in compliance with the License.
- You may obtain a copy of the License at
- http://www.apache.org/licenses/LICENSE-2.0.txt
- Unless required by applicable law or agreed to in writing, software
- distributed under the License is distributed on an "AS IS" BASIS,
- WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- See the License for the specific language governing permissions and
- limitations under the License.
- =========================================================================*/
- // CTK includes
- #include "ctkDoubleSpinBox.h"
- // Qt includes
- #include <QDoubleSpinBox>
- #include <QPointer>
- class ctkDoubleSpinBoxPrivate;
- class ctkValueProxy;
- //-----------------------------------------------------------------------------
- class ctkQDoubleSpinBox: public QDoubleSpinBox
- {
- Q_OBJECT
- /// This property controls whether decreasing the value by the mouse
- /// button or mouse wheel increases the value of the widget, and inverts the
- /// control similarly in the other way round or not. The property is switched off by
- /// default.
- /// \sa invertedControls(), setInvertedControls()
- Q_PROPERTY(bool invertedControls READ invertedControls WRITE setInvertedControls)
- public:
- typedef QDoubleSpinBox Superclass;
- ctkQDoubleSpinBox(ctkDoubleSpinBoxPrivate* pimpl, QWidget* widget);
- void setInvertedControls(bool invertedControls);
- bool invertedControls() const;
- /// Overrides QDoubleSpinBox::stepBy(int) and negates the step number if the
- /// invertedControls property is true.
- virtual void stepBy(int steps);
- /// Expose lineEdit() publicly.
- /// \sa QAbstractSpinBox::lineEdit()
- virtual QLineEdit* lineEdit()const;
- virtual double valueFromText(const QString &text) const;
- virtual QString textFromValue(double value) const;
- virtual int decimalsFromText(const QString &text) const;
- virtual QValidator::State validate(QString& input, int& pos)const;
- /// Expose publicly QAbstractSpinBox::initStyleOption()
- void initStyleOptionSpinBox(QStyleOptionSpinBox* option);
- protected:
- QScopedPointer<ctkDoubleSpinBoxPrivate> d_ptr;
- /// If the invertedControls property is false (by default) then this function
- /// behavesLike QDoubleSpinBox::stepEnabled(). If the property is true then
- /// stepping down is allowed if the value is less then the maximum, and
- /// stepping up is allowed if the value is greater then the minimum.
- virtual StepEnabled stepEnabled () const;
- bool InvertedControls;
- private:
- Q_DECLARE_PRIVATE(ctkDoubleSpinBox);
- Q_DISABLE_COPY(ctkQDoubleSpinBox);
- };
- //-----------------------------------------------------------------------------
- class ctkDoubleSpinBoxPrivate: public QObject
- {
- Q_OBJECT
- Q_DECLARE_PUBLIC(ctkDoubleSpinBox);
- protected:
- ctkDoubleSpinBox* const q_ptr;
- public:
- ctkDoubleSpinBoxPrivate(ctkDoubleSpinBox& object);
- ctkQDoubleSpinBox* SpinBox;
- ctkDoubleSpinBox::SetMode Mode;
- int DefaultDecimals;
- ctkDoubleSpinBox::DecimalsOptions DOption;
- bool InvertedControls;
- ctkDoubleSpinBox::SizeHintPolicy SizeHintPolicy;
- double InputValue;
- double InputRange[2];
- mutable QString CachedText;
- mutable double CachedValue;
- mutable QValidator::State CachedState;
- mutable int CachedDecimals;
- mutable QSize CachedSizeHint;
- mutable QSize CachedMinimumSizeHint;
- bool ForceInputValueUpdate;
- QPointer<ctkValueProxy> Proxy;
- void init();
- /// Compare two double previously rounded according to the number of decimals
- bool compare(double x1, double x2) const;
- /// Return a value rounded with the number of decimals
- double round(double value, int decimals)const;
- /// Remove prefix and suffix
- QString stripped(const QString& text, int* pos)const;
- /// Return the number of decimals bounded by the allowed min and max number of
- /// decimals.
- /// If -1, returns the current number of decimals.
- int boundDecimals(int decimals)const;
- /// Return the number of decimals to use to display the value.
- /// Note that if DecimalsByValue is not set, the number of decimals to use
- /// is DefaultDecimals.
- int decimalsForValue(double value)const;
- /// Set the number of decimals of the spinbox and emit the signal
- /// No check if they are the same.
- void setDecimals(int dec);
- /// Set value with a specific number of decimals. -1 means the number of
- /// decimals stays the same.
- void setValue(double value, int dec = -1);
- /// Ensure the spinbox text is meaningful.
- /// It is called multiple times when the spinbox line edit is modified,
- /// therefore values are cached.
- double validateAndInterpret(QString &input, int &pos,
- QValidator::State &state, int &decimals) const;
- void connectSpinBoxValueChanged();
- void disconnectSpinBoxValueChanged();
- public Q_SLOTS:
- void editorTextChanged(const QString& text);
- void onValueChanged();
- void onValueProxyAboutToBeModified();
- void onValueProxyModified();
- };
|