1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
3 // File: ModuleBase_WidgetDoubleValue.h
4 // Created: 04 June 2014
5 // Author: Vitaly Smetannikov
7 #ifndef ModuleBase_WidgetDoubleValue_H
8 #define ModuleBase_WidgetDoubleValue_H
10 #include "ModuleBase.h"
11 #include "ModuleBase_ModelWidget.h"
13 class ModuleBase_ParamSpinBox;
14 class Config_WidgetAPI;
21 * A class of property panel widget for double value input
22 * It can be defined with "doublevalue" keyword. For example:
24 * <doublevalue id="x" label="X:" icon=":pictures/x_point.png" tooltip="X coordinate"/>
27 class MODULEBASE_EXPORT ModuleBase_WidgetDoubleValue : public ModuleBase_ModelWidget
32 /// \param theParent the parent object
33 /// \param theData the widget configuation. The attribute of the model widget is obtained from
34 ModuleBase_WidgetDoubleValue(QWidget* theParent, const Config_WidgetAPI* theData);
36 virtual ~ModuleBase_WidgetDoubleValue();
38 /// Select the internal content if it can be selected. It is empty in the default realization
39 virtual void selectContent();
41 /// Returns list of widget controls
42 /// \return a control list
43 virtual QList<QWidget*> getControls() const;
45 /// Returns true if the event is processed.
46 virtual bool processEnter();
49 // Delayed value chnged: when user starts typing something,
50 // it gives him a 0,5 second to finish typing, when sends valueChnaged() signal
51 // void onValueChanged();
54 /// Saves the internal parameters to the given feature
55 /// \return True in success
56 virtual bool storeValueCustom() const;
58 //! Read value of corresponded attribute from data model to the input control
59 // \return True in success
60 virtual bool restoreValueCustom();
62 /// Fills the widget with default values
63 /// \return true if the widget current value is reset
64 virtual bool resetCustom();
67 /// Label of the widget
70 /// Input value control
71 ModuleBase_ParamSpinBox* mySpinBox;