23570: EDF17299 - Problem with filters

+ fix persistence of Group on Filter
+ minor fix of docs
This commit is contained in:
eap 2018-06-29 16:38:39 +03:00
parent f816f204d3
commit 074862c213
8 changed files with 17 additions and 11 deletions

View File

@ -4,7 +4,7 @@ salome.salome_init()
### create geometry ### create geometry
from salome.geom import geomBuilder from salome.geom import geomBuilder
geompy = geomBuilder.New(salome.myStudy) geompy = geomBuilder.New()
Box_1 = geompy.MakeBoxDXDYDZ(200, 200, 200) Box_1 = geompy.MakeBoxDXDYDZ(200, 200, 200)
geompy.addToStudy( Box_1, 'Box_1' ) geompy.addToStudy( Box_1, 'Box_1' )
@ -13,7 +13,7 @@ geompy.addToStudy( Box_1, 'Box_1' )
import SMESH import SMESH
from salome.smesh import smeshBuilder from salome.smesh import smeshBuilder
smesh = smeshBuilder.New(salome.myStudy) smesh = smeshBuilder.New()
Mesh_1 = smesh.Mesh( Box_1 ) Mesh_1 = smesh.Mesh( Box_1 )
Mesh_1.Segment().NumberOfSegments(15) Mesh_1.Segment().NumberOfSegments(15)

View File

@ -4,9 +4,9 @@ import salome
salome.salome_init() salome.salome_init()
from salome.geom import geomBuilder from salome.geom import geomBuilder
geompy = geomBuilder.New(salome.myStudy) geompy = geomBuilder.New()
from salome.smesh import smeshBuilder from salome.smesh import smeshBuilder
smesh = smeshBuilder.New(salome.myStudy) smesh = smeshBuilder.New()
# mesh a hexahedral mesh # mesh a hexahedral mesh
box = geompy.MakeBoxDXDYDZ (1, 1, 1 ) box = geompy.MakeBoxDXDYDZ (1, 1, 1 )

View File

@ -3,10 +3,10 @@
import salome import salome
salome.salome_init() salome.salome_init()
from salome.geom import geomBuilder from salome.geom import geomBuilder
geompy = geomBuilder.New(salome.myStudy) geompy = geomBuilder.New()
import SMESH import SMESH
from salome.smesh import smeshBuilder from salome.smesh import smeshBuilder
smesh = smeshBuilder.New(salome.myStudy) smesh = smeshBuilder.New()
# Create geometry: hollow sphere # Create geometry: hollow sphere

View File

@ -15,7 +15,9 @@ different meshing parameters than those assigned to the main shape.
Structurally, the sub-mesh is a mesh on a certain sub-shape, or a group of Structurally, the sub-mesh is a mesh on a certain sub-shape, or a group of
sub-shapes, possibly generated using different meshing algorithms sub-shapes, possibly generated using different meshing algorithms
and/or hypotheses than those used to generate the mesh on other and/or hypotheses than those used to generate the mesh on other
sub-shapes. sub-shapes. Elements generated on a sub-shape can be retrieved without
explicit creation of a sub-mesh by creating a *Group on Geometry* using
:ref:`Create Groups from Geometry <create_groups_from_geometry_page>` dialog.
Creation of a sub-mesh allows to control individually meshing of a 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

View File

@ -11,7 +11,7 @@ Documentation of SALOME Mesh module Python API is available in two forms:
- :doc:`Structured documentation <modules>`, where all methods and classes are grouped by their functionality. - :doc:`Structured documentation <modules>`, where all methods and classes are grouped by their functionality.
- :ref:`Linear documentation <modindex>` grouped only by classes, declared in the :mod:`smeshBuilder` and :mod:`StdMeshersBuilder` Python packages. - :ref:`Linear documentation <modindex>` grouped only by classes, declared in the :mod:`smeshBuilder` Python module.
With SALOME 7.2, the Python interface for Mesh has been slightly modified to offer new functionality. With SALOME 7.2, the Python interface for Mesh has been slightly modified to offer new functionality.
You may have to modify your scripts generated with SALOME 6 or older versions. You may have to modify your scripts generated with SALOME 6 or older versions.
@ -73,7 +73,7 @@ by calling *dir()* Python built-in function.
All methods of the Mesh Group can be found in :ref:`tui_create_standalone_group` sample script. All methods of the Mesh Group can be found in :ref:`tui_create_standalone_group` sample script.
An example below demonstrates usage of the Python API for 3d mesh An example below demonstrates usage of the Python API for 3D mesh
generation and for retrieving information on mesh nodes and elements. generation and for retrieving information on mesh nodes and elements.
.. _example_3d_mesh: .. _example_3d_mesh:

