Salome HOME
Origin selection as Rotation center of Sketch Rotation feature.
[modules/shaper.git] / src / ModuleBase / ModuleBase_DoubleSpinBox.h
index 347af2f49461d16ee029323ae620b6fd6352db8f..982b1088d264ec4a9d1d5fea2e636ae913e9c164 100644 (file)
@@ -1,7 +1,7 @@
 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
 
 // File:      ModuleBase_DoubleSpinBox.h
-// Author:    Sergey TELKOV
+// Author:    Sergey BELASH
 //
 #ifndef MODULEBASE_DOUBLESPINBOX_H_
 #define MODULEBASE_DOUBLESPINBOX_H_
 #include <QDoubleSpinBox>
 #include <QValidator>
 
+#include <QColor>
+
+class QKeyEvent;
 
 /**
 * \ingroup GUI
-* An extension and customozation of QDoubleSpinBox class
+* An extension and customization of QDoubleSpinBox class
 */
 class MODULEBASE_EXPORT ModuleBase_DoubleSpinBox : public QDoubleSpinBox
 {
 Q_OBJECT
 
  public:
-  explicit ModuleBase_DoubleSpinBox(QWidget* theParent = 0, int thePrecision = 6);
+  explicit ModuleBase_DoubleSpinBox( QWidget* theParent = 0, int thePrecision = -12 );
   virtual ~ModuleBase_DoubleSpinBox();
 
   /// Returns true if the control is clear
@@ -48,6 +51,19 @@ Q_OBJECT
   /// Validate current value
   virtual QValidator::State validate(QString&, int&) const;
 
+  /// Change enable/disable internal state to emit key press event
+  /// \param theEnable if true, the signal is emitted
+  /// \return the previous value
+  bool enableKeyPressEvent(const bool& theEnable);
+
+  /// Imitation of disable control value. If theEnable is false, the control becomes
+  /// read only and base color is disabled.
+  void setValueEnabled(const bool& theEnable);
+
+signals:
+  /// The signal about key release on the control, that corresponds to the attribute
+  void enterReleased();
+
  protected slots:
    /// Called on text changed
   virtual void onTextChanged(const QString&);
@@ -55,13 +71,24 @@ Q_OBJECT
  protected:
    /// Removes extra trailing zero symbols
   QString removeTrailingZeroes(const QString&) const;
+  /// Called on key press event
+  virtual void keyReleaseEvent(QKeyEvent* theEvent);
+
+  /// Called on key press event
+  virtual void keyPressEvent(QKeyEvent* theEvent);
 
  private:
+  // boolen flag whether the key event is emitted. The default value is false
+  bool myIsEmitKeyPressEvent;
+
    /// Is clear flag
   bool myCleared;
 
   /// Precision value
   int myPrecision;
+
+  /// Cashed color of active base palette
+  QColor myEnabledBaseColor;
 };
 
 #endif