0021557: EDF 2161 SMESH: Duplicate elements and nodes

1) Add
ListOfGroups DoubleNodeElemGroup2New(...)
2) Fix dump of DoubleNode*New(...)
This commit is contained in:
eap 2012-04-26 07:07:00 +00:00
parent d6352114af
commit 38a33519c9
2 changed files with 154 additions and 42 deletions

View File

@ -5257,14 +5257,15 @@ CORBA::Boolean SMESH_MeshEditor_i::DoubleNodeGroup(SMESH::SMESH_GroupBase_ptr th
* \return a new group with newly created nodes * \return a new group with newly created nodes
* \sa DoubleNodeGroup() * \sa DoubleNodeGroup()
*/ */
SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeGroupNew( SMESH::SMESH_GroupBase_ptr theNodes, SMESH::SMESH_Group_ptr
SMESH::SMESH_GroupBase_ptr theModifiedElems ) SMESH_MeshEditor_i::DoubleNodeGroupNew( SMESH::SMESH_GroupBase_ptr theNodes,
SMESH::SMESH_GroupBase_ptr theModifiedElems )
{ {
if ( CORBA::is_nil( theNodes ) && theNodes->GetType() != SMESH::NODE )
return false;
SMESH::SMESH_Group_var aNewGroup; SMESH::SMESH_Group_var aNewGroup;
if ( CORBA::is_nil( theNodes ) && theNodes->GetType() != SMESH::NODE )
return aNewGroup._retn();
// Duplicate nodes // Duplicate nodes
SMESH::long_array_var aNodes = theNodes->GetListOfID(); SMESH::long_array_var aNodes = theNodes->GetListOfID();
SMESH::long_array_var aModifiedElems; SMESH::long_array_var aModifiedElems;
@ -5278,7 +5279,6 @@ SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeGroupNew( SMESH::SMESH_Grou
TPythonDump pyDump; // suppress dump by the next line TPythonDump pyDump; // suppress dump by the next line
bool aResult = DoubleNodes( aNodes, aModifiedElems ); bool aResult = DoubleNodes( aNodes, aModifiedElems );
if ( aResult ) if ( aResult )
{ {
// Create group with newly created nodes // Create group with newly created nodes
@ -5288,11 +5288,12 @@ SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeGroupNew( SMESH::SMESH_Grou
string aNewName = generateGroupName(anUnindexedName + "_double"); string aNewName = generateGroupName(anUnindexedName + "_double");
aNewGroup = myMesh_i->CreateGroup(SMESH::NODE, aNewName.c_str()); aNewGroup = myMesh_i->CreateGroup(SMESH::NODE, aNewName.c_str());
aNewGroup->Add(anIds); aNewGroup->Add(anIds);
pyDump << aNewGroup << " = ";
} }
} }
pyDump << "createdNodes = " << this << ".DoubleNodeGroupNew( " << theNodes << ", " pyDump << this << ".DoubleNodeGroupNew( " << theNodes << ", "
<< theModifiedElems << " )"; << theModifiedElems << " )";
return aNewGroup._retn(); return aNewGroup._retn();
} }
@ -5365,8 +5366,9 @@ CORBA::Boolean SMESH_MeshEditor_i::DoubleNodeGroups(const SMESH::ListOfGroups& t
*/ */
//================================================================================ //================================================================================
SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeGroupsNew( const SMESH::ListOfGroups& theNodes, SMESH::SMESH_Group_ptr
const SMESH::ListOfGroups& theModifiedElems ) SMESH_MeshEditor_i::DoubleNodeGroupsNew( const SMESH::ListOfGroups& theNodes,
const SMESH::ListOfGroups& theModifiedElems )
{ {
SMESH::SMESH_Group_var aNewGroup; SMESH::SMESH_Group_var aNewGroup;
@ -5383,11 +5385,12 @@ SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeGroupsNew( const SMESH::Lis
string aNewName = generateGroupName(anUnindexedName + "_double"); string aNewName = generateGroupName(anUnindexedName + "_double");
aNewGroup = myMesh_i->CreateGroup(SMESH::NODE, aNewName.c_str()); aNewGroup = myMesh_i->CreateGroup(SMESH::NODE, aNewName.c_str());
aNewGroup->Add(anIds); aNewGroup->Add(anIds);
pyDump << aNewGroup << " = ";
} }
} }
pyDump << "createdNodes = " << this << ".DoubleNodeGroupsNew( " << theNodes << ", " pyDump << this << ".DoubleNodeGroupsNew( " << theNodes << ", "
<< theModifiedElems << " )"; << theModifiedElems << " )";
return aNewGroup._retn(); return aNewGroup._retn();
} }
@ -5531,14 +5534,40 @@ CORBA::Boolean SMESH_MeshEditor_i::DoubleNodeElemGroup(SMESH::SMESH_GroupBase_pt
* \return a new group with newly created elements * \return a new group with newly created elements
* \sa DoubleNodeElemGroup() * \sa DoubleNodeElemGroup()
*/ */
SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeElemGroupNew(SMESH::SMESH_GroupBase_ptr theElems, SMESH::SMESH_Group_ptr
SMESH::SMESH_GroupBase_ptr theNodesNot, SMESH_MeshEditor_i::DoubleNodeElemGroupNew(SMESH::SMESH_GroupBase_ptr theElems,
SMESH::SMESH_GroupBase_ptr theAffectedElems) SMESH::SMESH_GroupBase_ptr theNodesNot,
SMESH::SMESH_GroupBase_ptr theAffectedElems)
{ {
if ( CORBA::is_nil( theElems ) && theElems->GetType() == SMESH::NODE ) TPythonDump pyDump;
return false; SMESH::ListOfGroups_var twoGroups = DoubleNodeElemGroup2New( theElems,
theNodesNot,
theAffectedElems,
true, false );
SMESH::SMESH_GroupBase_var baseGroup = twoGroups[0].in();
SMESH::SMESH_Group_var elemGroup = SMESH::SMESH_Group::_narrow( baseGroup );
SMESH::SMESH_Group_var aNewGroup; pyDump << elemGroup << " = " << this << ".DoubleNodeElemGroupNew( "
<< theElems << ", "
<< theNodesNot << ", "
<< theAffectedElems << " )";
return elemGroup._retn();
}
SMESH::ListOfGroups*
SMESH_MeshEditor_i::DoubleNodeElemGroup2New(SMESH::SMESH_GroupBase_ptr theElems,
SMESH::SMESH_GroupBase_ptr theNodesNot,
SMESH::SMESH_GroupBase_ptr theAffectedElems,
CORBA::Boolean theElemGroupNeeded,
CORBA::Boolean theNodeGroupNeeded)
{
SMESH::SMESH_Group_var aNewElemGroup, aNewNodeGroup;
SMESH::ListOfGroups_var aTwoGroups = new SMESH::ListOfGroups();
aTwoGroups->length( 2 );
if ( CORBA::is_nil( theElems ) && theElems->GetType() == SMESH::NODE )
return aTwoGroups._retn();
initData(); initData();
@ -5554,25 +5583,49 @@ SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeElemGroupNew(SMESH::SMESH_G
bool aResult = aMeshEditor.DoubleNodes( anElems, aNodes, anAffected ); bool aResult = aMeshEditor.DoubleNodes( anElems, aNodes, anAffected );
storeResult( aMeshEditor) ; storeResult( aMeshEditor) ;
myMesh->GetMeshDS()->Modified();
if ( aResult ) { TPythonDump pyDump;
if ( aResult )
{
myMesh->SetIsModified( true ); myMesh->SetIsModified( true );
// Create group with newly created elements // Create group with newly created elements
SMESH::long_array_var anIds = GetLastCreatedElems(); CORBA::String_var elemGroupName = theElems->GetName();
if (anIds->length() > 0) { string aNewName = generateGroupName( string(elemGroupName.in()) + "_double");
if ( !aMeshEditor.GetLastCreatedElems().IsEmpty() && theElemGroupNeeded )
{
SMESH::long_array_var anIds = GetLastCreatedElems();
SMESH::ElementType aGroupType = myMesh_i->GetElementType(anIds[0], true); SMESH::ElementType aGroupType = myMesh_i->GetElementType(anIds[0], true);
string anUnindexedName (theElems->GetName()); aNewElemGroup = myMesh_i->CreateGroup(aGroupType, aNewName.c_str());
string aNewName = generateGroupName(anUnindexedName + "_double"); aNewElemGroup->Add(anIds);
aNewGroup = myMesh_i->CreateGroup(aGroupType, aNewName.c_str()); }
aNewGroup->Add(anIds); if ( !aMeshEditor.GetLastCreatedNodes().IsEmpty() && theNodeGroupNeeded )
{
SMESH::long_array_var anIds = GetLastCreatedNodes();
aNewNodeGroup = myMesh_i->CreateGroup(SMESH::NODE, aNewName.c_str());
aNewNodeGroup->Add(anIds);
} }
} }
// Update Python script // Update Python script
TPythonDump() << "createdElems = " << this << ".DoubleNodeElemGroupNew( " << theElems << ", "
<< theNodesNot << ", " << theAffectedElems << " )"; pyDump << "[ ";
return aNewGroup._retn(); if ( aNewElemGroup->_is_nil() ) pyDump << "nothing, ";
else pyDump << aNewElemGroup << ", ";
if ( aNewNodeGroup->_is_nil() ) pyDump << "nothing ] = ";
else pyDump << aNewNodeGroup << " ] = ";
pyDump << this << ".DoubleNodeElemGroup2New( " << theElems << ", "
<< theNodesNot << ", "
<< theAffectedElems << ", "
<< theElemGroupNeeded << ", "
<< theNodeGroupNeeded <<" )";
aTwoGroups[0] = aNewElemGroup._retn();
aTwoGroups[1] = aNewNodeGroup._retn();
return aTwoGroups._retn();
} }
//================================================================================ //================================================================================
@ -5691,11 +5744,37 @@ CORBA::Boolean SMESH_MeshEditor_i::DoubleNodeElemGroups(const SMESH::ListOfGroup
*/ */
//================================================================================ //================================================================================
SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeElemGroupsNew(const SMESH::ListOfGroups& theElems, SMESH::SMESH_Group_ptr
const SMESH::ListOfGroups& theNodesNot, SMESH_MeshEditor_i::DoubleNodeElemGroupsNew(const SMESH::ListOfGroups& theElems,
const SMESH::ListOfGroups& theAffectedElems) const SMESH::ListOfGroups& theNodesNot,
const SMESH::ListOfGroups& theAffectedElems)
{ {
SMESH::SMESH_Group_var aNewGroup; TPythonDump pyDump;
SMESH::ListOfGroups_var twoGroups = DoubleNodeElemGroups2New( theElems,
theNodesNot,
theAffectedElems,
true, false );
SMESH::SMESH_GroupBase_var baseGroup = twoGroups[0].in();
SMESH::SMESH_Group_var elemGroup = SMESH::SMESH_Group::_narrow( baseGroup );
pyDump << elemGroup << " = " << this << ".DoubleNodeElemGroupsNew( "
<< theElems << ", "
<< theNodesNot << ", "
<< theAffectedElems << " )";
return elemGroup._retn();
}
SMESH::ListOfGroups*
SMESH_MeshEditor_i::DoubleNodeElemGroups2New(const SMESH::ListOfGroups& theElems,
const SMESH::ListOfGroups& theNodesNot,
const SMESH::ListOfGroups& theAffectedElems,
CORBA::Boolean theElemGroupNeeded,
CORBA::Boolean theNodeGroupNeeded)
{
SMESH::SMESH_Group_var aNewElemGroup, aNewNodeGroup;
SMESH::ListOfGroups_var aTwoGroups = new SMESH::ListOfGroups();
aTwoGroups->length( 2 );
initData(); initData();
@ -5712,24 +5791,46 @@ SMESH::SMESH_Group_ptr SMESH_MeshEditor_i::DoubleNodeElemGroupsNew(const SMESH::
storeResult( aMeshEditor) ; storeResult( aMeshEditor) ;
myMesh->GetMeshDS()->Modified(); myMesh->GetMeshDS()->Modified();
if ( aResult ) { TPythonDump pyDump;
if ( aResult )
{
myMesh->SetIsModified( true ); myMesh->SetIsModified( true );
// Create group with newly created elements // Create group with newly created elements
SMESH::long_array_var anIds = GetLastCreatedElems(); CORBA::String_var elemGroupName = theElems[0]->GetName();
if (anIds->length() > 0) { string aNewName = generateGroupName( string(elemGroupName.in()) + "_double");
if ( !aMeshEditor.GetLastCreatedElems().IsEmpty() && theElemGroupNeeded )
{
SMESH::long_array_var anIds = GetLastCreatedElems();
SMESH::ElementType aGroupType = myMesh_i->GetElementType(anIds[0], true); SMESH::ElementType aGroupType = myMesh_i->GetElementType(anIds[0], true);
string anUnindexedName (theElems[0]->GetName()); aNewElemGroup = myMesh_i->CreateGroup(aGroupType, aNewName.c_str());
string aNewName = generateGroupName(anUnindexedName + "_double"); aNewElemGroup->Add(anIds);
aNewGroup = myMesh_i->CreateGroup(aGroupType, aNewName.c_str()); }
aNewGroup->Add(anIds); if ( !aMeshEditor.GetLastCreatedNodes().IsEmpty() && theNodeGroupNeeded )
{
SMESH::long_array_var anIds = GetLastCreatedNodes();
aNewNodeGroup = myMesh_i->CreateGroup(SMESH::NODE, aNewName.c_str());
aNewNodeGroup->Add(anIds);
} }
} }
// Update Python script // Update Python script
TPythonDump() << "createdElems = " << this << ".DoubleNodeElemGroupsNew( " << &theElems << ", "
<< &theNodesNot << ", " << &theAffectedElems << " )"; pyDump << "[ ";
return aNewGroup._retn(); if ( aNewElemGroup->_is_nil() ) pyDump << "nothing, ";
else pyDump << aNewElemGroup << ", ";
if ( aNewNodeGroup->_is_nil() ) pyDump << "nothing ] = ";
else pyDump << aNewNodeGroup << " ] = ";
pyDump << this << ".DoubleNodeElemGroups2New( " << &theElems << ", "
<< &theNodesNot << ", "
<< &theAffectedElems << ", "
<< theElemGroupNeeded << ", "
<< theNodeGroupNeeded << " )";
aTwoGroups[0] = aNewElemGroup._retn();
aTwoGroups[1] = aNewNodeGroup._retn();
return aTwoGroups._retn();
} }
//================================================================================ //================================================================================

View File

@ -660,6 +660,12 @@ public:
SMESH::SMESH_GroupBase_ptr theNodesNot, SMESH::SMESH_GroupBase_ptr theNodesNot,
SMESH::SMESH_GroupBase_ptr theAffectedElems ); SMESH::SMESH_GroupBase_ptr theAffectedElems );
SMESH::ListOfGroups* DoubleNodeElemGroup2New(SMESH::SMESH_GroupBase_ptr theElems,
SMESH::SMESH_GroupBase_ptr theNodesNot,
SMESH::SMESH_GroupBase_ptr theAffectedElems,
CORBA::Boolean theElemGroupNeeded,
CORBA::Boolean theNodeGroupNeeded);
/*! /*!
* \brief Creates a hole in a mesh by doubling the nodes of some particular elements * \brief Creates a hole in a mesh by doubling the nodes of some particular elements
* \param theElems - group of of elements (edges or faces) to be replicated * \param theElems - group of of elements (edges or faces) to be replicated
@ -702,6 +708,11 @@ public:
const SMESH::ListOfGroups& theNodesNot, const SMESH::ListOfGroups& theNodesNot,
const SMESH::ListOfGroups& theAffectedElems ); const SMESH::ListOfGroups& theAffectedElems );
SMESH::ListOfGroups* DoubleNodeElemGroups2New(const SMESH::ListOfGroups& theElems,
const SMESH::ListOfGroups& theNodesNot,
const SMESH::ListOfGroups& theAffectedElems,
CORBA::Boolean theElemGroupNeeded,
CORBA::Boolean theNodeGroupNeeded);
/*! /*!
* \brief Creates a hole in a mesh by doubling the nodes of some particular elements * \brief Creates a hole in a mesh by doubling the nodes of some particular elements