IMP 22635: EDF 8345 - Creation of group based on groups

Bug: MAJORITY mode works wrong with triangles

IMP 22877: EDF 10054 SMESH: Add a new filter "BelongToSmeshGroup" for Create Groupe
    Bug: Invalid Python dump
This commit is contained in:
eap 2015-04-14 17:18:18 +03:00
parent 5ac2bd91a8
commit d547f440f8
5 changed files with 15 additions and 10 deletions

View File

@ -3718,7 +3718,7 @@ void SMESHGUI_FilterDlg::onSelectionDone()
}
break;
}
case SMESH::FT_BelongToMeshGroup: // get a group name and IOR
case SMESH::FT_BelongToMeshGroup: // get a group Name and Entry
{
SMESH::SMESH_GroupBase_var grp = SMESH::IObjectToInterface<SMESH::SMESH_GroupBase>(anIO);
if ( !grp->_is_nil() )
@ -3732,13 +3732,8 @@ void SMESHGUI_FilterDlg::onSelectionDone()
if ( !myGroup->_is_nil() && myGroup->IsInDependency( grp ))
return; // avoid cyclic dependencies between Groups on Filter
SalomeApp_Application* app = dynamic_cast<SalomeApp_Application*>
( SUIT_Session::session()->activeApplication() );
if( !app ) return;
CORBA::String_var IOR = app->orb()->object_to_string( grp );
myTable->SetThreshold(aRow, SMESH::toQStr( grp->GetName() ));
myTable->SetID (aRow, IOR.in() );
myTable->SetID (aRow, anIO->getEntry() );
}
}
default: // get a GEOM object
@ -3747,7 +3742,7 @@ void SMESHGUI_FilterDlg::onSelectionDone()
if (!anObj->_is_nil())
{
myTable->SetThreshold(aRow, GEOMBase::GetName(anObj));
myTable->SetID(aRow, anIO->getEntry());
myTable->SetID (aRow, anIO->getEntry());
}
}
}

View File

@ -306,6 +306,8 @@ namespace {
// - FT_EntityType = 36
// v 7.3.0: FT_Undefined == 46, new items:
// - FT_ConnectedElements = 39
// v 7.6.0: FT_Undefined == 47, new items:
// - FT_BelongToMeshGroup = 22
//
// It's necessary to continue recording this history and to fill
// undef2newItems (see below) accordingly.
@ -326,6 +328,7 @@ namespace {
undef2newItems[ 44 ].push_back( 37 );
undef2newItems[ 45 ].push_back( 36 );
undef2newItems[ 46 ].push_back( 39 );
undef2newItems[ 47 ].push_back( 22 );
ASSERT( undef2newItems.rbegin()->first == SMESH::FT_Undefined );
}

View File

@ -764,7 +764,7 @@ void BelongToMeshGroup_i::SetGroupID( const char* theID ) // IOR or StoreName
CORBA::Object_var obj = SMESH_Gen_i::GetORB()->string_to_object( myID.c_str() );
SetGroup( SMESH::SMESH_GroupBase::_narrow( obj ));
}
else if ( strncmp( ":0", myID.c_str(), 2 ) == 0 ) // transient mode + GUI
else if ( strncmp( "0:", myID.c_str(), 2 ) == 0 ) // transient mode + GUI
{
SMESH_Gen_i* aSMESHGen = SMESH_Gen_i::GetSMESHGen();
SALOMEDS::Study_var aStudy = aSMESHGen->GetCurrentStudy();

View File

@ -1615,7 +1615,7 @@ namespace // functions making checks according to SMESH::NB_COMMON_NODES_ENUM
bool isMajorityOfNodesCommon(int nbChecked, int nbCommon, int nbNodes, int nbCorners,
bool & toStopChecking )
{
return nbCommon >= nbNodes / 2;
return nbCommon >= (nbNodes+1) / 2;
}
}

View File

@ -757,6 +757,13 @@ class smeshBuilder(object, SMESH._objref_SMESH_Gen):
raise ValueError, "Group type mismatches Element type"
aCriterion.ThresholdStr = aThreshold.GetName()
aCriterion.ThresholdID = salome.orb.object_to_string( aThreshold )
study = self.GetCurrentStudy()
if study:
so = study.FindObjectIOR( aCriterion.ThresholdID )
if so:
entry = so.GetID()
if entry:
aCriterion.ThresholdID = entry
else:
raise TypeError, "The Threshold should be a Mesh Group"
elif CritType == FT_RangeOfIds: