22763: [EDF] Shape processing

For DropSmallSolids operator, fix some bugs:
- Add missing default values of parameters in a resource file
- Add workaround to ShapeProcess functionality to process properly optional parameters (the case for DropSmallSolids operator)
- Small redesign of RepairGUI::ShowStatistics() function
This commit is contained in:
vsr 2014-12-16 14:16:15 +03:00
parent cceb7b5b9e
commit 57bf55dc1f
5 changed files with 59 additions and 33 deletions

View File

@ -18,6 +18,10 @@ ShapeProcess.FixFaceSize.Tolerance : 0.05
ShapeProcess.DropSmallEdges.Tolerance3d : 0.05 ShapeProcess.DropSmallEdges.Tolerance3d : 0.05
ShapeProcess.DropSmallSolids.WidthFactorThreshold : 1
ShapeProcess.DropSmallSolids.VolumeThreshold : 1000
ShapeProcess.DropSmallSolids.MergeSolids : 1
ShapeProcess.BSplineRestriction.SurfaceMode : 1 ShapeProcess.BSplineRestriction.SurfaceMode : 1
ShapeProcess.BSplineRestriction.Curve3dMode : 1 ShapeProcess.BSplineRestriction.Curve3dMode : 1
ShapeProcess.BSplineRestriction.Curve2dMode : 1 ShapeProcess.BSplineRestriction.Curve2dMode : 1
@ -210,6 +214,11 @@ ShapeProcess.SameParameter.Tolerance3d : 1.e-7
! DropSmallEdges : Eliminate small edges by removing or merging with neighbour ! DropSmallEdges : Eliminate small edges by removing or merging with neighbour
! DropSmallEdges.Tolerance3d : Tolerance (3d) ! DropSmallEdges.Tolerance3d : Tolerance (3d)
! DropSmallSolids : Eliminate small solids by a) removing them or b) absorbing them by adjacent larger solids.
! DropSmallSolids.WidthFactorThreshold : Maximum value of 2V/S of a solid where V is volume and S is surface area of the solid.
! DropSmallSolids.VolumeThreshold : Maximum volume of a solid.
! DropSmallSolids.MergeSolids : If false, solids are removed; otherwise, solids are merged to adjacent larger solids.
! FixShape.Tolerance3d : Tolerance (3d) for fixing of shape. ! FixShape.Tolerance3d : Tolerance (3d) for fixing of shape.
! FixShape.MaxTolerance3d : Maximal possible value of increasing of tolerance during fixing. ! FixShape.MaxTolerance3d : Maximal possible value of increasing of tolerance during fixing.
! FixShape.MinTolerance3d : Minimal value of tolerance. ! FixShape.MinTolerance3d : Minimal value of tolerance.

View File

