mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-12 09:40:35 +05:00
Method ::createMesh() is corrected for bug PAL12652.
(Creation of meshes for few GeomEntry is implemented).
This commit is contained in:
parent
06890db430
commit
337b491aaf
@ -1172,44 +1172,51 @@ bool SMESHGUI_MeshOp::createMesh( QString& theMess )
|
|||||||
{
|
{
|
||||||
theMess = "";
|
theMess = "";
|
||||||
|
|
||||||
QString aGeomEntry = myDlg->selectedObject( SMESHGUI_MeshDlg::Geom );
|
//QString aGeomEntry = myDlg->selectedObject( SMESHGUI_MeshDlg::Geom );
|
||||||
_PTR(SObject) pGeom = studyDS()->FindObjectID( aGeomEntry.latin1() );
|
//QString aGeomEntry = myDlg->selectedObject( SMESHGUI_MeshDlg::Geom );
|
||||||
GEOM::GEOM_Object_var aGeomVar =
|
|
||||||
GEOM::GEOM_Object::_narrow( _CAST( SObject,pGeom )->GetObject() );
|
|
||||||
|
|
||||||
SMESH::SMESH_Gen_var aSMESHGen = SMESHGUI::GetSMESHGen();
|
QStringList aList;
|
||||||
if ( aSMESHGen->_is_nil() )
|
myDlg->selectedObject( SMESHGUI_MeshDlg::Geom, aList );
|
||||||
return false;
|
QStringList::Iterator it = aList.begin();
|
||||||
|
for(; it!=aList.end(); it++) {
|
||||||
|
|
||||||
SUIT_OverrideCursor aWaitCursor;
|
QString aGeomEntry = *it;
|
||||||
|
_PTR(SObject) pGeom = studyDS()->FindObjectID( aGeomEntry.latin1() );
|
||||||
|
GEOM::GEOM_Object_var aGeomVar =
|
||||||
|
GEOM::GEOM_Object::_narrow( _CAST( SObject,pGeom )->GetObject() );
|
||||||
|
|
||||||
// create mesh
|
SMESH::SMESH_Gen_var aSMESHGen = SMESHGUI::GetSMESHGen();
|
||||||
SMESH::SMESH_Mesh_var aMeshVar = aSMESHGen->CreateMesh( aGeomVar );
|
if ( aSMESHGen->_is_nil() )
|
||||||
if ( aMeshVar->_is_nil() )
|
return false;
|
||||||
return false;
|
|
||||||
_PTR(SObject) aMeshSO = SMESH::FindSObject( aMeshVar.in() );
|
|
||||||
if ( aMeshSO )
|
|
||||||
SMESH::SetName( aMeshSO, myDlg->objectText( SMESHGUI_MeshDlg::Obj ).latin1() );
|
|
||||||
|
|
||||||
for ( int aDim = SMESH::DIM_1D; aDim <= SMESH::DIM_3D; aDim++ )
|
SUIT_OverrideCursor aWaitCursor;
|
||||||
{
|
|
||||||
if ( !isAccessibleDim( aDim )) continue;
|
|
||||||
|
|
||||||
// assign hypotheses
|
// create mesh
|
||||||
for ( int aHypType = MainHyp; aHypType <= AddHyp; aHypType++ )
|
SMESH::SMESH_Mesh_var aMeshVar = aSMESHGen->CreateMesh( aGeomVar );
|
||||||
{
|
if ( aMeshVar->_is_nil() )
|
||||||
int aHypIndex = currentHyp( aDim, aHypType );
|
return false;
|
||||||
if ( aHypIndex >= 0 && aHypIndex < myExistingHyps[ aDim ][ aHypType ].count() )
|
_PTR(SObject) aMeshSO = SMESH::FindSObject( aMeshVar.in() );
|
||||||
{
|
if ( aMeshSO )
|
||||||
SMESH::SMESH_Hypothesis_var aHypVar = myExistingHyps[ aDim ][ aHypType ][ aHypIndex ];
|
SMESH::SetName( aMeshSO, myDlg->objectText( SMESHGUI_MeshDlg::Obj ).latin1() );
|
||||||
if ( !aHypVar->_is_nil() )
|
|
||||||
SMESH::AddHypothesisOnMesh( aMeshVar, aHypVar );
|
for ( int aDim = SMESH::DIM_1D; aDim <= SMESH::DIM_3D; aDim++ ) {
|
||||||
|
if ( !isAccessibleDim( aDim )) continue;
|
||||||
|
|
||||||
|
// assign hypotheses
|
||||||
|
for ( int aHypType = MainHyp; aHypType <= AddHyp; aHypType++ ) {
|
||||||
|
int aHypIndex = currentHyp( aDim, aHypType );
|
||||||
|
if ( aHypIndex >= 0 && aHypIndex < myExistingHyps[ aDim ][ aHypType ].count() ) {
|
||||||
|
SMESH::SMESH_Hypothesis_var aHypVar = myExistingHyps[ aDim ][ aHypType ][ aHypIndex ];
|
||||||
|
if ( !aHypVar->_is_nil() )
|
||||||
|
SMESH::AddHypothesisOnMesh( aMeshVar, aHypVar );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
// find or create algorithm
|
||||||
|
SMESH::SMESH_Hypothesis_var anAlgoVar = getAlgo( aDim );
|
||||||
|
if ( !anAlgoVar->_is_nil() )
|
||||||
|
SMESH::AddHypothesisOnMesh( aMeshVar, anAlgoVar );
|
||||||
}
|
}
|
||||||
// find or create algorithm
|
|
||||||
SMESH::SMESH_Hypothesis_var anAlgoVar = getAlgo( aDim );
|
|
||||||
if ( !anAlgoVar->_is_nil() )
|
|
||||||
SMESH::AddHypothesisOnMesh( aMeshVar, anAlgoVar );
|
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user