Salome HOME
IMP 0020089: Take into account 0D elements (MED_POINT1)
[modules/smesh.git] / src / SMESHGUI / SMESHGUI_MeshInfosDlg.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_MeshInfosDlg.cxx
24 // Author : Nicolas BARBEROU
25 // SMESH includes
26 //
27 #include "SMESHGUI_MeshInfosDlg.h"
28
29 #include "SMESHGUI.h"
30 #include "SMESHGUI_Utils.h"
31
32 // SALOME GUI includes
33 #include <SUIT_Desktop.h>
34 #include <SUIT_ResourceMgr.h>
35 #include <SUIT_OverrideCursor.h>
36 #include <SUIT_Session.h>
37 #include <SUIT_MessageBox.h>
38
39 #include <LightApp_SelectionMgr.h>
40 #include <LightApp_Application.h>
41 #include <SALOME_ListIO.hxx>
42
43 // SALOME KERNEL includes
44 #include <SALOMEDSClient_Study.hxx>
45
46 // Qt includes
47 #include <QGroupBox>
48 #include <QLabel>
49 #include <QFrame>
50 #include <QStackedWidget>
51 #include <QVBoxLayout>
52 #include <QHBoxLayout>
53 #include <QGridLayout>
54 #include <QPushButton>
55 #include <QKeyEvent>
56
57 // IDL includes
58 #include <SALOMEconfig.h>
59 #include CORBA_SERVER_HEADER(SMESH_Mesh)
60 #include CORBA_SERVER_HEADER(SMESH_Group)
61
62 #define COLONIZE(str)   (QString(str).contains(":") > 0 ? QString(str) : QString(str) + " :" )
63 #define SPACING 6
64 #define MARGIN  11
65
66 //=================================================================================
67 // function : SMESHGUI_MeshInfosDlg()
68 // purpose  : Constructor
69 //=================================================================================
70 SMESHGUI_MeshInfosDlg::SMESHGUI_MeshInfosDlg(SMESHGUI* theModule): 
71   QDialog(SMESH::GetDesktop(theModule)),
72   mySelectionMgr(SMESH::GetSelectionMgr(theModule)),
73   mySMESHGUI(theModule)
74 {
75   setModal( false );
76   setAttribute( Qt::WA_DeleteOnClose, true );
77   setWindowTitle(tr("SMESH_MESHINFO_TITLE"));
78   setSizeGripEnabled(true);
79
80   myStartSelection = true;
81   myIsActiveWindow = true;
82
83   QVBoxLayout* aTopLayout = new QVBoxLayout(this);
84   aTopLayout->setSpacing(SPACING);  aTopLayout->setMargin(MARGIN);
85
86   // select button & label
87   QPixmap image0(SMESH::GetResourceMgr( mySMESHGUI )->loadPixmap("SMESH",tr("ICON_SELECT")));
88   mySelectBtn = new QPushButton(this);
89   mySelectBtn->setIcon(image0);
90   mySelectBtn->setSizePolicy(QSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed));
91
92   mySelectLab = new QLabel(this);
93   mySelectLab->setAlignment(Qt::AlignCenter);
94   QFont fnt = mySelectLab->font(); fnt.setBold(true);
95   mySelectLab->setFont(fnt);
96
97   QHBoxLayout* aSelectLayout = new QHBoxLayout;
98   aSelectLayout->setMargin(0); aSelectLayout->setSpacing(0);
99   aSelectLayout->addWidget(mySelectBtn);
100   aSelectLayout->addWidget(mySelectLab);
101
102   // top widget stack
103   myWGStack = new QStackedWidget(this);
104
105   // no valid selection
106   QWidget* myBadWidget = new QWidget(myWGStack);
107   QVBoxLayout* aBadLayout = new QVBoxLayout(myBadWidget);
108   QLabel* myBadLab = new QLabel(tr("SMESH_BAD_SELECTION"), myBadWidget);
109   myBadLab->setAlignment(Qt::AlignCenter);
110   myBadLab->setSizePolicy(QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding));
111   aBadLayout->addWidget(myBadLab);
112   myWGStack->addWidget(myBadWidget);
113
114   // mesh
115   myMeshWidget = new QWidget(myWGStack);
116   QGridLayout* aMeshLayout = new QGridLayout(myMeshWidget);
117   aMeshLayout->setSpacing(SPACING);  aMeshLayout->setMargin(0);
118   myWGStack->addWidget(myMeshWidget);
119
120   // --> name
121   QLabel* myMeshNameLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_NAME")), myMeshWidget);
122   myMeshName    = new QLabel(myMeshWidget);
123   myMeshName->setMinimumWidth(100);
124   QFrame* line1 = new QFrame(myMeshWidget);
125   line1->setFrameStyle(QFrame::HLine | QFrame::Sunken);
126
127   // --> nodes
128   QLabel* myMeshNbNodesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_NODES")), myMeshWidget);
129   myMeshNbNodes  = new QLabel(myMeshWidget);
130   myMeshNbNodes->setMinimumWidth(100);
131   QFrame* line12 = new QFrame(myMeshWidget);
132   line12->setFrameStyle(QFrame::HLine | QFrame::Sunken);
133
134   // --> 0D elements
135   QLabel* myMeshNb0DElemsLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_0DELEMS")), myMeshWidget);
136   myMeshNb0DElems = new QLabel(myMeshWidget);
137   myMeshNb0DElems->setMinimumWidth(100);
138
139   // --> header with orders
140   QLabel* myMeshOrder0Lab = new QLabel(tr("SMESH_MESHINFO_ORDER0"), myMeshWidget);
141   QLabel* myMeshOrder1Lab = new QLabel(tr("SMESH_MESHINFO_ORDER1"), myMeshWidget);
142   QLabel* myMeshOrder2Lab = new QLabel(tr("SMESH_MESHINFO_ORDER2"), myMeshWidget);
143   QFont fnti = myMeshOrder0Lab->font(); fnti.setItalic(true);
144   myMeshOrder0Lab->setFont(fnti);
145   myMeshOrder1Lab->setFont(fnti);
146   myMeshOrder2Lab->setFont(fnti);
147
148   // --> edges
149   QLabel* myMeshNbEdgesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_EDGES")), myMeshWidget);
150   myMeshNbEdges    = new QLabel(myMeshWidget);
151   myMeshNbEdges->setMinimumWidth(100);
152   myMeshNbEdges1   = new QLabel(myMeshWidget);
153   myMeshNbEdges1->setMinimumWidth(100);
154   myMeshNbEdges2   = new QLabel(myMeshWidget);
155   myMeshNbEdges2->setMinimumWidth(100);
156
157   // --> faces
158   myMeshFacesGroup = new QGroupBox(tr("SMESH_MESHINFO_FACES"), myMeshWidget);
159   QGridLayout* myMeshFacesGroupLayout = new QGridLayout(myMeshFacesGroup);
160   myMeshFacesGroupLayout->setSpacing(SPACING);  myMeshFacesGroupLayout->setMargin(MARGIN);
161
162   // --> faces --> total
163   QLabel* myMeshNbFacesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_TOTAL")), myMeshFacesGroup);
164   myMeshNbFacesLab->setFont(fnt);
165   myMeshNbFaces    = new QLabel(myMeshFacesGroup);
166   myMeshNbFaces->setMinimumWidth(100);
167   myMeshNbFaces->setFont(fnt);
168   myMeshNbFaces1   = new QLabel(myMeshFacesGroup);
169   myMeshNbFaces1->setMinimumWidth(100);
170   myMeshNbFaces1->setFont(fnt);
171   myMeshNbFaces2   = new QLabel(myMeshFacesGroup);
172   myMeshNbFaces2->setMinimumWidth(100);
173   myMeshNbFaces2->setFont(fnt);
174
175   // --> faces --> triangles
176   QLabel* myMeshNbTrianglesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_TRIANGLES")), myMeshFacesGroup);
177   myMeshNbTriangles    = new QLabel(myMeshFacesGroup);
178   myMeshNbTriangles->setMinimumWidth(100);
179   myMeshNbTriangles1   = new QLabel(myMeshFacesGroup);
180   myMeshNbTriangles1->setMinimumWidth(100);
181   myMeshNbTriangles2   = new QLabel(myMeshFacesGroup);
182   myMeshNbTriangles2->setMinimumWidth(100);
183
184   // --> faces --> quadrangles
185   QLabel* myMeshNbQuadranglesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_QUADRANGLES")), myMeshFacesGroup);
186   myMeshNbQuadrangles    = new QLabel(myMeshFacesGroup);
187   myMeshNbQuadrangles->setMinimumWidth(100);
188   myMeshNbQuadrangles1   = new QLabel(myMeshFacesGroup);
189   myMeshNbQuadrangles1->setMinimumWidth(100);
190   myMeshNbQuadrangles2   = new QLabel(myMeshFacesGroup);
191   myMeshNbQuadrangles2->setMinimumWidth(100);
192
193   // --> faces --> polygons
194   QLabel* myMeshNbPolygonesLab = new QLabel( COLONIZE( tr( "SMESH_MESHINFO_POLYGONES" ) ), myMeshFacesGroup );
195   myMeshNbPolygones      = new QLabel( myMeshFacesGroup );
196   myMeshNbPolygones->setMinimumWidth( 100 );
197
198   myMeshFacesGroupLayout->addWidget(myMeshNbFacesLab,       0, 0);
199   myMeshFacesGroupLayout->addWidget(myMeshNbFaces,          0, 1);
200   myMeshFacesGroupLayout->addWidget(myMeshNbFaces1,         0, 2);
201   myMeshFacesGroupLayout->addWidget(myMeshNbFaces2,         0, 3);
202   myMeshFacesGroupLayout->addWidget(myMeshNbTrianglesLab,   1, 0);
203   myMeshFacesGroupLayout->addWidget(myMeshNbTriangles,      1, 1);
204   myMeshFacesGroupLayout->addWidget(myMeshNbTriangles1,     1, 2);
205   myMeshFacesGroupLayout->addWidget(myMeshNbTriangles2,     1, 3);
206   myMeshFacesGroupLayout->addWidget(myMeshNbQuadranglesLab, 2, 0);
207   myMeshFacesGroupLayout->addWidget(myMeshNbQuadrangles,    2, 1);
208   myMeshFacesGroupLayout->addWidget(myMeshNbQuadrangles1,   2, 2);
209   myMeshFacesGroupLayout->addWidget(myMeshNbQuadrangles2,   2, 3);
210   myMeshFacesGroupLayout->addWidget(myMeshNbPolygonesLab,   3, 0);
211   myMeshFacesGroupLayout->addWidget(myMeshNbPolygones,      3, 1);
212   
213   // --> volumes
214   myMeshVolumesGroup = new QGroupBox(tr("SMESH_MESHINFO_VOLUMES"), myMeshWidget);
215   QGridLayout* myMeshVolumesGroupLayout = new QGridLayout(myMeshVolumesGroup);
216   myMeshVolumesGroupLayout->setSpacing(SPACING);  myMeshVolumesGroupLayout->setMargin(MARGIN);
217
218   // --> volumes --> total
219   QLabel* myMeshNbVolumesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_TOTAL")), myMeshVolumesGroup);
220   myMeshNbVolumesLab->setFont(fnt);
221   myMeshNbVolumes    = new QLabel(myMeshVolumesGroup);
222   myMeshNbVolumes->setMinimumWidth(100);
223   myMeshNbVolumes->setFont(fnt);
224   myMeshNbVolumes1   = new QLabel(myMeshVolumesGroup);
225   myMeshNbVolumes1->setMinimumWidth(100);
226   myMeshNbVolumes1->setFont(fnt);
227   myMeshNbVolumes2   = new QLabel(myMeshVolumesGroup);
228   myMeshNbVolumes2->setMinimumWidth(100);
229   myMeshNbVolumes2->setFont(fnt);
230
231   // --> volumes --> tetrahedrons
232   QLabel* myMeshNbTetraLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_TETRAS")), myMeshVolumesGroup);
233   myMeshNbTetra    = new QLabel(myMeshVolumesGroup);
234   myMeshNbTetra->setMinimumWidth(100);
235   myMeshNbTetra1   = new QLabel(myMeshVolumesGroup);
236   myMeshNbTetra1->setMinimumWidth(100);
237   myMeshNbTetra2   = new QLabel(myMeshVolumesGroup);
238   myMeshNbTetra2->setMinimumWidth(100);
239
240   // --> volumes --> hexahedrons
241   QLabel* myMeshNbHexaLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_HEXAS")), myMeshVolumesGroup);
242   myMeshNbHexa    = new QLabel(myMeshVolumesGroup);
243   myMeshNbHexa->setMinimumWidth(100);
244   myMeshNbHexa1   = new QLabel(myMeshVolumesGroup);
245   myMeshNbHexa1->setMinimumWidth(100);
246   myMeshNbHexa2   = new QLabel(myMeshVolumesGroup);
247   myMeshNbHexa2->setMinimumWidth(100);
248
249   // --> volumes --> prisms
250   QLabel* myMeshNbPrismLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_PRISMS")), myMeshVolumesGroup);
251   myMeshNbPrism    = new QLabel(myMeshVolumesGroup);
252   myMeshNbPrism->setMinimumWidth(100);
253   myMeshNbPrism1   = new QLabel(myMeshVolumesGroup);
254   myMeshNbPrism1->setMinimumWidth(100);
255   myMeshNbPrism2   = new QLabel(myMeshVolumesGroup);
256   myMeshNbPrism2->setMinimumWidth(100);
257
258   // --> volumes --> pyramids
259   QLabel* myMeshNbPyraLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_PYRAS")), myMeshVolumesGroup);
260   myMeshNbPyra    = new QLabel(myMeshVolumesGroup);
261   myMeshNbPyra->setMinimumWidth(100);
262   myMeshNbPyra1   = new QLabel(myMeshVolumesGroup);
263   myMeshNbPyra1->setMinimumWidth(100);
264   myMeshNbPyra2   = new QLabel(myMeshVolumesGroup);
265   myMeshNbPyra2->setMinimumWidth(100);
266
267   // --> volumes --> polyherones
268   QLabel* myMeshNbPolyhedronesLab = new QLabel( COLONIZE( tr( "SMESH_MESHINFO_POLYEDRES" ) ), myMeshVolumesGroup );
269   myMeshNbPolyhedrones = new QLabel( myMeshVolumesGroup );
270   myMeshNbPolyhedrones->setMinimumWidth( 100 );
271
272   myMeshVolumesGroupLayout->addWidget(myMeshNbVolumesLab,      0, 0);
273   myMeshVolumesGroupLayout->addWidget(myMeshNbVolumes,         0, 1);
274   myMeshVolumesGroupLayout->addWidget(myMeshNbVolumes1,        0, 2);
275   myMeshVolumesGroupLayout->addWidget(myMeshNbVolumes2,        0, 3);
276   myMeshVolumesGroupLayout->addWidget(myMeshNbTetraLab,        1, 0);
277   myMeshVolumesGroupLayout->addWidget(myMeshNbTetra,           1, 1);
278   myMeshVolumesGroupLayout->addWidget(myMeshNbTetra1,          1, 2);
279   myMeshVolumesGroupLayout->addWidget(myMeshNbTetra2,          1, 3);
280   myMeshVolumesGroupLayout->addWidget(myMeshNbHexaLab,         2, 0);
281   myMeshVolumesGroupLayout->addWidget(myMeshNbHexa,            2, 1);
282   myMeshVolumesGroupLayout->addWidget(myMeshNbHexa1,           2, 2);
283   myMeshVolumesGroupLayout->addWidget(myMeshNbHexa2,           2, 3);
284   myMeshVolumesGroupLayout->addWidget(myMeshNbPrismLab,        3, 0);
285   myMeshVolumesGroupLayout->addWidget(myMeshNbPrism,           3, 1);
286   myMeshVolumesGroupLayout->addWidget(myMeshNbPrism1,          3, 2);
287   myMeshVolumesGroupLayout->addWidget(myMeshNbPrism2,          3, 3);
288   myMeshVolumesGroupLayout->addWidget(myMeshNbPyraLab,         4, 0);
289   myMeshVolumesGroupLayout->addWidget(myMeshNbPyra,            4, 1);
290   myMeshVolumesGroupLayout->addWidget(myMeshNbPyra1,           4, 2);
291   myMeshVolumesGroupLayout->addWidget(myMeshNbPyra2,           4, 3);
292   myMeshVolumesGroupLayout->addWidget(myMeshNbPolyhedronesLab, 5, 0);
293   myMeshVolumesGroupLayout->addWidget(myMeshNbPolyhedrones,    5, 1);
294
295   aMeshLayout->addWidget(myMeshNameLab,      0, 0);
296   aMeshLayout->addWidget(myMeshName,         0, 1);
297   aMeshLayout->addWidget(line1,              1, 0, 1, 2);
298   aMeshLayout->addWidget(myMeshNbNodesLab,   2, 0);
299   aMeshLayout->addWidget(myMeshNbNodes,      2, 1);
300   aMeshLayout->addWidget(line12,             3, 0, 1, 2);
301   aMeshLayout->addWidget(myMeshNb0DElemsLab, 4, 0);
302   aMeshLayout->addWidget(myMeshNb0DElems,    4, 1);
303   aMeshLayout->addWidget(myMeshOrder0Lab,    5, 1);
304   aMeshLayout->addWidget(myMeshOrder1Lab,    5, 2);
305   aMeshLayout->addWidget(myMeshOrder2Lab,    5, 3);
306   aMeshLayout->addWidget(myMeshNbEdgesLab,   6, 0);
307   aMeshLayout->addWidget(myMeshNbEdges,      6, 1);
308   aMeshLayout->addWidget(myMeshNbEdges1,     6, 2);
309   aMeshLayout->addWidget(myMeshNbEdges2,     6, 3);
310   aMeshLayout->addWidget(myMeshFacesGroup,   7, 0, 1, 4);
311   aMeshLayout->addWidget(myMeshVolumesGroup, 8, 0, 1, 4);
312   aMeshLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Minimum, QSizePolicy::Expanding), 9, 0);
313
314   // submesh
315   mySubMeshWidget = new QWidget(myWGStack);
316   QGridLayout* aSubMeshLayout = new QGridLayout(mySubMeshWidget);
317   aSubMeshLayout->setSpacing(SPACING);  aSubMeshLayout->setMargin(0);
318   myWGStack->addWidget(mySubMeshWidget);
319
320   // --> name
321   QLabel* mySubMeshNameLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_NAME")), mySubMeshWidget);
322   mySubMeshName    = new QLabel(mySubMeshWidget);
323   mySubMeshName->setMinimumWidth(100);
324   QFrame* line2 = new QFrame(mySubMeshWidget);
325   line2->setFrameStyle(QFrame::HLine | QFrame::Sunken);
326
327   // --> nodes
328   QLabel* mySubMeshNbNodesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_NODES")), mySubMeshWidget);
329   mySubMeshNbNodes    = new QLabel(mySubMeshWidget);
330   mySubMeshNbNodes->setMinimumWidth(100);
331
332   // --> elements
333   mySubMeshElementsGroup = new QGroupBox(tr("SMESH_MESHINFO_ELEMENTS"), mySubMeshWidget);
334   QGridLayout* mySubMeshElementsGroupLayout = new QGridLayout(mySubMeshElementsGroup);
335   mySubMeshElementsGroupLayout->setSpacing(SPACING);  mySubMeshElementsGroupLayout->setMargin(MARGIN);
336
337   // --> elements --> total
338   QLabel* mySubMeshNbElementsLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_TOTAL")), mySubMeshElementsGroup);
339   mySubMeshNbElementsLab->setFont(fnt);
340   mySubMeshNbElements    = new QLabel(mySubMeshElementsGroup);
341   mySubMeshNbElements->setMinimumWidth(100);
342   mySubMeshNbElements->setFont(fnt);
343
344   // --> 0D elements
345   QLabel* mySubMeshNb0DElemsLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_0DELEMS")), mySubMeshElementsGroup);
346   mySubMeshNb0DElems = new QLabel(mySubMeshElementsGroup);
347   mySubMeshNb0DElems->setMinimumWidth(100);
348
349   // --> elements --> edges
350   QLabel* mySubMeshNbEdgesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_EDGES")), mySubMeshElementsGroup);
351   mySubMeshNbEdges    = new QLabel(mySubMeshElementsGroup);
352   mySubMeshNbEdges->setMinimumWidth(100);
353
354   // --> elements --> faces
355   QLabel* mySubMeshNbFacesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_FACES")), mySubMeshElementsGroup);
356   mySubMeshNbFaces    = new QLabel(mySubMeshElementsGroup);
357   mySubMeshNbFaces->setMinimumWidth(100);
358
359   // --> elements --> volumes
360   QLabel* mySubMeshNbVolumesLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_VOLUMES")), mySubMeshElementsGroup);
361   mySubMeshNbVolumes    = new QLabel(mySubMeshElementsGroup);
362   mySubMeshNbVolumes->setMinimumWidth(100);
363
364   mySubMeshElementsGroupLayout->addWidget(mySubMeshNbElementsLab, 0, 0);
365   mySubMeshElementsGroupLayout->addWidget(mySubMeshNbElements,    0, 1);
366   mySubMeshElementsGroupLayout->addWidget(mySubMeshNb0DElemsLab,  1, 0);
367   mySubMeshElementsGroupLayout->addWidget(mySubMeshNb0DElems,     1, 1);
368   mySubMeshElementsGroupLayout->addWidget(mySubMeshNbEdgesLab,    2, 0);
369   mySubMeshElementsGroupLayout->addWidget(mySubMeshNbEdges,       2, 1);
370   mySubMeshElementsGroupLayout->addWidget(mySubMeshNbFacesLab,    3, 0);
371   mySubMeshElementsGroupLayout->addWidget(mySubMeshNbFaces,       3, 1);
372   mySubMeshElementsGroupLayout->addWidget(mySubMeshNbVolumesLab,  4, 0);
373   mySubMeshElementsGroupLayout->addWidget(mySubMeshNbVolumes,     4, 1);
374
375   aSubMeshLayout->addWidget(mySubMeshNameLab,       0, 0);
376   aSubMeshLayout->addWidget(mySubMeshName,          0, 1);
377   aSubMeshLayout->addWidget(line2,                  1, 0, 1, 2);
378   aSubMeshLayout->addWidget(mySubMeshNbNodesLab,    2, 0);
379   aSubMeshLayout->addWidget(mySubMeshNbNodes,       2, 1);
380   aSubMeshLayout->addWidget(mySubMeshElementsGroup, 3, 0, 1, 2);
381   aSubMeshLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Minimum, QSizePolicy::Expanding), 4, 0);
382
383   // group
384   myGroupWidget = new QWidget(myWGStack);
385   QGridLayout* myGroupWidgetLayout = new QGridLayout(myGroupWidget);
386   myGroupWidgetLayout->setSpacing(SPACING);  myGroupWidgetLayout->setMargin(0);
387   myWGStack->addWidget(myGroupWidget);
388
389   // --> name
390   QLabel* myGroupNameLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_NAME")), myGroupWidget);
391   myGroupName = new QLabel(myGroupWidget);
392   myGroupName->setMinimumWidth(100);
393   QFrame* line3 = new QFrame(myGroupWidget);
394   line3->setFrameStyle(QFrame::HLine | QFrame::Sunken);
395
396   // --> type
397   QLabel* myGroupTypeLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_TYPE")), myGroupWidget);
398   myGroupType = new QLabel(myGroupWidget);
399   myGroupType->setMinimumWidth(100);
400
401   // --> number of entities
402   QLabel* myGroupNbLab = new QLabel(COLONIZE(tr("SMESH_MESHINFO_ENTITIES")), myGroupWidget);
403   myGroupNb = new QLabel(myGroupWidget);
404   myGroupNb->setMinimumWidth(100);
405
406   myGroupWidgetLayout->addWidget(myGroupNameLab, 0, 0);
407   myGroupWidgetLayout->addWidget(myGroupName,    0, 1);
408   myGroupWidgetLayout->addWidget(line3,          1, 0, 1, 2);
409   myGroupWidgetLayout->addWidget(myGroupTypeLab, 2, 0);
410   myGroupWidgetLayout->addWidget(myGroupType,    2, 1);
411   myGroupWidgetLayout->addWidget(myGroupNbLab,   3, 0);
412   myGroupWidgetLayout->addWidget(myGroupNb,      3, 1);
413   myGroupWidgetLayout->addItem(new QSpacerItem(0, 0, QSizePolicy::Minimum, QSizePolicy::Expanding), 4, 0);
414
415   // buttons
416   myButtonsGroup = new QGroupBox(this);
417   QHBoxLayout* myButtonsGroupLayout = new QHBoxLayout(myButtonsGroup);
418   myButtonsGroupLayout->setSpacing(SPACING); myButtonsGroupLayout->setMargin(MARGIN);
419
420   // buttons --> OK and Help buttons
421   myOkBtn = new QPushButton(tr("SMESH_BUT_OK" ), myButtonsGroup);
422   myOkBtn->setAutoDefault(true); myOkBtn->setDefault(true);
423   myHelpBtn = new QPushButton(tr("SMESH_BUT_HELP" ), myButtonsGroup);
424   myHelpBtn->setAutoDefault(true);
425
426   myButtonsGroupLayout->addWidget(myOkBtn);
427   myButtonsGroupLayout->addSpacing(10);
428   myButtonsGroupLayout->addStretch();
429   myButtonsGroupLayout->addWidget(myHelpBtn);
430
431   aTopLayout->addLayout(aSelectLayout);
432   aTopLayout->addWidget(myWGStack);
433   aTopLayout->addWidget(myButtonsGroup);
434
435   mySMESHGUI->SetActiveDialogBox(this);
436
437   // connect signals
438   connect(myOkBtn,                 SIGNAL(clicked()),                      this, SLOT(close()));
439   connect( myHelpBtn,              SIGNAL(clicked()),                      this, SLOT(onHelp()));
440   connect(mySelectBtn,             SIGNAL(clicked()),                      this, SLOT(onStartSelection()));
441   connect(mySMESHGUI, SIGNAL(SignalCloseAllDialogs()),        this, SLOT(close()));
442   connect(mySMESHGUI, SIGNAL(SignalDeactivateActiveDialog()), this, SLOT(DeactivateActiveDialog()));
443   connect(mySelectionMgr,          SIGNAL(currentSelectionChanged()),      this, SLOT(onSelectionChanged()));
444
445   // init dialog with current selection
446   onSelectionChanged();
447
448   myHelpFileName = "mesh_infos_page.html#advanced_mesh_infos_anchor";
449 }
450
451 //=================================================================================
452 // function : ~SMESHGUI_MeshInfosDlg()
453 // purpose  : Destructor
454 //=================================================================================
455 SMESHGUI_MeshInfosDlg::~SMESHGUI_MeshInfosDlg()
456 {
457 }
458
459 //=================================================================================
460 // function : DumpMeshInfos()
461 // purpose  : 
462 //=================================================================================
463 void SMESHGUI_MeshInfosDlg::DumpMeshInfos()
464 {
465   SUIT_OverrideCursor wc;
466
467   SALOME_ListIO aList;
468   mySelectionMgr->selectedObjects(aList);
469
470   int nbSel = aList.Extent();
471   if (nbSel == 1) {
472     myStartSelection = false;
473     mySelectLab->setText("");
474     Handle(SALOME_InteractiveObject) IObject = aList.First();
475     _PTR(SObject) aSO = SMESH::GetActiveStudyDocument()->FindObjectID(IObject->getEntry());
476     if (aSO) {
477       //CORBA::Object_var anObject = aSO->GetObject();
478       CORBA::Object_var anObject = SMESH::SObjectToObject(aSO);
479       if (!CORBA::is_nil(anObject)) {
480         SMESH::SMESH_Mesh_var aMesh = SMESH::SMESH_Mesh::_narrow(anObject);
481         if (!aMesh->_is_nil()) {
482           myWGStack->setCurrentWidget(myMeshWidget);
483           setWindowTitle(tr("SMESH_MESHINFO_TITLE") + " [" + tr("SMESH_OBJECT_MESH") + "]");
484           myMeshName->setText(aSO->GetName().c_str());
485           myMeshNbNodes->setNum((int)aMesh->NbNodes());
486           myMeshNb0DElems->setNum((int)aMesh->Nb0DElements());
487           myMeshNbEdges->setNum((int)aMesh->NbEdges());
488           myMeshNbEdges1->setNum((int)aMesh->NbEdgesOfOrder(SMESH::ORDER_LINEAR));
489           myMeshNbEdges2->setNum((int)aMesh->NbEdgesOfOrder(SMESH::ORDER_QUADRATIC));
490           myMeshNbFaces->setNum((int)aMesh->NbFaces());
491           myMeshNbFaces1->setNum((int)aMesh->NbFacesOfOrder(SMESH::ORDER_LINEAR));
492           myMeshNbFaces2->setNum((int)aMesh->NbFacesOfOrder(SMESH::ORDER_QUADRATIC));
493           myMeshNbTriangles->setNum((int)aMesh->NbTriangles());
494           myMeshNbTriangles1->setNum((int)aMesh->NbTrianglesOfOrder(SMESH::ORDER_LINEAR));
495           myMeshNbTriangles2->setNum((int)aMesh->NbTrianglesOfOrder(SMESH::ORDER_QUADRATIC));
496           myMeshNbQuadrangles->setNum((int)aMesh->NbQuadrangles());
497           myMeshNbQuadrangles1->setNum((int)aMesh->NbQuadranglesOfOrder(SMESH::ORDER_LINEAR));
498           myMeshNbQuadrangles2->setNum((int)aMesh->NbQuadranglesOfOrder(SMESH::ORDER_QUADRATIC));
499           myMeshNbPolygones->setNum( (int)aMesh->NbPolygons() );
500           myMeshNbVolumes->setNum((int)aMesh->NbVolumes());
501           myMeshNbVolumes1->setNum((int)aMesh->NbVolumesOfOrder(SMESH::ORDER_LINEAR));
502           myMeshNbVolumes2->setNum((int)aMesh->NbVolumesOfOrder(SMESH::ORDER_QUADRATIC));
503           myMeshNbTetra->setNum((int)aMesh->NbTetras());
504           myMeshNbTetra1->setNum((int)aMesh->NbTetrasOfOrder(SMESH::ORDER_LINEAR));
505           myMeshNbTetra2->setNum((int)aMesh->NbTetrasOfOrder(SMESH::ORDER_QUADRATIC));
506           myMeshNbHexa->setNum((int)aMesh->NbHexas());
507           myMeshNbHexa1->setNum((int)aMesh->NbHexasOfOrder(SMESH::ORDER_LINEAR));
508           myMeshNbHexa2->setNum((int)aMesh->NbHexasOfOrder(SMESH::ORDER_QUADRATIC));
509           myMeshNbPrism->setNum((int)aMesh->NbPrisms());
510           myMeshNbPrism1->setNum((int)aMesh->NbPrismsOfOrder(SMESH::ORDER_LINEAR));
511           myMeshNbPrism2->setNum((int)aMesh->NbPrismsOfOrder(SMESH::ORDER_QUADRATIC));
512           myMeshNbPyra->setNum((int)aMesh->NbPyramids());
513           myMeshNbPyra1->setNum((int)aMesh->NbPyramidsOfOrder(SMESH::ORDER_LINEAR));
514           myMeshNbPyra2->setNum((int)aMesh->NbPyramidsOfOrder(SMESH::ORDER_QUADRATIC));
515           myMeshNbPolyhedrones->setNum( (int)aMesh->NbPolyhedrons() );
516           return;
517         }
518         SMESH::SMESH_subMesh_var aSubMesh = SMESH::SMESH_subMesh::_narrow(anObject);
519         if (!aSubMesh->_is_nil()) {
520           myWGStack->setCurrentWidget(mySubMeshWidget);
521           setWindowTitle(tr("SMESH_MESHINFO_TITLE") + " [" + tr("SMESH_SUBMESH") + "]");
522           mySubMeshName->setText(aSO->GetName().c_str());
523           mySubMeshNbNodes->setNum((int)aSubMesh->GetNumberOfNodes(true));
524           mySubMeshNbElements->setNum((int)aSubMesh->GetNumberOfElements());
525           mySubMeshNb0DElems->setNum((int)(aSubMesh->GetElementsByType(SMESH::ELEM0D)->length()));
526           mySubMeshNbEdges->setNum((int)(aSubMesh->GetElementsByType(SMESH::EDGE)->length()));
527           mySubMeshNbFaces->setNum((int)(aSubMesh->GetElementsByType(SMESH::FACE)->length()));
528           mySubMeshNbVolumes->setNum((int)(aSubMesh->GetElementsByType(SMESH::VOLUME)->length()));
529           return;
530         }
531         SMESH::SMESH_GroupBase_var aGroup = SMESH::SMESH_GroupBase::_narrow(anObject);
532         if (!aGroup->_is_nil()) {
533           myWGStack->setCurrentWidget(myGroupWidget);
534           setWindowTitle(tr("SMESH_MESHINFO_TITLE") + " [" + tr("SMESH_GROUP") + "]");
535           myGroupName->setText(aSO->GetName().c_str());
536           int aType = aGroup->GetType();
537           QString strType;
538           switch (aType) {
539           case SMESH::NODE:
540             strType = "SMESH_MESHINFO_NODES"; break;
541           case SMESH::ELEM0D:
542             strType = "SMESH_MESHINFO_0DELEMS"; break;
543           case SMESH::EDGE:
544             strType = "SMESH_MESHINFO_EDGES"; break;
545           case SMESH::FACE:
546             strType = "SMESH_MESHINFO_FACES"; break;
547           case SMESH::VOLUME:
548             strType = "SMESH_MESHINFO_VOLUMES"; break;
549           default:
550             strType = "SMESH_MESHINFO_ALL_TYPES"; break;
551           }
552
553           myGroupType->setText(tr(strType.toLatin1().data()));
554           myGroupNb->setNum((int)aGroup->Size());
555           return;
556         }
557       }
558     }
559   }
560   myWGStack->setCurrentIndex(0);
561   setWindowTitle(tr("SMESH_MESHINFO_TITLE"));
562 }
563
564 //=================================================================================
565 // function : SelectionIntoArgument()
566 // purpose  : Called when selection has changed
567 //=================================================================================
568 void SMESHGUI_MeshInfosDlg::onSelectionChanged()
569 {
570   if (myStartSelection)
571     DumpMeshInfos();
572 }
573
574 //=================================================================================
575 // function : closeEvent()
576 // purpose  :
577 //=================================================================================
578 void SMESHGUI_MeshInfosDlg::closeEvent(QCloseEvent* e)
579 {
580   mySMESHGUI->ResetState();
581   QDialog::closeEvent(e);
582 }
583
584 //=================================================================================
585 // function : windowActivationChange()
586 // purpose  : called when window is activated/deactivated
587 //=================================================================================
588 void SMESHGUI_MeshInfosDlg::windowActivationChange(bool oldActive)
589 {
590   QDialog::windowActivationChange(oldActive);
591   if (isActiveWindow() && myIsActiveWindow != isActiveWindow())
592     ActivateThisDialog();
593   myIsActiveWindow = isActiveWindow();
594 }
595
596 //=================================================================================
597 // function : DeactivateActiveDialog()
598 // purpose  :
599 //=================================================================================
600 void SMESHGUI_MeshInfosDlg::DeactivateActiveDialog()
601 {
602   disconnect(mySelectionMgr, 0, this, 0);
603 }
604
605 //=================================================================================
606 // function : ActivateThisDialog()
607 // purpose  :
608 //=================================================================================
609 void SMESHGUI_MeshInfosDlg::ActivateThisDialog()
610 {
611   /* Emit a signal to deactivate any active dialog */
612   mySMESHGUI->EmitSignalDeactivateDialog();
613   connect(mySelectionMgr, SIGNAL(currentSelectionChanged()), this, SLOT(onSelectionChanged()));
614 }
615
616 //=================================================================================
617 // function : onStartSelection()
618 // purpose  : starts selection
619 //=================================================================================
620 void SMESHGUI_MeshInfosDlg::onStartSelection()
621 {
622   myStartSelection = true;
623   onSelectionChanged();
624   myStartSelection = true;
625   mySelectLab->setText(tr("INF_SELECT_OBJECT"));
626 }
627
628 //=================================================================================
629 // function : onHelp()
630 // purpose  :
631 //=================================================================================
632 void SMESHGUI_MeshInfosDlg::onHelp()
633 {
634   LightApp_Application* app = (LightApp_Application*)(SUIT_Session::session()->activeApplication());
635   if (app) 
636     app->onHelpContextModule(mySMESHGUI ? app->moduleName(mySMESHGUI->moduleName()) : QString(""), myHelpFileName);
637   else {
638     QString platform;
639 #ifdef WIN32
640     platform = "winapplication";
641 #else
642     platform = "application";
643 #endif
644     SUIT_MessageBox::warning(this, tr("WRN_WARNING"),
645                              tr("EXTERNAL_BROWSER_CANNOT_SHOW_PAGE").
646                              arg(app->resourceMgr()->stringValue("ExternalBrowser", 
647                                                                  platform)).
648                              arg(myHelpFileName));
649   }
650 }
651
652 //=================================================================================
653 // function : keyPressEvent()
654 // purpose  :
655 //=================================================================================
656 void SMESHGUI_MeshInfosDlg::keyPressEvent( QKeyEvent* e )
657 {
658   QDialog::keyPressEvent( e );
659   if ( e->isAccepted() )
660     return;
661
662   if ( e->key() == Qt::Key_F1 ) {
663     e->accept();
664     onHelp();
665   }
666 }