@ -275,6 +275,11 @@ bool GEOMImpl_IHealingOperations::GetParameters (const std::string theOperation,
} else if( theOperation == "DropSmallEdges" ) { } else if( theOperation == "DropSmallEdges" ) {
theParams.push_back( "DropSmallEdges.Tolerance3d" ); theParams.push_back( "DropSmallEdges.Tolerance3d" );
} else if( theOperation == "DropSmallSolids" ) {
theParams.push_back( "DropSmallSolids.WidthFactorThreshold" );
theParams.push_back( "DropSmallSolids.VolumeThreshold" );
theParams.push_back( "DropSmallSolids.MergeSolids" );
} else if( theOperation == "BSplineRestriction" ) { } else if( theOperation == "BSplineRestriction" ) {
theParams.push_back( "BSplineRestriction.SurfaceMode" ); theParams.push_back( "BSplineRestriction.SurfaceMode" );
theParams.push_back( "BSplineRestriction.Curve3dMode" ); theParams.push_back( "BSplineRestriction.Curve3dMode" );

View File

@ -29,6 +29,7 @@
#include <SUIT_Desktop.h> #include <SUIT_Desktop.h>
#include <SUIT_Session.h> #include <SUIT_Session.h>
#include <SUIT_OverrideCursor.h>
#include <SalomeApp_Application.h> #include <SalomeApp_Application.h>
#include "RepairGUI_SewingDlg.h" // Method SEWING #include "RepairGUI_SewingDlg.h" // Method SEWING
@ -147,8 +148,7 @@ namespace
StatsDlg::StatsDlg( GEOM::ModifStatistics_var stats, QWidget* parent ): QDialog( parent ) StatsDlg::StatsDlg( GEOM::ModifStatistics_var stats, QWidget* parent ): QDialog( parent )
{ {
setModal( false ); setModal( true );
setAttribute( Qt::WA_DeleteOnClose, true );
setWindowTitle( tr( "GEOM_HEALING_STATS_TITLE" ) ); setWindowTitle( tr( "GEOM_HEALING_STATS_TITLE" ) );
setMinimumWidth( 500 ); setMinimumWidth( 500 );
@ -174,11 +174,12 @@ namespace
// helpBtn->setAutoDefault( true ); // helpBtn->setAutoDefault( true );
QHBoxLayout* btnLayout = new QHBoxLayout; QHBoxLayout* btnLayout = new QHBoxLayout;
btnLayout->setMargin( 9 ); btnLayout->setMargin( 0 );
btnLayout->setSpacing( 6 ); btnLayout->setSpacing( 6 );
btnLayout->addStretch();
btnLayout->addWidget( okBtn ); btnLayout->addWidget( okBtn );
btnLayout->addStretch( 10 ); btnLayout->addStretch();
// btnLayout->addWidget( helpBtn ); // btnLayout->addWidget( helpBtn );
QVBoxLayout* aLay = new QVBoxLayout( this ); QVBoxLayout* aLay = new QVBoxLayout( this );
@ -196,7 +197,6 @@ namespace
connect( okBtn, SIGNAL( clicked() ), this, SLOT( reject() )); connect( okBtn, SIGNAL( clicked() ), this, SLOT( reject() ));
//connect( helpBtn, SIGNAL( clicked() ), this, SLOT( help() )); //connect( helpBtn, SIGNAL( clicked() ), this, SLOT( help() ));
} }
} }
@ -213,6 +213,9 @@ void RepairGUI::ShowStatistics( GEOM::GEOM_IHealingOperations_var anOper, QWidge
if ( ! &stats.in() || stats->length() == 0 ) if ( ! &stats.in() || stats->length() == 0 )
return; return;
StatsDlg* dlg = new StatsDlg( stats, parent ); SUIT_OverrideCursor wc;
dlg->exec(); wc.suspend();
StatsDlg dlg( stats, parent );
dlg.exec();
} }

View File

