mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-26 23:00:32 +05:00
PAL0023627: [IMACS] ASERIS: project point to the mesh
This commit is contained in:
parent
db0762b147
commit
858b4bff64
@ -773,6 +773,20 @@ module SMESH
|
||||
in ElementType type)
|
||||
raises (SALOME::SALOME_Exception);
|
||||
|
||||
/*!
|
||||
* Project a point to a mesh object.
|
||||
* Return ID of an element of given type where the given point is projected
|
||||
* and coordinates of the projection point.
|
||||
* In the case if nothing found, return -1 and []
|
||||
*/
|
||||
long ProjectPoint(in double x,
|
||||
in double y,
|
||||
in double z,
|
||||
in SMESH_IDSource meshObject,
|
||||
in ElementType type,
|
||||
out double_array projecton)
|
||||
raises (SALOME::SALOME_Exception);
|
||||
|
||||
/*!
|
||||
* Return point state in a closed 2D mesh in terms of TopAbs_State enumeration.
|
||||
* TopAbs_UNKNOWN state means that either mesh is wrong or the analysis fails.
|
||||
|
@ -1243,11 +1243,11 @@ gp_XYZ SMESH_ElementSearcherImpl::Project(const gp_Pnt& point,
|
||||
|
||||
ElementBndBoxTree*& ebbTree = _ebbTree[ _elementType ];
|
||||
if ( !ebbTree )
|
||||
ebbTree = new ElementBndBoxTree( *_mesh, _elementType );
|
||||
ebbTree = new ElementBndBoxTree( *_mesh, _elementType, _meshPartIt );
|
||||
|
||||
gp_XYZ p = point.XYZ();
|
||||
ElementBndBoxTree* ebbLeaf = ebbTree->getLeafAtPoint( p );
|
||||
const Bnd_B3d* box = ebbLeaf->getBox();
|
||||
const Bnd_B3d* box = ebbLeaf ? ebbLeaf->getBox() : ebbTree->getBox();
|
||||
double radius = ( box->CornerMax() - box->CornerMin() ).Modulus();
|
||||
|
||||
ElementBndBoxTree::TElemSeq elems;
|
||||
|
@ -178,7 +178,7 @@ namespace MeshEditor_I {
|
||||
|
||||
//=============================================================================
|
||||
/*!
|
||||
* \brief Deleter of theNodeSearcher at any compute event occurred
|
||||
* \brief Deleter of theNodeSearcher and theElementSearcher at any compute event occurred
|
||||
*/
|
||||
//=============================================================================
|
||||
|
||||
@ -381,7 +381,7 @@ namespace MeshEditor_I {
|
||||
*/
|
||||
//================================================================================
|
||||
|
||||
string getPartIOR( SMESH::SMESH_IDSource_ptr theMeshPart, SMESH::ElementType type)
|
||||
string getPartIOR( SMESH::SMESH_IDSource_ptr theMeshPart, SMESH::ElementType type = SMESH::ALL )
|
||||
{
|
||||
string partIOR = SMESH_Gen_i::GetORB()->object_to_string( theMeshPart );
|
||||
if ( SMESH_Group_i* group_i = SMESH::DownCast<SMESH_Group_i*>( theMeshPart ))
|
||||
@ -4652,6 +4652,68 @@ SMESH_MeshEditor_i::FindAmongElementsByPoint(SMESH::SMESH_IDSource_ptr elementID
|
||||
return 0;
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : ProjectPoint
|
||||
//purpose : Project a point to a mesh object.
|
||||
// Return ID of an element of given type where the given point is projected
|
||||
// and coordinates of the projection point.
|
||||
// In the case if nothing found, return -1 and []
|
||||
//=======================================================================
|
||||
|
||||
CORBA::Long SMESH_MeshEditor_i::ProjectPoint(CORBA::Double x,
|
||||
CORBA::Double y,
|
||||
CORBA::Double z,
|
||||
SMESH::SMESH_IDSource_ptr meshObject,
|
||||
SMESH::ElementType type,
|
||||
SMESH::double_array_out projecton)
|
||||
throw (SALOME::SALOME_Exception)
|
||||
{
|
||||
if ( CORBA::is_nil( meshObject ))
|
||||
THROW_SALOME_CORBA_EXCEPTION("NULL meshObject", SALOME::BAD_PARAM);
|
||||
|
||||
SMESH_TRY;
|
||||
|
||||
SMESH::SMESH_Mesh_var mesh = meshObject->GetMesh();
|
||||
SMESH_Mesh_i* mesh_i = SMESH::DownCast<SMESH_Mesh_i*>( mesh );
|
||||
if ( mesh_i != myMesh_i )
|
||||
{
|
||||
SMESH::SMESH_MeshEditor_var editor=
|
||||
myIsPreviewMode ? mesh_i->GetMeshEditPreviewer() : mesh_i->GetMeshEditor();
|
||||
return editor->ProjectPoint( x,y,z, meshObject, type, projecton );
|
||||
}
|
||||
|
||||
|
||||
theSearchersDeleter.Set( myMesh, getPartIOR( meshObject ));
|
||||
if ( !theElementSearcher )
|
||||
{
|
||||
// create a searcher from meshObject
|
||||
|
||||
SMDS_ElemIteratorPtr elemIt;
|
||||
if ( ! SMESH::DownCast<SMESH_Mesh_i*>( meshObject ))
|
||||
elemIt = myMesh_i->GetElements( meshObject, type );
|
||||
|
||||
theElementSearcher = SMESH_MeshAlgos::GetElementSearcher( *getMeshDS(), elemIt );
|
||||
}
|
||||
|
||||
const SMDS_MeshElement* elem = 0;
|
||||
gp_XYZ pProj = theElementSearcher->Project( gp_Pnt( x,y,z ),
|
||||
SMDSAbs_ElementType( type ),
|
||||
&elem );
|
||||
|
||||
projecton = new SMESH::double_array();
|
||||
if ( elem && !elem->IsNull() )
|
||||
{
|
||||
projecton->length( 3 );
|
||||
projecton[0] = pProj.X();
|
||||
projecton[1] = pProj.Y();
|
||||
projecton[2] = pProj.Z();
|
||||
return elem->GetID();
|
||||
}
|
||||
|
||||
SMESH_CATCH( SMESH::throwCorbaException );
|
||||
return -1;
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
//function : GetPointState
|
||||
//purpose : Return point state in a closed 2D mesh in terms of TopAbs_State enumeration.
|
||||
|
@ -546,6 +546,20 @@ public:
|
||||
SMESH::ElementType type)
|
||||
throw (SALOME::SALOME_Exception);
|
||||
|
||||
/*!
|
||||
* Project a point to a mesh object.
|
||||
* Return ID of an element of given type where the given point is projected
|
||||
* and coordinates of the projection point.
|
||||
* In the case if nothing found, return -1 and []
|
||||
*/
|
||||
CORBA::Long ProjectPoint(CORBA::Double x,
|
||||
CORBA::Double y,
|
||||
CORBA::Double z,
|
||||
SMESH::SMESH_IDSource_ptr meshObject,
|
||||
SMESH::ElementType type,
|
||||
SMESH::double_array_out projecton)
|
||||
throw (SALOME::SALOME_Exception);
|
||||
|
||||
/*!
|
||||
* Return point state in a closed 2D mesh in terms of TopAbs_State enumeration.
|
||||
* TopAbs_UNKNOWN state means that either mesh is wrong or the analysis fails.
|
||||
|
@ -4228,6 +4228,17 @@ class Mesh(metaclass = MeshMeta):
|
||||
else:
|
||||
return self.editor.FindElementsByPoint(x, y, z, elementType)
|
||||
|
||||
def ProjectPoint(self, x,y,z, meshObject, elementType):
|
||||
"""
|
||||
Project a point to a mesh object.
|
||||
Return ID of an element of given type where the given point is projected
|
||||
and coordinates of the projection point.
|
||||
In the case if nothing found, return -1 and []
|
||||
"""
|
||||
if ( isinstance( meshObject, Mesh )):
|
||||
meshObject = meshObject.GetMesh()
|
||||
return self.editor.ProjectPoint( x,y,z, meshObject, elementType )
|
||||
|
||||
def GetPointState(self, x, y, z):
|
||||
"""
|
||||
Return point state in a closed 2D mesh in terms of TopAbs_State enumeration:
|
||||
|
Loading…
Reference in New Issue
Block a user