mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-26 23:20:33 +05:00
IMP 23300: [EDF 12865] Independent calculation of sub-meshes
This commit is contained in:
parent
efbf393dc4
commit
b3cb4c5a57
@ -40,11 +40,27 @@ algo_local = mesh.Segment(EdgeX)
|
|||||||
algo_local.Arithmetic1D(1, 4)
|
algo_local.Arithmetic1D(1, 4)
|
||||||
|
|
||||||
# define "Propagation" hypothesis that propagates algo_local and "Arithmetic1D" hypothesis
|
# define "Propagation" hypothesis that propagates algo_local and "Arithmetic1D" hypothesis
|
||||||
# on all parallel edges of the box
|
# from EdgeX to all parallel edges
|
||||||
algo_local.Propagation()
|
algo_local.Propagation()
|
||||||
|
|
||||||
# assign a hexahedral algorithm
|
# assign a hexahedral algorithm
|
||||||
mesh.Hexahedron()
|
mesh.Hexahedron()
|
||||||
|
|
||||||
# compute the mesh
|
|
||||||
|
# any sub-shape can be meshed individually --
|
||||||
|
# compute mesh on two surfaces using different methods
|
||||||
|
|
||||||
|
# get surfaces
|
||||||
|
surfaces = geompy.SubShapeAll(box, geompy.ShapeType["FACE"])
|
||||||
|
|
||||||
|
# method 1: no sub-mesh is created
|
||||||
|
mesh.Compute( surfaces[0] )
|
||||||
|
|
||||||
|
# method 2: a sub-mesh is created
|
||||||
|
submesh = mesh.GetSubMesh( surfaces[2], "submesh 2" )
|
||||||
|
submesh.Compute()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# compute the whole mesh
|
||||||
mesh.Compute()
|
mesh.Compute()
|
||||||
|
@ -16,6 +16,10 @@ Creation of a sub-mesh allows to control individually meshing of a
|
|||||||
certain sub-shape, thus to get a locally coarser or finer mesh, to get
|
certain sub-shape, thus to get a locally coarser or finer mesh, to get
|
||||||
elements of different types in the same mesh, etc.
|
elements of different types in the same mesh, etc.
|
||||||
|
|
||||||
|
A sub-mesh can be meshed individually. To achieve this, select a
|
||||||
|
sub-mesh and either invoke <b>Compute Sub-mesh</b> vai the contextual
|
||||||
|
menu in the Object Browser or invoke <b> Mesh > Compute </b> menu.
|
||||||
|
|
||||||
\section submesh_shape_section How to get a sub-shape for sub-mesh construction
|
\section submesh_shape_section How to get a sub-shape for sub-mesh construction
|
||||||
|
|
||||||
A sub-shape to create a sub-mesh on should be retrieved from the main shape
|
A sub-shape to create a sub-mesh on should be retrieved from the main shape
|
||||||
|
@ -2688,7 +2688,10 @@ bool SMESHGUI::OnGUIEvent( int theCommandID )
|
|||||||
case SMESHOp::OpCreateMesh:
|
case SMESHOp::OpCreateMesh:
|
||||||
case SMESHOp::OpCreateSubMesh:
|
case SMESHOp::OpCreateSubMesh:
|
||||||
case SMESHOp::OpEditMeshOrSubMesh:
|
case SMESHOp::OpEditMeshOrSubMesh:
|
||||||
|
case SMESHOp::OpEditMesh:
|
||||||
|
case SMESHOp::OpEditSubMesh:
|
||||||
case SMESHOp::OpCompute:
|
case SMESHOp::OpCompute:
|
||||||
|
case SMESHOp::OpComputeSubMesh:
|
||||||
case SMESHOp::OpPreCompute:
|
case SMESHOp::OpPreCompute:
|
||||||
case SMESHOp::OpEvaluate:
|
case SMESHOp::OpEvaluate:
|
||||||
case SMESHOp::OpMeshOrder:
|
case SMESHOp::OpMeshOrder:
|
||||||
@ -3806,9 +3809,12 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
createSMESHAction( SMESHOp::OpCreateMesh, "CREATE_MESH", "ICON_DLG_INIT_MESH" );
|
createSMESHAction( SMESHOp::OpCreateMesh, "CREATE_MESH", "ICON_DLG_INIT_MESH" );
|
||||||
createSMESHAction( SMESHOp::OpCreateSubMesh, "CREATE_SUBMESH", "ICON_DLG_ADD_SUBMESH" );
|
createSMESHAction( SMESHOp::OpCreateSubMesh, "CREATE_SUBMESH", "ICON_DLG_ADD_SUBMESH" );
|
||||||
createSMESHAction( SMESHOp::OpEditMeshOrSubMesh, "EDIT_MESHSUBMESH", "ICON_DLG_EDIT_MESH" );
|
createSMESHAction( SMESHOp::OpEditMeshOrSubMesh, "EDIT_MESHSUBMESH", "ICON_DLG_EDIT_MESH" );
|
||||||
|
createSMESHAction( SMESHOp::OpEditMesh, "EDIT_MESH", "ICON_DLG_EDIT_MESH" );
|
||||||
|
createSMESHAction( SMESHOp::OpEditSubMesh, "EDIT_SUBMESH", "ICON_DLG_EDIT_MESH" );
|
||||||
createSMESHAction( SMESHOp::OpBuildCompoundMesh, "BUILD_COMPOUND", "ICON_BUILD_COMPOUND" );
|
createSMESHAction( SMESHOp::OpBuildCompoundMesh, "BUILD_COMPOUND", "ICON_BUILD_COMPOUND" );
|
||||||
createSMESHAction( SMESHOp::OpCopyMesh, "COPY_MESH", "ICON_COPY_MESH" );
|
createSMESHAction( SMESHOp::OpCopyMesh, "COPY_MESH", "ICON_COPY_MESH" );
|
||||||
createSMESHAction( SMESHOp::OpCompute, "COMPUTE", "ICON_COMPUTE" );
|
createSMESHAction( SMESHOp::OpCompute, "COMPUTE", "ICON_COMPUTE" );
|
||||||
|
createSMESHAction( SMESHOp::OpComputeSubMesh, "COMPUTE_SUBMESH", "ICON_COMPUTE" );
|
||||||
createSMESHAction( SMESHOp::OpPreCompute, "PRECOMPUTE", "ICON_PRECOMPUTE" );
|
createSMESHAction( SMESHOp::OpPreCompute, "PRECOMPUTE", "ICON_PRECOMPUTE" );
|
||||||
createSMESHAction( SMESHOp::OpEvaluate, "EVALUATE", "ICON_EVALUATE" );
|
createSMESHAction( SMESHOp::OpEvaluate, "EVALUATE", "ICON_EVALUATE" );
|
||||||
createSMESHAction( SMESHOp::OpMeshOrder, "MESH_ORDER", "ICON_MESH_ORDER");
|
createSMESHAction( SMESHOp::OpMeshOrder, "MESH_ORDER", "ICON_MESH_ORDER");
|
||||||
@ -4303,24 +4309,26 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
QString dc = "selcount"; // VSR : instead of QtxPopupSelection::defSelCountParam()
|
QString dc = "selcount"; // VSR : instead of QtxPopupSelection::defSelCountParam()
|
||||||
|
|
||||||
myRules.clear();
|
myRules.clear();
|
||||||
QString OB = "'ObjectBrowser'",
|
QString
|
||||||
View = "'" + SVTK_Viewer::Type() + "'",
|
OB = "'ObjectBrowser'",
|
||||||
pat = "'%1'",
|
View = "'" + SVTK_Viewer::Type() + "'",
|
||||||
mesh = pat.arg( SMESHGUI_Selection::typeName( SMESH::MESH ) ),
|
pat = "'%1'",
|
||||||
group = pat.arg( SMESHGUI_Selection::typeName( SMESH::GROUP ) ),
|
mesh = pat.arg( SMESHGUI_Selection::typeName( SMESH::MESH ) ),
|
||||||
hypo = pat.arg( SMESHGUI_Selection::typeName( SMESH::HYPOTHESIS ) ),
|
group = pat.arg( SMESHGUI_Selection::typeName( SMESH::GROUP ) ),
|
||||||
algo = pat.arg( SMESHGUI_Selection::typeName( SMESH::ALGORITHM ) ),
|
hypo = pat.arg( SMESHGUI_Selection::typeName( SMESH::HYPOTHESIS ) ),
|
||||||
elems = QString( "'%1' '%2' '%3' '%4' '%5' '%6'" ).
|
algo = pat.arg( SMESHGUI_Selection::typeName( SMESH::ALGORITHM ) ),
|
||||||
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_VERTEX ) ).
|
elems = QString( "'%1' '%2' '%3' '%4' '%5' '%6'" ).
|
||||||
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_EDGE ) ).
|
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_VERTEX ) ).
|
||||||
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_FACE ) ).
|
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_EDGE ) ).
|
||||||
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_SOLID ) ).
|
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_FACE ) ).
|
||||||
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_COMPOUND ) ).
|
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_SOLID ) ).
|
||||||
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH ) ),
|
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH_COMPOUND ) ).
|
||||||
subMesh = elems,
|
arg( SMESHGUI_Selection::typeName( SMESH::SUBMESH ) ),
|
||||||
mesh_part = mesh + " " + subMesh + " " + group,
|
subMesh = elems,
|
||||||
mesh_group = mesh + " " + group,
|
mesh_part = mesh + " " + subMesh + " " + group,
|
||||||
hyp_alg = hypo + " " + algo;
|
mesh_group = mesh + " " + group,
|
||||||
|
mesh_submesh = mesh + " " + subMesh,
|
||||||
|
hyp_alg = hypo + " " + algo;
|
||||||
|
|
||||||
// popup for object browser
|
// popup for object browser
|
||||||
QString
|
QString
|
||||||
@ -4339,36 +4347,36 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
hasVolumes("({'Volume'} in elemTypes)"),
|
hasVolumes("({'Volume'} in elemTypes)"),
|
||||||
hasFacesOrVolumes("(({'Face'} in elemTypes) || ({'Volume'} in elemTypes)) ");
|
hasFacesOrVolumes("(({'Face'} in elemTypes) || ({'Volume'} in elemTypes)) ");
|
||||||
|
|
||||||
createPopupItem( SMESHOp::OpFileInformation, OB, mesh, "&& selcount=1 && isImported" );
|
createPopupItem( SMESHOp::OpFileInformation, OB, mesh, "&& selcount=1 && isImported" );
|
||||||
createPopupItem( SMESHOp::OpCreateSubMesh, OB, mesh, "&& hasGeomReference");
|
createPopupItem( SMESHOp::OpCreateSubMesh, OB, mesh, "&& hasGeomReference");
|
||||||
createPopupItem( SMESHOp::OpEditMeshOrSubMesh, OB, mesh );
|
createPopupItem( SMESHOp::OpEditMesh, OB, mesh, "&& selcount=1" );
|
||||||
createPopupItem( SMESHOp::OpEditMeshOrSubMesh, OB, subMesh, "&& hasGeomReference" );
|
createPopupItem( SMESHOp::OpEditSubMesh, OB, subMesh, "&& selcount=1 && hasGeomReference" );
|
||||||
createPopupItem( SMESHOp::OpEditGroup, OB, group );
|
createPopupItem( SMESHOp::OpEditGroup, OB, group );
|
||||||
createPopupItem( SMESHOp::OpEditGeomGroupAsGroup, OB, group, "&& groupType != 'Group'" );
|
createPopupItem( SMESHOp::OpEditGeomGroupAsGroup, OB, group, "&& groupType != 'Group'" );
|
||||||
|
|
||||||
popupMgr()->insert( separator(), -1, 0 );
|
popupMgr()->insert( separator(), -1, 0 );
|
||||||
createPopupItem( SMESHOp::OpCompute, OB, mesh, "&& isComputable" );
|
createPopupItem( SMESHOp::OpCompute, OB, mesh, "&& selcount=1 && isComputable" );
|
||||||
createPopupItem( SMESHOp::OpPreCompute, OB, mesh, "&& isPreComputable" );
|
createPopupItem( SMESHOp::OpComputeSubMesh, OB, subMesh, "&& selcount=1 && isComputable" );
|
||||||
createPopupItem( SMESHOp::OpEvaluate, OB, mesh, "&& isComputable" );
|
createPopupItem( SMESHOp::OpPreCompute, OB, mesh, "&& selcount=1 && isPreComputable" );
|
||||||
createPopupItem( SMESHOp::OpMeshOrder, OB, mesh, "&& isComputable && hasGeomReference" );
|
createPopupItem( SMESHOp::OpEvaluate, OB, mesh, "&& selcount=1 && isComputable" );
|
||||||
createPopupItem( SMESHOp::OpUpdate, OB, mesh_part );
|
createPopupItem( SMESHOp::OpMeshOrder, OB, mesh, "&& selcount=1 && isComputable && hasGeomReference" );
|
||||||
createPopupItem( SMESHOp::OpMeshInformation, OB, mesh_part );
|
createPopupItem( SMESHOp::OpUpdate, OB, mesh_part );
|
||||||
createPopupItem( SMESHOp::OpFindElementByPoint, OB, mesh_group );
|
createPopupItem( SMESHOp::OpMeshInformation, OB, mesh_part );
|
||||||
createPopupItem( SMESHOp::OpOverallMeshQuality, OB, mesh_part );
|
createPopupItem( SMESHOp::OpFindElementByPoint,OB, mesh_group, "&& selcount=1" );
|
||||||
|
createPopupItem( SMESHOp::OpOverallMeshQuality,OB, mesh_part );
|
||||||
popupMgr()->insert( separator(), -1, 0 );
|
popupMgr()->insert( separator(), -1, 0 );
|
||||||
createPopupItem( SMESHOp::OpCreateGroup, OB, mesh );
|
createPopupItem( SMESHOp::OpCreateGroup, OB, mesh, "&& selcount=1" );
|
||||||
createPopupItem( SMESHOp::OpCreateGeometryGroup, OB, mesh, "&& hasGeomReference" );
|
createPopupItem( SMESHOp::OpCreateGeometryGroup, OB, mesh, "&& selcount=1 && hasGeomReference" );
|
||||||
createPopupItem( SMESHOp::OpConstructGroup, OB, subMesh );
|
createPopupItem( SMESHOp::OpConstructGroup, OB, subMesh );
|
||||||
popupMgr()->insert( separator(), -1, 0 );
|
popupMgr()->insert( separator(), -1, 0 );
|
||||||
createPopupItem( SMESHOp::OpEditHypothesis, OB, hypo, "&& isEditableHyp");
|
createPopupItem( SMESHOp::OpEditHypothesis, OB, hypo, "&& isEditableHyp");
|
||||||
createPopupItem( SMESHOp::OpUnassign, OB, hyp_alg ); // REMOVE HYPOTHESIS / ALGORITHMS
|
createPopupItem( SMESHOp::OpUnassign, OB, hyp_alg );
|
||||||
popupMgr()->insert( separator(), -1, 0 );
|
popupMgr()->insert( separator(), -1, 0 );
|
||||||
createPopupItem( SMESHOp::OpConvertMeshToQuadratic, OB, mesh + " " + subMesh ); // convert to quadratic
|
createPopupItem( SMESHOp::OpConvertMeshToQuadratic, OB, mesh_submesh );
|
||||||
createPopupItem( SMESHOp::OpCreateBoundaryElements, OB, mesh + " " + group, // create 2D mesh from 3D
|
createPopupItem( SMESHOp::OpCreateBoundaryElements, OB, mesh_group, "&& selcount=1 && dim>=2");
|
||||||
"&& dim>=2");
|
|
||||||
popupMgr()->insert( separator(), -1, 0 );
|
popupMgr()->insert( separator(), -1, 0 );
|
||||||
createPopupItem( SMESHOp::OpClearMesh, OB, mesh );
|
createPopupItem( SMESHOp::OpClearMesh, OB, mesh );
|
||||||
popupMgr()->insert( separator(), -1, 0 );
|
//popupMgr()->insert( separator(), -1, 0 );
|
||||||
|
|
||||||
QString only_one_non_empty = QString( " && %1=1 && numberOfNodes>0" ).arg( dc );
|
QString only_one_non_empty = QString( " && %1=1 && numberOfNodes>0" ).arg( dc );
|
||||||
QString multiple_non_empty = QString( " && %1>0 && numberOfNodes>0" ).arg( dc );
|
QString multiple_non_empty = QString( " && %1>0 && numberOfNodes>0" ).arg( dc );
|
||||||
@ -5489,9 +5497,12 @@ LightApp_Operation* SMESHGUI::createOperation( const int id ) const
|
|||||||
op = new SMESHGUI_MeshOp( true, false );
|
op = new SMESHGUI_MeshOp( true, false );
|
||||||
break;
|
break;
|
||||||
case SMESHOp::OpEditMeshOrSubMesh:
|
case SMESHOp::OpEditMeshOrSubMesh:
|
||||||
|
case SMESHOp::OpEditMesh:
|
||||||
|
case SMESHOp::OpEditSubMesh:
|
||||||
op = new SMESHGUI_MeshOp( false );
|
op = new SMESHGUI_MeshOp( false );
|
||||||
break;
|
break;
|
||||||
case SMESHOp::OpCompute:
|
case SMESHOp::OpCompute:
|
||||||
|
case SMESHOp::OpComputeSubMesh:
|
||||||
op = new SMESHGUI_ComputeOp();
|
op = new SMESHGUI_ComputeOp();
|
||||||
break;
|
break;
|
||||||
case SMESHOp::OpPreCompute:
|
case SMESHOp::OpPreCompute:
|
||||||
@ -6219,8 +6230,7 @@ void SMESHGUI::restoreVisualParameters (int savePoint)
|
|||||||
if (ac->IsA("SMESH_Actor")) {
|
if (ac->IsA("SMESH_Actor")) {
|
||||||
SMESH_Actor* aGeomAc = SMESH_Actor::SafeDownCast(ac);
|
SMESH_Actor* aGeomAc = SMESH_Actor::SafeDownCast(ac);
|
||||||
if (aGeomAc->hasIO()) {
|
if (aGeomAc->hasIO()) {
|
||||||
Handle(SALOME_InteractiveObject) io =
|
Handle(SALOME_InteractiveObject) io = aGeomAc->getIO();
|
||||||
Handle(SALOME_InteractiveObject)::DownCast(aGeomAc->getIO());
|
|
||||||
if (io->hasEntry() && strcmp(io->getEntry(), entry.toLatin1().data()) == 0) {
|
if (io->hasEntry() && strcmp(io->getEntry(), entry.toLatin1().data()) == 0) {
|
||||||
isFound = true;
|
isFound = true;
|
||||||
vtkActors.Bind(viewIndex, aGeomAc);
|
vtkActors.Bind(viewIndex, aGeomAc);
|
||||||
|
@ -683,6 +683,7 @@ void SMESHGUI_BaseComputeOp::startOperation()
|
|||||||
|
|
||||||
myMesh = SMESH::SMESH_Mesh::_nil();
|
myMesh = SMESH::SMESH_Mesh::_nil();
|
||||||
myMainShape = GEOM::GEOM_Object::_nil();
|
myMainShape = GEOM::GEOM_Object::_nil();
|
||||||
|
myCurShape = GEOM::GEOM_Object::_nil();
|
||||||
|
|
||||||
// check selection
|
// check selection
|
||||||
LightApp_SelectionMgr *Sel = selectionMgr();
|
LightApp_SelectionMgr *Sel = selectionMgr();
|
||||||
@ -698,7 +699,23 @@ void SMESHGUI_BaseComputeOp::startOperation()
|
|||||||
}
|
}
|
||||||
|
|
||||||
myIObject = selected.First();
|
myIObject = selected.First();
|
||||||
myMesh = SMESH::GetMeshByIO(myIObject);
|
CORBA::Object_var anObj = SMESH::IObjectToObject( myIObject );
|
||||||
|
|
||||||
|
myMesh = SMESH::SMESH_Mesh::_narrow(anObj);
|
||||||
|
if ( myMesh->_is_nil() )
|
||||||
|
{
|
||||||
|
SMESH::SMESH_subMesh_var aSubMesh = SMESH::SMESH_subMesh::_narrow(anObj);
|
||||||
|
if ( !aSubMesh->_is_nil() )
|
||||||
|
{
|
||||||
|
myMesh = aSubMesh->GetFather();
|
||||||
|
myCurShape = aSubMesh->GetSubShape();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
myCurShape = myMesh->GetShapeToMesh();
|
||||||
|
}
|
||||||
|
|
||||||
if (myMesh->_is_nil()) {
|
if (myMesh->_is_nil()) {
|
||||||
SUIT_MessageBox::warning(desktop(),
|
SUIT_MessageBox::warning(desktop(),
|
||||||
tr("SMESH_WRN_WARNING"),
|
tr("SMESH_WRN_WARNING"),
|
||||||
@ -706,6 +723,7 @@ void SMESHGUI_BaseComputeOp::startOperation()
|
|||||||
onCancel();
|
onCancel();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
myMainShape = myMesh->GetShapeToMesh();
|
myMainShape = myMesh->GetShapeToMesh();
|
||||||
|
|
||||||
SMESHGUI_Operation::startOperation();
|
SMESHGUI_Operation::startOperation();
|
||||||
@ -882,10 +900,8 @@ void SMESHGUI_BaseComputeOp::computeMesh()
|
|||||||
myMesh->Clear();
|
myMesh->Clear();
|
||||||
SUIT_OverrideCursor aWaitCursor;
|
SUIT_OverrideCursor aWaitCursor;
|
||||||
try {
|
try {
|
||||||
#if (OCC_VERSION_MAJOR << 16 | OCC_VERSION_MINOR << 8 | OCC_VERSION_MAINTENANCE) > 0x060100
|
|
||||||
OCC_CATCH_SIGNALS;
|
OCC_CATCH_SIGNALS;
|
||||||
#endif
|
SMESHGUI_ComputeDlg_QThreadQDialog qthreaddialog(desktop(), gen, myMesh, myCurShape);
|
||||||
SMESHGUI_ComputeDlg_QThreadQDialog qthreaddialog(desktop(), gen, myMesh, myMainShape);
|
|
||||||
qthreaddialog.exec();
|
qthreaddialog.exec();
|
||||||
computeFailed = !qthreaddialog.result();
|
computeFailed = !qthreaddialog.result();
|
||||||
}
|
}
|
||||||
@ -893,9 +909,7 @@ void SMESHGUI_BaseComputeOp::computeMesh()
|
|||||||
memoryLack = true;
|
memoryLack = true;
|
||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
#if (OCC_VERSION_MAJOR << 16 | OCC_VERSION_MINOR << 8 | OCC_VERSION_MAINTENANCE) > 0x060100
|
|
||||||
OCC_CATCH_SIGNALS;
|
OCC_CATCH_SIGNALS;
|
||||||
#endif
|
|
||||||
aCompErrors = gen->GetComputeErrors( myMesh, myMainShape );
|
aCompErrors = gen->GetComputeErrors( myMesh, myMainShape );
|
||||||
// check if there are memory problems
|
// check if there are memory problems
|
||||||
for ( CORBA::ULong i = 0; (i < aCompErrors->length()) && !memoryLack; ++i )
|
for ( CORBA::ULong i = 0; (i < aCompErrors->length()) && !memoryLack; ++i )
|
||||||
@ -911,7 +925,8 @@ void SMESHGUI_BaseComputeOp::computeMesh()
|
|||||||
|
|
||||||
// NPAL16631: if ( !memoryLack )
|
// NPAL16631: if ( !memoryLack )
|
||||||
{
|
{
|
||||||
SMESH::ModifiedMesh( aMeshSObj,
|
_PTR(SObject) sobj = SMESH::GetActiveStudyDocument()->FindObjectID(myIObject->getEntry());
|
||||||
|
SMESH::ModifiedMesh( sobj,
|
||||||
!computeFailed && aHypErrors.isEmpty(),
|
!computeFailed && aHypErrors.isEmpty(),
|
||||||
myMesh->NbNodes() == 0);
|
myMesh->NbNodes() == 0);
|
||||||
update( UF_ObjBrowser | UF_Model );
|
update( UF_ObjBrowser | UF_Model );
|
||||||
@ -1245,8 +1260,9 @@ void SMESHGUI_BaseComputeOp::stopOperation()
|
|||||||
|
|
||||||
void SMESHGUI_BaseComputeOp::onPublishShape()
|
void SMESHGUI_BaseComputeOp::onPublishShape()
|
||||||
{
|
{
|
||||||
GEOM::GEOM_Gen_var geomGen = SMESH::GetGEOMGen();
|
GEOM::GEOM_Gen_var geomGen = SMESH::GetGEOMGen();
|
||||||
SALOMEDS::Study_var study = SMESHGUI::GetSMESHGen()->GetCurrentStudy();
|
SALOMEDS::Study_var study = SMESHGUI::GetSMESHGen()->GetCurrentStudy();
|
||||||
|
GEOM::GEOM_Object_var meshShape = myMesh->GetShapeToMesh();
|
||||||
|
|
||||||
QStringList entryList;
|
QStringList entryList;
|
||||||
QList<int> rows;
|
QList<int> rows;
|
||||||
@ -1754,14 +1770,15 @@ void SMESHGUI_PrecomputeOp::initDialog()
|
|||||||
*/
|
*/
|
||||||
//================================================================================
|
//================================================================================
|
||||||
|
|
||||||
void SMESHGUI_PrecomputeOp::getAssignedAlgos(_PTR(SObject) theMesh,
|
void SMESHGUI_PrecomputeOp::getAssignedAlgos(_PTR(SObject) theMesh,
|
||||||
QMap<int,int>& theModeMap)
|
QMap<int,int>& theModeMap)
|
||||||
{
|
{
|
||||||
if ( !theMesh ) return;
|
if ( !theMesh ) return;
|
||||||
|
|
||||||
_PTR(SObject) aHypFolder;
|
_PTR(SObject) aHypFolder;
|
||||||
_PTR(GenericAttribute) anAttr;
|
_PTR(GenericAttribute) anAttr;
|
||||||
int aPart = SMESH::Tag_RefOnAppliedAlgorithms;
|
int aPart = SMESH::Tag_RefOnAppliedAlgorithms;
|
||||||
if ( theMesh->FindSubObject( aPart, aHypFolder ) )
|
if ( theMesh->FindSubObject( aPart, aHypFolder ))
|
||||||
{
|
{
|
||||||
_PTR(ChildIterator) anIter =
|
_PTR(ChildIterator) anIter =
|
||||||
SMESH::GetActiveStudyDocument()->NewChildIterator( aHypFolder );
|
SMESH::GetActiveStudyDocument()->NewChildIterator( aHypFolder );
|
||||||
|
@ -112,6 +112,7 @@ private:
|
|||||||
protected:
|
protected:
|
||||||
SMESH::SMESH_Mesh_var myMesh;
|
SMESH::SMESH_Mesh_var myMesh;
|
||||||
GEOM::GEOM_Object_var myMainShape;
|
GEOM::GEOM_Object_var myMainShape;
|
||||||
|
GEOM::GEOM_Object_var myCurShape;
|
||||||
SMESH::TShapeDisplayer* myTShapeDisplayer;
|
SMESH::TShapeDisplayer* myTShapeDisplayer;
|
||||||
SMESHGUI_MeshEditPreview* myBadMeshDisplayer;
|
SMESHGUI_MeshEditPreview* myBadMeshDisplayer;
|
||||||
Handle(SALOME_InteractiveObject) myIObject;
|
Handle(SALOME_InteractiveObject) myIObject;
|
||||||
|
@ -624,12 +624,32 @@ SMESHGUI_MeshDlg::SMESHGUI_MeshDlg( const bool theToCreate, const bool theIsMesh
|
|||||||
objectWg( Mesh, Btn )->hide();
|
objectWg( Mesh, Btn )->hide();
|
||||||
objectWg( Geom, Btn )->hide();
|
objectWg( Geom, Btn )->hide();
|
||||||
}
|
}
|
||||||
|
setTitile( theToCreate, theIsMesh );
|
||||||
}
|
}
|
||||||
|
|
||||||
SMESHGUI_MeshDlg::~SMESHGUI_MeshDlg()
|
SMESHGUI_MeshDlg::~SMESHGUI_MeshDlg()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Set dialog title
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
|
||||||
|
void SMESHGUI_MeshDlg::setTitile( const bool theToCreate, const bool theIsMesh )
|
||||||
|
{
|
||||||
|
if ( theToCreate )
|
||||||
|
{
|
||||||
|
setWindowTitle( tr( theIsMesh ? "CREATE_MESH" : "CREATE_SUBMESH" ));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
setWindowTitle( tr( theIsMesh ? "EDIT_MESH" : "EDIT_SUBMESH") );
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief Gets tab with given id
|
* \brief Gets tab with given id
|
||||||
|
@ -78,6 +78,7 @@ public:
|
|||||||
void setAvailableMeshType(const QStringList& );
|
void setAvailableMeshType(const QStringList& );
|
||||||
int currentMeshType();
|
int currentMeshType();
|
||||||
void setCurrentMeshType( const int );
|
void setCurrentMeshType( const int );
|
||||||
|
void setTitile( const bool, const bool );
|
||||||
|
|
||||||
signals:
|
signals:
|
||||||
void hypoSet( const QString& );
|
void hypoSet( const QString& );
|
||||||
|
@ -638,13 +638,14 @@ void SMESHGUI_MeshOp::selectionDone()
|
|||||||
{
|
{
|
||||||
SMESH::SMESH_subMesh_var submeshVar =
|
SMESH::SMESH_subMesh_var submeshVar =
|
||||||
SMESH::SMESH_subMesh::_narrow( _CAST( SObject,pObj )->GetObject() );
|
SMESH::SMESH_subMesh::_narrow( _CAST( SObject,pObj )->GetObject() );
|
||||||
|
myIsMesh = submeshVar->_is_nil();
|
||||||
|
myDlg->setTitile( myToCreate, myIsMesh );
|
||||||
myDlg->setObjectShown( SMESHGUI_MeshDlg::Mesh, !submeshVar->_is_nil() );
|
myDlg->setObjectShown( SMESHGUI_MeshDlg::Mesh, !submeshVar->_is_nil() );
|
||||||
myDlg->setObjectShown( SMESHGUI_MeshDlg::Geom, true );
|
myDlg->setObjectShown( SMESHGUI_MeshDlg::Geom, true );
|
||||||
myDlg->objectWg( SMESHGUI_MeshDlg::Mesh, SMESHGUI_MeshDlg::Btn )->hide();
|
myDlg->objectWg( SMESHGUI_MeshDlg::Mesh, SMESHGUI_MeshDlg::Btn )->hide();
|
||||||
myDlg->objectWg( SMESHGUI_MeshDlg::Geom, SMESHGUI_MeshDlg::Btn )->hide();
|
myDlg->objectWg( SMESHGUI_MeshDlg::Geom, SMESHGUI_MeshDlg::Btn )->hide();
|
||||||
myDlg->updateGeometry();
|
myDlg->updateGeometry();
|
||||||
myDlg->adjustSize();
|
myDlg->adjustSize();
|
||||||
myIsMesh = submeshVar->_is_nil();
|
|
||||||
readMesh();
|
readMesh();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -69,12 +69,15 @@ namespace SMESHOp {
|
|||||||
OpCreateMesh = 2030, // MENU MESH - CREATE MESH
|
OpCreateMesh = 2030, // MENU MESH - CREATE MESH
|
||||||
OpCreateSubMesh = 2031, // MENU MESH - CREATE SUBMESH
|
OpCreateSubMesh = 2031, // MENU MESH - CREATE SUBMESH
|
||||||
OpEditMeshOrSubMesh = 2032, // MENU MESH - EDIT MESH/SUBMESH
|
OpEditMeshOrSubMesh = 2032, // MENU MESH - EDIT MESH/SUBMESH
|
||||||
OpBuildCompoundMesh = 2033, // MENU MESH - BUILD COMPOUND
|
OpEditMesh = 2033, // POPUP - EDIT MESH
|
||||||
OpCopyMesh = 2034, // MENU MESH - COPY MESH
|
OpEditSubMesh = 2034, // POPUP - EDIT SUBMESH
|
||||||
|
OpBuildCompoundMesh = 2035, // MENU MESH - BUILD COMPOUND
|
||||||
|
OpCopyMesh = 2036, // MENU MESH - COPY MESH
|
||||||
OpCompute = 2040, // MENU MESH - COMPUTE
|
OpCompute = 2040, // MENU MESH - COMPUTE
|
||||||
OpPreCompute = 2041, // MENU MESH - PREVIEW
|
OpComputeSubMesh = 2041, // POPUP - COMPUTE SUBMESH
|
||||||
OpEvaluate = 2042, // MENU MESH - EVALUATE
|
OpPreCompute = 2042, // MENU MESH - PREVIEW
|
||||||
OpMeshOrder = 2043, // MENU MESH - CHANGE SUBMESH PRIORITY
|
OpEvaluate = 2043, // MENU MESH - EVALUATE
|
||||||
|
OpMeshOrder = 2044, // MENU MESH - CHANGE SUBMESH PRIORITY
|
||||||
OpCreateGroup = 2050, // MENU MESH - CREATE GROUP
|
OpCreateGroup = 2050, // MENU MESH - CREATE GROUP
|
||||||
OpCreateGeometryGroup = 2051, // MENU MESH - CREATE GROUPS FROM GEOMETRY
|
OpCreateGeometryGroup = 2051, // MENU MESH - CREATE GROUPS FROM GEOMETRY
|
||||||
OpConstructGroup = 2052, // MENU MESH - CONSTRUCT GROUP
|
OpConstructGroup = 2052, // MENU MESH - CONSTRUCT GROUP
|
||||||
|
@ -518,11 +518,18 @@ int SMESHGUI_Selection::dim( int ind ) const
|
|||||||
|
|
||||||
bool SMESHGUI_Selection::isComputable( int ind ) const
|
bool SMESHGUI_Selection::isComputable( int ind ) const
|
||||||
{
|
{
|
||||||
if ( ind >= 0 && ind < myTypes.count() && myTypes[ind] == "Mesh" )
|
if ( ind >= 0 && ind < myTypes.count() && ( myTypes[ind] == "Mesh" ||
|
||||||
|
myTypes[ind].startsWith("Mesh " )))
|
||||||
{
|
{
|
||||||
QMap<int,int> modeMap;
|
QMap<int,int> modeMap;
|
||||||
_PTR(SObject) so = SMESH::GetActiveStudyDocument()->FindObjectID( entry( ind ).toLatin1().data() );
|
_PTR(SObject) meshSO = SMESH::GetActiveStudyDocument()->FindObjectID( entry( ind ).toLatin1().data() );
|
||||||
SMESHGUI_PrecomputeOp::getAssignedAlgos( so, modeMap );
|
|
||||||
|
_PTR(SComponent) component = meshSO->GetFatherComponent();
|
||||||
|
if ( meshSO->Depth() - component->Depth() > 1 ) // sub-mesh, get a mesh
|
||||||
|
while ( meshSO->Depth() - component->Depth() > 1 )
|
||||||
|
meshSO = meshSO->GetFather();
|
||||||
|
|
||||||
|
SMESHGUI_PrecomputeOp::getAssignedAlgos( meshSO, modeMap );
|
||||||
return modeMap.size() > 0;
|
return modeMap.size() > 0;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -256,6 +256,10 @@
|
|||||||
<source>MEN_COMPUTE</source>
|
<source>MEN_COMPUTE</source>
|
||||||
<translation>Compute</translation>
|
<translation>Compute</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_COMPUTE_SUBMESH</source>
|
||||||
|
<translation>Compute Sub-mesh</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>MEN_PRECOMPUTE</source>
|
<source>MEN_PRECOMPUTE</source>
|
||||||
<translation>Preview</translation>
|
<translation>Preview</translation>
|
||||||
@ -420,6 +424,14 @@
|
|||||||
<source>MEN_EDIT_MESHSUBMESH</source>
|
<source>MEN_EDIT_MESHSUBMESH</source>
|
||||||
<translation>Edit Mesh/Sub-mesh</translation>
|
<translation>Edit Mesh/Sub-mesh</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_EDIT_MESH</source>
|
||||||
|
<translation>Edit Mesh</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_EDIT_SUBMESH</source>
|
||||||
|
<translation>Edit Sub-mesh</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>MEN_EXPORT</source>
|
<source>MEN_EXPORT</source>
|
||||||
<translation>Export</translation>
|
<translation>Export</translation>
|
||||||
@ -2929,6 +2941,10 @@ Use Display Entity menu command to show them.
|
|||||||
<source>STB_COMPUTE</source>
|
<source>STB_COMPUTE</source>
|
||||||
<translation>Compute</translation>
|
<translation>Compute</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>STB_COMPUTE_SUBMESH</source>
|
||||||
|
<translation>Compute Sub-mesh</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>STB_PRECOMPUTE</source>
|
<source>STB_PRECOMPUTE</source>
|
||||||
<translation>Preview</translation>
|
<translation>Preview</translation>
|
||||||
@ -3061,6 +3077,14 @@ Use Display Entity menu command to show them.
|
|||||||
<source>STB_EDIT_MESHSUBMESH</source>
|
<source>STB_EDIT_MESHSUBMESH</source>
|
||||||
<translation>Edit Mesh/Sub-mesh</translation>
|
<translation>Edit Mesh/Sub-mesh</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>STB_EDIT_MESH</source>
|
||||||
|
<translation>Edit Mesh</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>STB_EDIT_SUBMESH</source>
|
||||||
|
<translation>Edit Sub-mesh</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>STB_EXPORT_DAT</source>
|
<source>STB_EXPORT_DAT</source>
|
||||||
<translation>Export to DAT file</translation>
|
<translation>Export to DAT file</translation>
|
||||||
@ -3597,6 +3621,10 @@ Use Display Entity menu command to show them.
|
|||||||
<source>TOP_COMPUTE</source>
|
<source>TOP_COMPUTE</source>
|
||||||
<translation>Compute</translation>
|
<translation>Compute</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>TOP_COMPUTE_SUBMESH</source>
|
||||||
|
<translation>Compute Sub-mesh</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>TOP_PRECOMPUTE</source>
|
<source>TOP_PRECOMPUTE</source>
|
||||||
<translation>Preview</translation>
|
<translation>Preview</translation>
|
||||||
@ -3729,6 +3757,14 @@ Use Display Entity menu command to show them.
|
|||||||
<source>TOP_EDIT_MESHSUBMESH</source>
|
<source>TOP_EDIT_MESHSUBMESH</source>
|
||||||
<translation>Edit Mesh/Sub-mesh</translation>
|
<translation>Edit Mesh/Sub-mesh</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>TOP_EDIT_MESH</source>
|
||||||
|
<translation>Edit Mesh</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>TOP_EDIT_SUBMESH</source>
|
||||||
|
<translation>Edit Sub-mesh</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>TOP_EXPORT_DAT</source>
|
<source>TOP_EXPORT_DAT</source>
|
||||||
<translation>Export to DAT file</translation>
|
<translation>Export to DAT file</translation>
|
||||||
@ -6132,8 +6168,12 @@ Please specify them and try again</translation>
|
|||||||
<translation>3D</translation>
|
<translation>3D</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>EDIT_MESH_SUBMESH</source>
|
<source>EDIT_MESH</source>
|
||||||
<translation>Edit mesh/sub-mesh</translation>
|
<translation>Edit mesh</translation>
|
||||||
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>EDIT_SUBMESH</source>
|
||||||
|
<translation>Edit sub-mesh</translation>
|
||||||
</message>
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>GEOMETRY</source>
|
<source>GEOMETRY</source>
|
||||||
|
@ -1916,8 +1916,8 @@ CORBA::Boolean SMESH_Gen_i::Compute( SMESH::SMESH_Mesh_ptr theMesh,
|
|||||||
myLocShape = SMESH_Mesh::PseudoShape();
|
myLocShape = SMESH_Mesh::PseudoShape();
|
||||||
// call implementation compute
|
// call implementation compute
|
||||||
::SMESH_Mesh& myLocMesh = meshServant->GetImpl();
|
::SMESH_Mesh& myLocMesh = meshServant->GetImpl();
|
||||||
myGen.PrepareCompute( myLocMesh, myLocShape);
|
myGen.PrepareCompute( myLocMesh, myLocShape );
|
||||||
bool ok = myGen.Compute( myLocMesh, myLocShape);
|
bool ok = myGen.Compute( myLocMesh, myLocShape, myLocShape != myLocMesh.GetShapeToMesh());
|
||||||
meshServant->CreateGroupServants(); // algos can create groups (issue 0020918)
|
meshServant->CreateGroupServants(); // algos can create groups (issue 0020918)
|
||||||
myLocMesh.GetMeshDS()->Modified();
|
myLocMesh.GetMeshDS()->Modified();
|
||||||
return ok;
|
return ok;
|
||||||
|
@ -1497,11 +1497,12 @@ class Mesh:
|
|||||||
print allReasons
|
print allReasons
|
||||||
pass
|
pass
|
||||||
if salome.sg.hasDesktop() and self.mesh.GetStudyId() >= 0:
|
if salome.sg.hasDesktop() and self.mesh.GetStudyId() >= 0:
|
||||||
smeshgui = salome.ImportComponentGUI("SMESH")
|
if not isinstance( refresh, list): # not a call from subMesh.Compute()
|
||||||
smeshgui.Init(self.mesh.GetStudyId())
|
smeshgui = salome.ImportComponentGUI("SMESH")
|
||||||
smeshgui.SetMeshIcon( salome.ObjectToID( self.mesh ), ok, (self.NbNodes()==0) )
|
smeshgui.Init(self.mesh.GetStudyId())
|
||||||
if refresh: salome.sg.updateObjBrowser(1)
|
smeshgui.SetMeshIcon( salome.ObjectToID( self.mesh ), ok, (self.NbNodes()==0) )
|
||||||
pass
|
if refresh: salome.sg.updateObjBrowser(1)
|
||||||
|
|
||||||
return ok
|
return ok
|
||||||
|
|
||||||
## Return a list of error messages (SMESH.ComputeError) of the last Compute()
|
## Return a list of error messages (SMESH.ComputeError) of the last Compute()
|
||||||
@ -5001,7 +5002,7 @@ class Mesh:
|
|||||||
pass # end of Mesh class
|
pass # end of Mesh class
|
||||||
|
|
||||||
|
|
||||||
## class used to compensate change of CORBA API of SMESH_Mesh for backward compatibility
|
## Class used to compensate change of CORBA API of SMESH_Mesh for backward compatibility
|
||||||
# with old dump scripts which call SMESH_Mesh directly and not via smeshBuilder.Mesh
|
# with old dump scripts which call SMESH_Mesh directly and not via smeshBuilder.Mesh
|
||||||
#
|
#
|
||||||
class meshProxy(SMESH._objref_SMESH_Mesh):
|
class meshProxy(SMESH._objref_SMESH_Mesh):
|
||||||
@ -5017,7 +5018,40 @@ class meshProxy(SMESH._objref_SMESH_Mesh):
|
|||||||
pass
|
pass
|
||||||
omniORB.registerObjref(SMESH._objref_SMESH_Mesh._NP_RepositoryId, meshProxy)
|
omniORB.registerObjref(SMESH._objref_SMESH_Mesh._NP_RepositoryId, meshProxy)
|
||||||
|
|
||||||
## class used to compensate change of CORBA API of SMESH_MeshEditor for backward compatibility
|
|
||||||
|
## Class wrapping SMESH_SubMesh in order to add Compute()
|
||||||
|
#
|
||||||
|
class submeshProxy(SMESH._objref_SMESH_subMesh):
|
||||||
|
def __init__(self):
|
||||||
|
SMESH._objref_SMESH_subMesh.__init__(self)
|
||||||
|
self.mesh = None
|
||||||
|
def __deepcopy__(self, memo=None):
|
||||||
|
new = self.__class__()
|
||||||
|
return new
|
||||||
|
|
||||||
|
## Computes the sub-mesh and returns the status of the computation
|
||||||
|
# @param refresh if @c True, Object browser is automatically updated (when running in GUI)
|
||||||
|
# @return True or False
|
||||||
|
# @ingroup l2_construct
|
||||||
|
def Compute(self,refresh=False):
|
||||||
|
if not self.mesh:
|
||||||
|
self.mesh = Mesh( smeshBuilder(), None, self.GetMesh())
|
||||||
|
|
||||||
|
ok = self.mesh.Compute( self.GetSubShape(),refresh=[] )
|
||||||
|
|
||||||
|
if salome.sg.hasDesktop() and self.mesh.GetStudyId() >= 0:
|
||||||
|
smeshgui = salome.ImportComponentGUI("SMESH")
|
||||||
|
smeshgui.Init(self.mesh.GetStudyId())
|
||||||
|
smeshgui.SetMeshIcon( salome.ObjectToID( self ), ok, (self.GetNumberOfElements()==0) )
|
||||||
|
if refresh: salome.sg.updateObjBrowser(1)
|
||||||
|
pass
|
||||||
|
|
||||||
|
return ok
|
||||||
|
pass
|
||||||
|
omniORB.registerObjref(SMESH._objref_SMESH_subMesh._NP_RepositoryId, submeshProxy)
|
||||||
|
|
||||||
|
|
||||||
|
## Class used to compensate change of CORBA API of SMESH_MeshEditor for backward compatibility
|
||||||
# with old dump scripts which call SMESH_MeshEditor directly and not via smeshBuilder.Mesh
|
# with old dump scripts which call SMESH_MeshEditor directly and not via smeshBuilder.Mesh
|
||||||
#
|
#
|
||||||
class meshEditor(SMESH._objref_SMESH_MeshEditor):
|
class meshEditor(SMESH._objref_SMESH_MeshEditor):
|
||||||
@ -5129,7 +5163,7 @@ class algoCreator:
|
|||||||
raise RuntimeError, "No class found for algo type %s" % algoType
|
raise RuntimeError, "No class found for algo type %s" % algoType
|
||||||
return None
|
return None
|
||||||
|
|
||||||
# Private class used to substitute and store variable parameters of hypotheses.
|
## Private class used to substitute and store variable parameters of hypotheses.
|
||||||
#
|
#
|
||||||
class hypMethodWrapper:
|
class hypMethodWrapper:
|
||||||
def __init__(self, hyp, method):
|
def __init__(self, hyp, method):
|
||||||
@ -5160,7 +5194,8 @@ class hypMethodWrapper:
|
|||||||
return result
|
return result
|
||||||
pass
|
pass
|
||||||
|
|
||||||
# A helper class that call UnRegister() of SALOME.GenericObj'es stored in it
|
## A helper class that call UnRegister() of SALOME.GenericObj'es stored in it
|
||||||
|
#
|
||||||
class genObjUnRegister:
|
class genObjUnRegister:
|
||||||
|
|
||||||
def __init__(self, genObj=None):
|
def __init__(self, genObj=None):
|
||||||
@ -5181,6 +5216,9 @@ class genObjUnRegister:
|
|||||||
if genObj and hasattr( genObj, "UnRegister" ):
|
if genObj and hasattr( genObj, "UnRegister" ):
|
||||||
genObj.UnRegister()
|
genObj.UnRegister()
|
||||||
|
|
||||||
|
|
||||||
|
## Bind methods creating mesher plug-ins to the Mesh class
|
||||||
|
#
|
||||||
for pluginName in os.environ[ "SMESH_MeshersList" ].split( ":" ):
|
for pluginName in os.environ[ "SMESH_MeshersList" ].split( ":" ):
|
||||||
#
|
#
|
||||||
#print "pluginName: ", pluginName
|
#print "pluginName: ", pluginName
|
||||||
|
@ -1202,7 +1202,7 @@ bool StdMeshers_RadialQuadrangle_1D2D::IsApplicable( const TopoDS_Shape & aShape
|
|||||||
for (TopExp_Explorer exp( aShape, TopAbs_FACE ); exp.More(); exp.Next(), ++nbFoundFaces )
|
for (TopExp_Explorer exp( aShape, TopAbs_FACE ); exp.More(); exp.Next(), ++nbFoundFaces )
|
||||||
{
|
{
|
||||||
StdMeshers_FaceSidePtr circSide, linSide1, linSide2;
|
StdMeshers_FaceSidePtr circSide, linSide1, linSide2;
|
||||||
int nbSides = analyseFace( aShape, NULL, circSide, linSide1, linSide2 );
|
int nbSides = analyseFace( exp.Current(), NULL, circSide, linSide1, linSide2 );
|
||||||
bool ok = ( 0 < nbSides && nbSides <= 3 &&
|
bool ok = ( 0 < nbSides && nbSides <= 3 &&
|
||||||
isCornerInsideCircle( circSide, linSide1, linSide2 ));
|
isCornerInsideCircle( circSide, linSide1, linSide2 ));
|
||||||
if( toCheckAll && !ok ) return false;
|
if( toCheckAll && !ok ) return false;
|
||||||
|
Loading…
Reference in New Issue
Block a user