1 // Copyright (C) 2007-2019 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
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, or (at your option) any later version.
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.
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
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 // SMESH SMESHGUI : GUI for SMESH component
24 // File : SMESHGUI_Hypotheses.h
25 // Author : Julia DOROVSKIKH, Open CASCADE S.A.S.
27 #ifndef SMESHGUI_HYPOTHESES_H
28 #define SMESHGUI_HYPOTHESES_H
31 #include "SMESH_SMESHGUI.hxx"
32 #include "SMESHGUI_HypothesesUtils.h"
35 #include <QtxDialog.h>
39 #include <SALOMEconfig.h>
40 #include CORBA_SERVER_HEADER(SMESH_Hypothesis)
45 * \brief Auxiliary class for creation of hypotheses
47 class SMESHGUI_EXPORT SMESHGUI_GenericHypothesisCreator : public QObject
52 SMESHGUI_GenericHypothesisCreator( const QString& );
53 virtual ~SMESHGUI_GenericHypothesisCreator();
55 void create( SMESH::SMESH_Hypothesis_ptr,
56 const QString&, QWidget*, QObject*, const QString& );
57 void create( bool, const QString&, QWidget*, QObject*, const QString& );
58 void edit( SMESH::SMESH_Hypothesis_ptr, const QString&, QWidget*, QObject*, const QString& );
59 void setInitParamsHypothesis(SMESH::SMESH_Hypothesis_ptr);
61 virtual bool checkParams( QString& ) const;
62 virtual void onReject();
63 virtual QString helpPage() const;
65 QString hypType() const;
66 QString hypName() const;
67 bool isCreation() const;
69 QString getShapeEntry() const { return myShapeEntry; }
70 void setShapeEntry( const QString& theEntry );
72 QString getMainShapeEntry() const { return myMainShapeEntry; }
73 void setMainShapeEntry( const QString& theEntry ) { myMainShapeEntry = theEntry; }
75 void setNoGeomMesh( const bool noGeom ) { myNoGeomMesh = noGeom; }
76 bool getNoGeomMesh() const { return myNoGeomMesh; }
88 QByteArray myTextAsBytes;
92 const char* text() const {
93 ((QByteArray&) myTextAsBytes) = myText.toUtf8(); return myTextAsBytes.constData();
95 void setNoName() { myName.clear(); } // ==> widget occupies both columns
96 bool hasName() const { return !myName.isEmpty(); }
99 typedef QList<StdParam> ListOfStdParams;
100 typedef QList<QWidget*> ListOfWidgets;
102 SMESH::SMESH_Hypothesis_var hypothesis() const;
103 SMESH::SMESH_Hypothesis_var initParamsHypothesis(const bool strict=false) const;
104 bool hasInitParamsHypothesis() const;
105 const ListOfWidgets& widgets() const;
106 ListOfWidgets& changeWidgets();
107 QLabel* getLabel(int i) const;
108 QtxDialog* dlg() const;
109 QString getVariableName(const char* methodName) const;
111 virtual QFrame* buildFrame() = 0;
112 QFrame* buildStdFrame();
113 virtual void retrieveParams() const = 0;
114 virtual QString storeParams() const = 0;
115 virtual bool stdParams( ListOfStdParams& ) const;
116 bool getStdParamFromDlg( ListOfStdParams& ) const;
117 virtual QStringList getVariablesFromDlg() const;
118 static QString stdParamValues( const ListOfStdParams& );
119 virtual void attuneStdWidget( QWidget*, const int ) const;
120 virtual QWidget* getCustomWidget( const StdParam&,
121 QWidget*, const int ) const;
122 virtual QWidget* getHelperWidget() const;
123 virtual bool getParamFromCustomWidget( StdParam&, QWidget* ) const;
124 virtual void valueChanged( QWidget* );
125 virtual QString caption() const;
126 virtual QPixmap icon() const;
127 virtual QString type() const;
130 virtual void onValueChanged();
133 virtual void onDialogFinished( int );
136 void editHypothesis( SMESH::SMESH_Hypothesis_ptr, const QString&, QWidget*, QObject* obj, const QString& );
139 SMESH::SMESH_Hypothesis_var myHypo, myInitParamsHypo;
140 bool myToDeleteInitParamsHypo;
143 ListOfWidgets myParamWidgets;
144 ListOfWidgets myParamLabels;
146 bool myNoGeomMesh; //!< true for a mesh not based on geometry
148 QString myShapeEntry;
149 QString myMainShapeEntry;
152 class SMESHGUI_HypothesisDlg : public QtxDialog
157 SMESHGUI_HypothesisDlg( SMESHGUI_GenericHypothesisCreator*, QWidget* );
158 virtual ~SMESHGUI_HypothesisDlg();
160 void setHIcon( const QPixmap& );
161 void setCustomFrame( QFrame* );
162 void setType( const QString& );
165 virtual void accept();
166 virtual void reject();
170 SMESHGUI_GenericHypothesisCreator* myCreator;
171 QLabel *myIconLabel, *myTypeLabel;
172 QString myHelpFileName;
176 * \brief Information about a hypothesis
178 struct HypothesisData
180 HypothesisData( const QString&, const QString&, const QString&,
181 const QString&, const QString&, const QString&,
182 const QString&, const int, const int,
183 const QList<int>&, const bool,
184 const QStringList&, const QStringList&,
185 const QStringList&, const QStringList&,
186 const int, const bool supportSub );
188 QString TypeName; //!< hypothesis type name
189 QString PluginName; //!< plugin name
190 QString ServerLibName; //!< server library name
191 QString ClientLibName; //!< client library name
192 QString Label; //!< label
193 QString IconId; //!< icon identifier
194 QString Context; //!< ["GLOBAL","LOCAL","ANY"(default)]
195 int GroupID; //!< group ID (staring from zero)
196 int Priority; //!< integer, priority within the group
197 QList<int> Dim; //!< list of supported dimensions (see SMESH::Dimension enumeration)
198 bool IsAuxOrNeedHyp; //!< TRUE if given HYPOTHESIS is auxiliary one, FALSE otherwise
199 //!< TRUE if given ALGORITHM can't work w/o hypotheses
200 int IsNeedGeometry; //!< 1 if the algorithm works with shapes only,
201 //!< -1 if the algorithm works without shapes only,
202 //!< 0 if the algorithm works in both cases
203 bool IsSupportSubmeshes; //!< TRUE if the algorithm building all-dim elems supports sub-meshes
205 // for algorithm only: dependencies algo <-> algo and algo -> hypos
206 QStringList BasicHypos; //!< list of basic hypotheses
207 QStringList OptionalHypos;//!< list of optional hypotheses
208 QStringList InputTypes; //!< list of element types required as a prerequisite
209 QStringList OutputTypes; //!< list of types of generated elements
213 * \brief Class containing set of hypotheses
215 * Actually it contains list of hypo types
220 HypothesesSet( const QString& );
221 HypothesesSet( const QString&, const QStringList&, const QStringList& );
223 QString name() const;
224 void set( bool, const QStringList& );
225 int count( bool ) const;
227 void setIsCustom( bool );
228 bool getIsCustom() const;
233 // CASCADE-like iteration
237 QString current() const;
240 QStringList* list(bool) const;
241 QStringList* list() const;
244 QString myHypoSetName;
245 QStringList myHypoList, myAlgoList;
246 bool myIsAlgo, myIsCustom;
250 #endif // SMESHGUI_HYPOTHESES_H