@ -162,10 +162,10 @@ void RepairGUI_ShapeProcessDlg::init()
myDropSmallSolidsVolChk = new QCheckBox( tr("VOLUME_TOL"), w ); myDropSmallSolidsVolChk = new QCheckBox( tr("VOLUME_TOL"), w );
myDropSmallSolidsWidTol = new SalomeApp_DoubleSpinBox( w ); myDropSmallSolidsWidTol = new SalomeApp_DoubleSpinBox( w );
myDropSmallSolidsVolTol = new SalomeApp_DoubleSpinBox( w ); myDropSmallSolidsVolTol = new SalomeApp_DoubleSpinBox( w );
initSpinBox( myDropSmallSolidsWidTol, 0., 100., 1e-7, "len_tol_precision" ); initSpinBox( myDropSmallSolidsWidTol, 0., 1e3, 1., "len_tol_precision" );
initSpinBox( myDropSmallSolidsVolTol, 0., 100., 1e-7, "len_tol_precision" ); initSpinBox( myDropSmallSolidsVolTol, 0., 1e9, 1., "len_tol_precision" );
myDropSmallSolidsWidTol->setValue( 1e-7 ); myDropSmallSolidsWidTol->setValue( 1 );
myDropSmallSolidsVolTol->setValue( 1e-7 ); myDropSmallSolidsVolTol->setValue( 1e3 );
myDropSmallSolidsVolChk->setChecked( true ); myDropSmallSolidsVolChk->setChecked( true );
myDropSmallSolidsWidTol->setEnabled( false ); myDropSmallSolidsWidTol->setEnabled( false );
myDropSmallSolidsMergeChk = new QCheckBox( tr("TO_MERGE_SOLIDS"), w ); myDropSmallSolidsMergeChk = new QCheckBox( tr("TO_MERGE_SOLIDS"), w );
@ -563,15 +563,24 @@ void RepairGUI_ShapeProcessDlg::setValue( QWidget* theControl, const QString& th
QString RepairGUI_ShapeProcessDlg::getValue( QWidget* theControl ) const QString RepairGUI_ShapeProcessDlg::getValue( QWidget* theControl ) const
{ {
if ( theControl ) { if ( theControl ) {
if ( qobject_cast<SalomeApp_DoubleSpinBox*>( theControl )) if ( qobject_cast<SalomeApp_DoubleSpinBox*>( theControl )) {
if ( ( theControl == myDropSmallSolidsWidTol || theControl == myDropSmallSolidsVolTol ) && !theControl->isEnabled() ) {
// VSR: stupid workaround about ShapeProcessAPI:
// specific processing for optional parameters of DropSmallSolids operator
return QString::number( Precision::Infinite() );
}
return QString::number( qobject_cast<SalomeApp_DoubleSpinBox*>( theControl )->value() ); return QString::number( qobject_cast<SalomeApp_DoubleSpinBox*>( theControl )->value() );
else if ( qobject_cast<SalomeApp_IntSpinBox*>( theControl )) }
else if ( qobject_cast<SalomeApp_IntSpinBox*>( theControl )) {
return QString::number( qobject_cast<SalomeApp_IntSpinBox*>( theControl )->value() ); return QString::number( qobject_cast<SalomeApp_IntSpinBox*>( theControl )->value() );
else if ( qobject_cast<QComboBox*>( theControl )) }
else if ( qobject_cast<QComboBox*>( theControl )) {
return qobject_cast<QComboBox*>( theControl )->currentText(); return qobject_cast<QComboBox*>( theControl )->currentText();
else if ( qobject_cast<QCheckBox*>( theControl )) }
else if ( qobject_cast<QCheckBox*>( theControl )) {
return qobject_cast<QCheckBox*>( theControl )->isChecked() ? "1" : "0"; return qobject_cast<QCheckBox*>( theControl )->isChecked() ? "1" : "0";
} }
}
return 0; return 0;
} }
@ -705,17 +714,14 @@ bool RepairGUI_ShapeProcessDlg::execute( ObjectList& objects )
GEOM::string_array* RepairGUI_ShapeProcessDlg::getActiveOperators() GEOM::string_array* RepairGUI_ShapeProcessDlg::getActiveOperators()
{ {
GEOM::string_array_var anOperators = new GEOM::string_array(); GEOM::string_array_var anOperators = new GEOM::string_array();
QStringList aCheckedList;
for ( int i = 0; i < myOpList->count(); i++ ) { int j = 0, n = myOpList->count();
anOperators->length( n );
for ( int i = 0; i < n; i++ ) {
if ( myOpList->item( i )->checkState() == Qt::Checked ) if ( myOpList->item( i )->checkState() == Qt::Checked )
aCheckedList << myOpList->item( i )->text(); anOperators[j++] = myOpList->item( i )->text().toLatin1().constData();
} }
anOperators->length( j );
anOperators->length( aCheckedList.count() );
for ( int i = 0; i < aCheckedList.count(); i++ )
anOperators[i] = aCheckedList[i].toLatin1().constData();
return anOperators._retn(); return anOperators._retn();
} }
@ -732,7 +738,7 @@ QWidget* RepairGUI_ShapeProcessDlg::getControl( const QString& theParam )
else if ( theParam == "FixFaceSize.Tolerance" ) return myFixFaceSizeTol; else if ( theParam == "FixFaceSize.Tolerance" ) return myFixFaceSizeTol;
else if ( theParam == "DropSmallEdges.Tolerance3d" ) return myDropSmallEdgesTol3D; else if ( theParam == "DropSmallEdges.Tolerance3d" ) return myDropSmallEdgesTol3D;
else if ( theParam == "DropSmallSolids.WidthFactorThreshold" ) return myDropSmallSolidsWidTol; else if ( theParam == "DropSmallSolids.WidthFactorThreshold" ) return myDropSmallSolidsWidTol;
else if ( theParam == "DropSmallSolids.VolumeThreshold" ) return myDropSmallSolidsWidTol; else if ( theParam == "DropSmallSolids.VolumeThreshold" ) return myDropSmallSolidsVolTol;
else if ( theParam == "DropSmallSolids.MergeSolids" ) return myDropSmallSolidsMergeChk; else if ( theParam == "DropSmallSolids.MergeSolids" ) return myDropSmallSolidsMergeChk;
else if ( theParam == "BSplineRestriction.SurfaceMode" ) return myBSplineSurfModeChk; else if ( theParam == "BSplineRestriction.SurfaceMode" ) return myBSplineSurfModeChk;
else if ( theParam == "BSplineRestriction.Curve3dMode" ) return myBSpline3DCurveChk; else if ( theParam == "BSplineRestriction.Curve3dMode" ) return myBSpline3DCurveChk;
@ -824,17 +830,20 @@ GEOM::string_array* RepairGUI_ShapeProcessDlg::getParameters( const GEOM::string
// calculate the length of parameters // calculate the length of parameters
for ( i = 0, j = 0; i < theOperators.length(); i++ ) for ( i = 0, j = 0; i < theOperators.length(); i++ )
j += myValMap[ QString( theOperators[i] ) ].size(); j += myValMap[ QString( theOperators[i].in() ) ].size();
// set the new length of paremeters // set the new length of paremeters
aParams->length( j ); aParams->length( j );
// fill the parameters // fill the parameters
for ( i = 0, j = 0; i < theOperators.length(); i++ ) { for ( i = 0, j = 0; i < theOperators.length(); i++ ) {
QStringList aValLst = myValMap[ QString( theOperators[i] ) ]; QStringList aParamLst = myValMap[ QString( theOperators[i].in() ) ];
for ( QStringList::Iterator it = aValLst.begin(); it != aValLst.end(); ++it ) foreach ( QString aParam, aParamLst ) {
aParams[j++] = CORBA::string_dup( (*it).toLatin1().constData() ); aParams[j++] = CORBA::string_dup( aParam.toLatin1().constData() );
} }
}
aParams->length( j );
return aParams._retn(); return aParams._retn();
} }
@ -851,7 +860,7 @@ GEOM::string_array* RepairGUI_ShapeProcessDlg::getValues( const GEOM::string_arr
for ( int i = 0; i < theParams.length(); i++ ) { for ( int i = 0; i < theParams.length(); i++ ) {
QWidget* aCtrl = getControl( (const char*)theParams[i] ); QWidget* aCtrl = getControl( (const char*)theParams[i] );
if ( aCtrl && aCtrl->isEnabled() ) if ( aCtrl )
aValues[i] = get_convert( (const char*)theParams[i], getValue( aCtrl )); aValues[i] = get_convert( (const char*)theParams[i], getValue( aCtrl ));
} }

View File

@ -163,12 +163,12 @@ void ShHealOper_ShapeProcess::SetParameter(const TCollection_AsciiString& theNam
TCollection_AsciiString anameParam(myPrefix); TCollection_AsciiString anameParam(myPrefix);
anameParam += "."; anameParam += ".";
anameParam+= theNameParam; anameParam+= theNameParam;
if(theVal.IsIntegerValue()) if(theVal.IsRealValue())
myOperations.Context()->ResourceManager()->
SetResource(anameParam.ToCString(),theVal.IntegerValue());
else if(theVal.IsRealValue())
myOperations.Context()->ResourceManager()-> myOperations.Context()->ResourceManager()->
SetResource(anameParam.ToCString(),theVal.RealValue()); SetResource(anameParam.ToCString(),theVal.RealValue());
else if(theVal.IsIntegerValue())
myOperations.Context()->ResourceManager()->
SetResource(anameParam.ToCString(),theVal.IntegerValue());
else else
myOperations.Context()->ResourceManager()-> myOperations.Context()->ResourceManager()->
SetResource(anameParam.ToCString(),theVal.ToCString()); SetResource(anameParam.ToCString(),theVal.ToCString());