mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-22 07:30:33 +05:00
0021557: EDF 2161 SMESH: Duplicate elements and nodes
1) Add ListOfGroups DoubleNodeElemGroup2New(...) 2) Fix dump of DoubleNode*New(...)
This commit is contained in:
parent
d6352114af
commit
38a33519c9
@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user