Salome HOME
PAL15429 Computation of the mesh, based on "014.brep" via Tetrahedron(NETGEN), is...
[modules/smesh.git] / src / SMESHGUI / SMESHGUI_SpinBox.cxx
1 //  Copyright (C) 2007-2008  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 //  Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 //  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
6 //  This library is free software; you can redistribute it and/or
7 //  modify it under the terms of the GNU Lesser General Public
8 //  License as published by the Free Software Foundation; either
9 //  version 2.1 of the License.
10 //
11 //  This library is distributed in the hope that it will be useful,
12 //  but WITHOUT ANY WARRANTY; without even the implied warranty of
13 //  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 //  Lesser General Public License for more details.
15 //
16 //  You should have received a copy of the GNU Lesser General Public
17 //  License along with this library; if not, write to the Free Software
18 //  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
19 //
20 //  See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 //  SMESH SMESHGUI : GUI for SMESH component
23 //  File   : SMESHGUI_SpinBox.cxx
24 //  Author : Lucien PIGNOLONI
25 //  Module : SMESH
26 //  $Header$
27 //
28 #include "SMESHGUI_SpinBox.h"
29 #include "SMESHGUI.h"
30
31 #include <qvalidator.h>
32 #include <qlineedit.h>
33
34 using namespace std;
35
36 //=================================================================================
37 // class    : SMESHGUI_SpinBox()
38 // purpose  : constructor of specific widget accepting floats in double precision.
39 //=================================================================================
40 SMESHGUI_SpinBox::SMESHGUI_SpinBox (QWidget* parent, const char* name)
41      : QtxDblSpinBox(parent, name)
42 {
43 }
44
45 //=================================================================================
46 // function : SetStep()  [SLOT]
47 // purpose  :
48 //=================================================================================
49 void SMESHGUI_SpinBox::SetStep (double newStep)
50 {
51   setLineStep(newStep);
52 }
53
54 //=================================================================================
55 // function : ~SMESHGUI_SpinBox()
56 // purpose  : destructor
57 //=================================================================================
58 SMESHGUI_SpinBox::~SMESHGUI_SpinBox()
59 {
60 }
61
62 //=================================================================================
63 // function : SetValue()
64 // purpose  :
65 //=================================================================================
66 void SMESHGUI_SpinBox::SetValue (double v)
67 {
68   setValue(v);
69   editor()->setCursorPosition( 0 );
70 }
71
72 //=================================================================================
73 // function : GetValue()
74 // purpose  : returns a double
75 //=================================================================================
76 double SMESHGUI_SpinBox::GetValue()
77 {
78   return value();
79 }
80
81 //=================================================================================
82 // function : GetString()
83 // purpose  : returns a QString
84 //=================================================================================
85 QString SMESHGUI_SpinBox::GetString()
86 {
87   return cleanText();
88 }
89
90 //=================================================================================
91 // function : RangeStepAndValidator()
92 // purpose  :
93 //=================================================================================
94 void SMESHGUI_SpinBox::RangeStepAndValidator
95   (double min, double max, double step, unsigned short decimals)
96 {
97   setPrecision(-decimals); // PAL8769. Minus is for using 'g' double->string conversion specifier,
98   //                          see QtxDblSpinBox::mapValueToText( double v )
99   setRange(min, max);
100   setLineStep(step);
101   ((QDoubleValidator*)validator())->setRange(min, max, decimals);
102 }