View File

@ -4567,6 +4567,7 @@ ElementsOnShape::Classifier::~Classifier()
bool ElementsOnShape::Classifier::isOutOfSolid (const gp_Pnt& p) bool ElementsOnShape::Classifier::isOutOfSolid (const gp_Pnt& p)
{ {
if ( isOutOfBox( p )) return true;
mySolidClfr->Perform( p, myTol ); mySolidClfr->Perform( p, myTol );
return ( mySolidClfr->State() != TopAbs_IN && mySolidClfr->State() != TopAbs_ON ); return ( mySolidClfr->State() != TopAbs_IN && mySolidClfr->State() != TopAbs_ON );
} }
@ -4578,6 +4579,7 @@ bool ElementsOnShape::Classifier::isOutOfBox (const gp_Pnt& p)
bool ElementsOnShape::Classifier::isOutOfFace (const gp_Pnt& p) bool ElementsOnShape::Classifier::isOutOfFace (const gp_Pnt& p)
{ {
if ( isOutOfBox( p )) return true;
myProjFace.Perform( p ); myProjFace.Perform( p );
if ( myProjFace.IsDone() && myProjFace.LowerDistance() <= myTol ) if ( myProjFace.IsDone() && myProjFace.LowerDistance() <= myTol )
{ {
@ -4594,6 +4596,7 @@ bool ElementsOnShape::Classifier::isOutOfFace (const gp_Pnt& p)
bool ElementsOnShape::Classifier::isOutOfEdge (const gp_Pnt& p) bool ElementsOnShape::Classifier::isOutOfEdge (const gp_Pnt& p)
{ {
if ( isOutOfBox( p )) return true;
myProjEdge.Perform( p ); myProjEdge.Perform( p );
return ! ( myProjEdge.NbPoints() > 0 && myProjEdge.LowerDistance() <= myTol ); return ! ( myProjEdge.NbPoints() > 0 && myProjEdge.LowerDistance() <= myTol );
} }

View File

@ -61,7 +61,7 @@ using namespace std;
namespace namespace
{ {
enum { GroupOnFilter_OutOfDate = -1 }; enum { GroupOnFilter_OutOfDate = -777 };
// count not yet loaded meshes // count not yet loaded meshes
static int theMeshCounter = 0; static int theMeshCounter = 0;
@ -254,7 +254,7 @@ namespace
std::vector<int> data; std::vector<int> data;
for ( size_t i = 0; i < meshInfo->length(); ++i ) for ( size_t i = 0; i < meshInfo->length(); ++i )
if ( meshInfo[i] > 0 ) if ( meshInfo[i] > 0 || meshInfo[i] == GroupOnFilter_OutOfDate )
{ {
data.push_back( DriverMED::GetMedGeoType( SMDSAbs_EntityType( i ))); //medTypes[ i ] ); data.push_back( DriverMED::GetMedGeoType( SMDSAbs_EntityType( i ))); //medTypes[ i ] );
data.push_back( meshInfo[ i ] ); data.push_back( meshInfo[ i ] );

View File

@ -74,6 +74,7 @@ class Mesh_Algorithm:
""" """
Finds a hypothesis in the study by its type name and parameters. Finds a hypothesis in the study by its type name and parameters.
Finds only the hypotheses created in smeshBuilder engine. Finds only the hypotheses created in smeshBuilder engine.
Returns: Returns:
:class:`~SMESH.SMESH_Hypothesis` :class:`~SMESH.SMESH_Hypothesis`
""" """