1 // Copyright (C) 2007-2016 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
22 // File : RepairGUI.cxx
23 // Author : Damien COQUERET, Open CASCADE S.A.S.
25 #include "RepairGUI.h"
27 #include <GeometryGUI.h>
28 #include "GeometryGUI_Operations.h"
30 #include <SUIT_Desktop.h>
31 #include <SUIT_Session.h>
32 #include <SUIT_OverrideCursor.h>
33 #include <SalomeApp_Application.h>
35 #include "RepairGUI_SewingDlg.h" // Method SEWING
36 #include "RepairGUI_SuppressFacesDlg.h" // Method SUPPRESS FACES
37 #include "RepairGUI_RemoveHolesDlg.h" // Method SUPPRESS HOLE
38 #include "RepairGUI_ShapeProcessDlg.h" // Method PROCESS SHAPE
39 #include "RepairGUI_CloseContourDlg.h" // Method CLOSE CONTOUR
40 #include "RepairGUI_RemoveIntWiresDlg.h"// Method REMOVE INTERNAL WIRES
41 #include "RepairGUI_DivideEdgeDlg.h" // Method DEVIDE EDGE
42 #include "RepairGUI_FreeBoundDlg.h" // Method FREE BOUNDARIES
43 #include "RepairGUI_FreeFacesDlg.h" // Method FREE FACES
44 #include "RepairGUI_GlueDlg.h" // Method GLUE FACES
45 #include "RepairGUI_LimitToleranceDlg.h" // Method LIMIT TOLERANCE
46 #include "RepairGUI_ChangeOrientationDlg.h" // Method CHANGE ORIENTATION
47 #include "RepairGUI_RemoveWebsDlg.h" // Method REMOVE INTERNAL FACES
48 #include "RepairGUI_RemoveExtraEdgesDlg.h" // Method REMOVE EXTRA EDGES
49 #include "RepairGUI_FuseEdgesDlg.h" // Method FUSE COLLINEAR EDGES
50 #include "RepairGUI_UnionFacesDlg.h" // Method UNION FACES
51 #include "RepairGUI_InspectObjectDlg.h" // Method INSPECT OBJECT
53 //=======================================================================
54 // function : RepairGUI()
55 // purpose : Constructor
56 //=======================================================================
57 RepairGUI::RepairGUI( GeometryGUI* parent )
62 //=======================================================================
63 // function : ~RepairGUI()
64 // purpose : Destructor
65 //=======================================================================
66 RepairGUI::~RepairGUI()
71 //=======================================================================
72 // function : OnGUIEvent()
74 //=======================================================================
75 bool RepairGUI::OnGUIEvent( int theCommandID, SUIT_Desktop* parent )
77 SalomeApp_Application* app = getGeometryGUI()->getApp();
78 if ( !app ) return false;
80 getGeometryGUI()->EmitSignalDeactivateDialog();
83 switch (theCommandID) {
84 case GEOMOp::OpSewing: aDlg = new RepairGUI_SewingDlg (getGeometryGUI(), parent); break;
85 case GEOMOp::OpGlueFaces: aDlg = new RepairGUI_GlueDlg (getGeometryGUI(), parent, false, TopAbs_FACE); break;
86 case GEOMOp::OpGlueEdges: aDlg = new RepairGUI_GlueDlg (getGeometryGUI(), parent, false, TopAbs_EDGE); break;
87 case GEOMOp::OpLimitTolerance: aDlg = new RepairGUI_LimitToleranceDlg (getGeometryGUI(), parent); break;
88 case GEOMOp::OpSuppressFaces: aDlg = new RepairGUI_SuppressFacesDlg (getGeometryGUI(), parent); break;
89 case GEOMOp::OpSuppressHoles: aDlg = new RepairGUI_RemoveHolesDlg (getGeometryGUI(), parent); break;
90 case GEOMOp::OpShapeProcess: aDlg = new RepairGUI_ShapeProcessDlg (getGeometryGUI(), parent); break;
91 case GEOMOp::OpCloseContour: aDlg = new RepairGUI_CloseContourDlg (getGeometryGUI(), parent); break;
92 case GEOMOp::OpRemoveIntWires: aDlg = new RepairGUI_RemoveIntWiresDlg (getGeometryGUI(), parent); break;
93 case GEOMOp::OpAddPointOnEdge: aDlg = new RepairGUI_DivideEdgeDlg (getGeometryGUI(), parent); break;
94 case GEOMOp::OpFreeBoundaries: aDlg = new RepairGUI_FreeBoundDlg (getGeometryGUI(), parent); break;
95 case GEOMOp::OpFreeFaces: aDlg = new RepairGUI_FreeFacesDlg (getGeometryGUI(), parent); break;
96 case GEOMOp::OpOrientation: aDlg = new RepairGUI_ChangeOrientationDlg (getGeometryGUI(), parent); break;
97 case GEOMOp::OpRemoveWebs: aDlg = new RepairGUI_RemoveWebsDlg (getGeometryGUI(), parent); break;
98 case GEOMOp::OpRemoveExtraEdges: aDlg = new RepairGUI_RemoveExtraEdgesDlg (getGeometryGUI(), parent); break;
99 case GEOMOp::OpFuseEdges: aDlg = new RepairGUI_FuseEdgesDlg (getGeometryGUI(), parent); break;
100 case GEOMOp::OpUnionFaces: aDlg = new RepairGUI_UnionFacesDlg (getGeometryGUI(), parent); break;
101 case GEOMOp::OpInspectObj: aDlg = new RepairGUI_InspectObjectDlg (getGeometryGUI(), parent); break;
103 app->putInfo(tr("GEOM_PRP_COMMAND").arg(theCommandID));
114 //=====================================================================================
116 //=====================================================================================
120 __declspec( dllexport )
122 GEOMGUI* GetLibGUI( GeometryGUI* parent )
124 return new RepairGUI( parent );
128 //=====================================================================================
130 //=====================================================================================
133 #include <QHBoxLayout>
134 #include <QHeaderView>
135 #include <QPushButton>
137 #include <QStringList>
138 #include <QTableWidget>
139 #include <QTableWidget>
140 #include <QTableWidgetItem>
141 #include <QVBoxLayout>
145 class StatsDlg : public QDialog
148 StatsDlg( GEOM::ModifStatistics_var stats, QWidget* parent );
151 StatsDlg::StatsDlg( GEOM::ModifStatistics_var stats, QWidget* parent ): QDialog( parent )
154 setWindowTitle( tr( "GEOM_HEALING_STATS_TITLE" ) );
155 setMinimumWidth( 500 );
157 const int nbRows = stats->length();
158 const int nbCols = 2;
159 QTableWidget* table = new QTableWidget( nbRows, nbCols, this );
160 table->setEditTriggers( QAbstractItemView::NoEditTriggers );
161 #if QT_VERSION < QT_VERSION_CHECK(5, 0, 0)
162 table->horizontalHeader()->setResizeMode( 1, QHeaderView::Interactive );
164 table->horizontalHeader()->setSectionResizeMode( 1, QHeaderView::Interactive );
166 table->horizontalHeader()->setStretchLastSection( true );
169 headers << tr( "GEOM_HEALING_STATS_COL_1" );
170 headers << tr( "GEOM_HEALING_STATS_COL_2" );
171 table->setHorizontalHeaderLabels( headers );
175 QPushButton* okBtn = new QPushButton( tr( "GEOM_BUT_OK" ), this );
176 okBtn->setAutoDefault( true );
177 okBtn->setDefault( true );
179 // QPushButton* helpBtn = new QPushButton( tr( "GEOM_BUT_HELP" ), this );
180 // helpBtn->setAutoDefault( true );
182 QHBoxLayout* btnLayout = new QHBoxLayout;
183 btnLayout->setMargin( 0 );
184 btnLayout->setSpacing( 6 );
186 btnLayout->addStretch();
187 btnLayout->addWidget( okBtn );
188 btnLayout->addStretch();
189 // btnLayout->addWidget( helpBtn );
191 QVBoxLayout* aLay = new QVBoxLayout( this );
192 aLay->setMargin( 9 );
193 aLay->setSpacing( 6 );
194 aLay->addWidget( table );
195 aLay->addLayout( btnLayout );
198 for ( int row = 0; row < nbRows; ++row )
200 table->setItem( row, 0, new QTableWidgetItem( QString::number( stats[ row ].count )));
201 table->setItem( row, 1, new QTableWidgetItem( tr( stats[ row ].name.in() )));
204 connect( okBtn, SIGNAL( clicked() ), this, SLOT( reject() ));
205 //connect( helpBtn, SIGNAL( clicked() ), this, SLOT( help() ));
209 //================================================================================
211 * \brief Show a dialog providing info on what is done by healing
213 //================================================================================
215 void RepairGUI::ShowStatistics( GEOM::GEOM_IHealingOperations_var anOper, QWidget* parent )
217 GEOM::ModifStatistics_var stats = anOper->GetStatistics();
219 if ( ! &stats.in() || stats->length() == 0 )
222 SUIT_OverrideCursor wc;
225 StatsDlg dlg( stats, parent );