mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-15 12:00:33 +05:00
496 lines
16 KiB
C++
496 lines
16 KiB
C++
// Copyright (C) 2007-2024 CEA, EDF, OPEN CASCADE
|
|
//
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
|
//
|
|
// This library is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU Lesser General Public
|
|
// License as published by the Free Software Foundation; either
|
|
// version 2.1 of the License, or (at your option) any later version.
|
|
//
|
|
// This library is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
// Lesser General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU Lesser General Public
|
|
// License along with this library; if not, write to the Free Software
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
//
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
|
//
|
|
|
|
// SMESH StdMeshers_ImportSource1D : implementation of SMESH idl descriptions
|
|
// File : StdMeshers_ImportSource1D.cxx
|
|
// Module : SMESH
|
|
//
|
|
#include "StdMeshers_ImportSource.hxx"
|
|
|
|
#include "SMESHDS_GroupOnGeom.hxx"
|
|
#include "SMESHDS_Mesh.hxx"
|
|
#include "SMESH_Algo.hxx"
|
|
#include "SMESH_Gen.hxx"
|
|
#include "SMESH_Group.hxx"
|
|
#include "SMESH_Mesh.hxx"
|
|
#include "SMESH_subMeshEventListener.hxx"
|
|
|
|
#include "utilities.h"
|
|
|
|
#include <Standard_ErrorHandler.hxx>
|
|
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
using namespace std;
|
|
|
|
//=============================================================================
|
|
/*!
|
|
* Creates StdMeshers_ImportSource1D
|
|
*/
|
|
//=============================================================================
|
|
|
|
StdMeshers_ImportSource1D::StdMeshers_ImportSource1D(int hypId,
|
|
SMESH_Gen * gen)
|
|
:SMESH_Hypothesis(hypId, gen),
|
|
_toCopyMesh(false),
|
|
_toCopyGroups(false)
|
|
{
|
|
_name = "ImportSource1D";
|
|
_param_algo_dim = 1; // is used by StdMeshers_Import_1D;
|
|
}
|
|
|
|
//=============================================================================
|
|
/*!
|
|
* Creates StdMeshers_ImportSource2D
|
|
*/
|
|
//=============================================================================
|
|
|
|
StdMeshers_ImportSource2D::StdMeshers_ImportSource2D(int hypId,
|
|
SMESH_Gen * gen)
|
|
:StdMeshers_ImportSource1D(hypId, gen)
|
|
{
|
|
_name = "ImportSource2D";
|
|
_param_algo_dim = 2; // is used by StdMeshers_Import_2D;
|
|
}
|
|
|
|
//=============================================================================
|
|
/*!
|
|
*
|
|
*/
|
|
//=============================================================================
|
|
|
|
StdMeshers_ImportSource1D::~StdMeshers_ImportSource1D()
|
|
{
|
|
}
|
|
//=============================================================================
|
|
/*!
|
|
* Sets groups to import elements from
|
|
*/
|
|
//=============================================================================
|
|
|
|
void StdMeshers_ImportSource1D::SetGroups(const std::vector<SMESH_Group*>& groups)
|
|
{
|
|
if (_groups != groups)
|
|
{
|
|
_groups = groups;
|
|
NotifySubMeshesHypothesisModification();
|
|
}
|
|
}
|
|
|
|
void StdMeshers_ImportSource1D::SetCopySourceMesh(bool toCopyMesh, bool toCopyGroups)
|
|
{
|
|
if ( !toCopyMesh ) toCopyGroups = false;
|
|
if ( _toCopyMesh != toCopyMesh || _toCopyGroups != toCopyGroups )
|
|
{
|
|
_toCopyMesh = toCopyMesh; _toCopyGroups = toCopyGroups;
|
|
NotifySubMeshesHypothesisModification();
|
|
}
|
|
}
|
|
void StdMeshers_ImportSource1D::GetCopySourceMesh(bool& toCopyMesh, bool& toCopyGroups) const
|
|
{
|
|
toCopyMesh = _toCopyMesh; toCopyGroups = _toCopyGroups;
|
|
}
|
|
|
|
namespace
|
|
{
|
|
//================================================================================
|
|
/*!
|
|
* \brief Return only alive groups
|
|
*/
|
|
//================================================================================
|
|
|
|
vector<SMESH_Group*> getValidGroups(const vector<SMESH_Group*>& groups,
|
|
StudyContextStruct* studyContext,
|
|
bool loaded=false)
|
|
{
|
|
vector<SMESH_Group*> okGroups;
|
|
for ( size_t i = 0; i < groups.size(); ++i )
|
|
{
|
|
try
|
|
{
|
|
// we expect SIGSEGV on a dead group
|
|
OCC_CATCH_SIGNALS;
|
|
SMESH_Group* okGroup = 0;
|
|
map<int, SMESH_Mesh*>::iterator itm = studyContext->mapMesh.begin();
|
|
for ( ; !okGroup && itm != studyContext->mapMesh.end(); itm++)
|
|
{
|
|
SMESH_Mesh::GroupIteratorPtr gIt = itm->second->GetGroups();
|
|
while ( gIt->more() && !okGroup )
|
|
if ( gIt->next() == groups[i] )
|
|
{
|
|
okGroup = groups[i];
|
|
if ( loaded )
|
|
itm->second->Load();
|
|
}
|
|
}
|
|
if ( okGroup )
|
|
okGroups.push_back( okGroup );
|
|
}
|
|
catch(...)
|
|
{
|
|
}
|
|
}
|
|
return okGroups;
|
|
}
|
|
//================================================================================
|
|
/*!
|
|
* \brief Pack meshes into a pair of ints
|
|
*/
|
|
//================================================================================
|
|
|
|
pair<int, int> getResMapKey(const SMESHDS_Mesh& srcMesh, const SMESHDS_Mesh& tgtMesh)
|
|
{
|
|
return make_pair( srcMesh.GetPersistentId() , tgtMesh.GetPersistentId() );
|
|
}
|
|
//================================================================================
|
|
/*!
|
|
* \brief Return a target mesh by a pair of ints
|
|
*/
|
|
//================================================================================
|
|
|
|
SMESH_Mesh* getTgtMeshByKey( const pair<int, int> & resMapKey,
|
|
StudyContextStruct* studyContext)
|
|
{
|
|
int tgtID = resMapKey.second;
|
|
SMESH_Mesh* tgtMesh = 0;
|
|
map<int, SMESH_Mesh*>::iterator itm = studyContext->mapMesh.begin();
|
|
for ( ; !tgtMesh && itm != studyContext->mapMesh.end(); itm++)
|
|
{
|
|
tgtMesh = (*itm).second;
|
|
if ( tgtMesh->GetMeshDS()->GetPersistentId() != tgtID )
|
|
tgtMesh = 0;
|
|
}
|
|
return tgtMesh;
|
|
}
|
|
//================================================================================
|
|
/*!
|
|
* \brief Return a target mesh by a pair of ints
|
|
*/
|
|
//================================================================================
|
|
|
|
int getSrcMeshID( const pair<int, int> & resMapKey )
|
|
{
|
|
return resMapKey.first;
|
|
}
|
|
}
|
|
|
|
//=============================================================================
|
|
/*!
|
|
* Returns groups to import elements from
|
|
* \param [in] loaded - if \c true, meshes holding the groups are loaded
|
|
*/
|
|
//=============================================================================
|
|
|
|
const std::vector<SMESH_Group*>& StdMeshers_ImportSource1D::GetGroups(bool loaded) const
|
|
{
|
|
// filter off deleted groups
|
|
vector<SMESH_Group*> okGroups = getValidGroups( _groups,
|
|
_gen->GetStudyContext(),
|
|
loaded);
|
|
if ( okGroups.size() != _groups.size() )
|
|
((StdMeshers_ImportSource1D*)this)->_groups = okGroups;
|
|
|
|
return _groups;
|
|
}
|
|
|
|
//================================================================================
|
|
/*!
|
|
* \brief Return source meshes
|
|
*/
|
|
//================================================================================
|
|
|
|
std::vector<SMESH_Mesh*> StdMeshers_ImportSource1D::GetSourceMeshes() const
|
|
{
|
|
// GetPersistentId()'s of meshes
|
|
set<int> meshIDs;
|
|
const vector<SMESH_Group*>& groups = GetGroups();
|
|
if ( !groups.empty() )
|
|
{
|
|
for ( unsigned i = 0; i < groups.size(); ++i )
|
|
{
|
|
const SMESHDS_GroupBase* gDS = groups[i]->GetGroupDS();
|
|
int id = gDS->GetMesh()->GetPersistentId();
|
|
meshIDs.insert( id );
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if ( _resultGroups.empty() )
|
|
((StdMeshers_ImportSource1D*)this)->RestoreGroups(_groups);
|
|
TResGroupMap::const_iterator key_groups = _resultGroups.begin();
|
|
for ( ; key_groups != _resultGroups.end(); ++key_groups )
|
|
meshIDs.insert( getSrcMeshID( key_groups->first ));
|
|
}
|
|
|
|
// Find corresponding meshes
|
|
vector<SMESH_Mesh*> meshes;
|
|
if ( !meshIDs.empty() )
|
|
{
|
|
StudyContextStruct* studyContext = _gen->GetStudyContext();
|
|
for ( set<int>::iterator id = meshIDs.begin(); id != meshIDs.end(); ++id )
|
|
{
|
|
map<int, SMESH_Mesh*>::iterator itm = studyContext->mapMesh.begin();
|
|
for ( ; itm != studyContext->mapMesh.end(); itm++)
|
|
{
|
|
SMESH_Mesh* mesh = (*itm).second;
|
|
if ( mesh->GetMeshDS()->GetPersistentId() == *id )
|
|
{
|
|
meshes.push_back( mesh );
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return meshes;
|
|
}
|
|
|
|
//================================================================================
|
|
/*!
|
|
* \brief Return submeshes whose events affect the target mesh
|
|
*/
|
|
//================================================================================
|
|
|
|
std::vector<SMESH_subMesh*>
|
|
StdMeshers_ImportSource1D::GetSourceSubMeshes(const SMESH_Mesh* srcMesh) const
|
|
{
|
|
if ( !srcMesh->HasShapeToMesh() )
|
|
{
|
|
SMESH_Mesh* srcM = const_cast< SMESH_Mesh* >( srcMesh );
|
|
return vector<SMESH_subMesh*>(1, srcM->GetSubMesh( srcM->GetShapeToMesh()));
|
|
}
|
|
set<int> shapeIDs;
|
|
const vector<SMESH_Group*>& groups = GetGroups();
|
|
const SMESHDS_Mesh * srcMeshDS = srcMesh->GetMeshDS();
|
|
for ( size_t i = 0; i < groups.size(); ++i )
|
|
{
|
|
SMESHDS_GroupBase * grDS = groups[i]->GetGroupDS();
|
|
if ( grDS->GetMesh() != srcMeshDS )
|
|
continue;
|
|
if ( SMESHDS_GroupOnGeom* gog = dynamic_cast<SMESHDS_GroupOnGeom*>( grDS ))
|
|
{
|
|
shapeIDs.insert( srcMeshDS->ShapeToIndex( gog->GetShape() ));
|
|
}
|
|
else
|
|
{
|
|
SMDS_ElemIteratorPtr elIt = grDS->GetElements();
|
|
while ( elIt->more() )
|
|
shapeIDs.insert( elIt->next()->getshapeId() );
|
|
}
|
|
}
|
|
if ( !shapeIDs.empty() && *shapeIDs.begin() < 1 )
|
|
{
|
|
shapeIDs.erase( shapeIDs.begin() );
|
|
shapeIDs.insert( 1 );
|
|
}
|
|
|
|
vector<SMESH_subMesh*> smVec( shapeIDs.size());
|
|
set<int>::iterator sID = shapeIDs.begin();
|
|
for ( int i = 0; sID != shapeIDs.end(); ++sID, ++i )
|
|
smVec[i] = srcMesh->GetSubMeshContaining( *sID );
|
|
|
|
return smVec;
|
|
}
|
|
|
|
//=============================================================================
|
|
/*!
|
|
* Save _toCopyMesh and _toCopyGroups to a stream
|
|
*/
|
|
//=============================================================================
|
|
|
|
ostream & StdMeshers_ImportSource1D::SaveTo(ostream & save)
|
|
{
|
|
resultGroupsToIntVec();
|
|
|
|
save << " " << _toCopyMesh << " " << _toCopyGroups;
|
|
save << " " << _resultGroupsStorage.size();
|
|
for ( unsigned i = 0; i < _resultGroupsStorage.size(); ++i )
|
|
save << " " << _resultGroupsStorage[i];
|
|
|
|
return save;
|
|
}
|
|
|
|
//=============================================================================
|
|
/*!
|
|
* Load _toCopyMesh and _toCopyGroups from a stream
|
|
*/
|
|
//=============================================================================
|
|
|
|
istream & StdMeshers_ImportSource1D::LoadFrom(istream & load)
|
|
{
|
|
load >> _toCopyMesh >> _toCopyGroups;
|
|
|
|
_resultGroupsStorage.clear();
|
|
int val;
|
|
if ( load >> val )
|
|
{
|
|
_resultGroupsStorage.reserve(val);
|
|
while ( _resultGroupsStorage.size() < _resultGroupsStorage.capacity() && load >> val )
|
|
_resultGroupsStorage.push_back( val );
|
|
}
|
|
return load;
|
|
}
|
|
|
|
//================================================================================
|
|
/*!
|
|
* \brief Convert result groups into _resultGroupsStorage
|
|
*/
|
|
//================================================================================
|
|
|
|
void StdMeshers_ImportSource1D::resultGroupsToIntVec()
|
|
{
|
|
_resultGroupsStorage.clear();
|
|
|
|
// store result groups
|
|
TResGroupMap::iterator key2groups = _resultGroups.begin();
|
|
for ( ; key2groups != _resultGroups.end(); ++key2groups )
|
|
{
|
|
const pair<int, int>& key = key2groups->first;
|
|
const vector<SMESH_Group*>& groups = key2groups->second;
|
|
// mesh ids, nb groups
|
|
_resultGroupsStorage.push_back( key.first );
|
|
_resultGroupsStorage.push_back( key.second );
|
|
_resultGroupsStorage.push_back( groups.size() );
|
|
for ( unsigned i = 0; i < groups.size(); ++i )
|
|
{
|
|
// store group names as sequence of ints each standing for a char
|
|
// of a name; that is to avoid pb with names containing white spaces
|
|
string name = groups[i]->GetGroupDS()->GetStoreName();
|
|
_resultGroupsStorage.push_back( name.size() );
|
|
for ( unsigned j = 0; j < name.size(); ++j )
|
|
_resultGroupsStorage.push_back( name[j] );
|
|
}
|
|
}
|
|
}
|
|
|
|
//================================================================================
|
|
/*!
|
|
* \brief Restore source groups and result groups by _resultGroupsStorage
|
|
*/
|
|
//================================================================================
|
|
|
|
void StdMeshers_ImportSource1D::RestoreGroups(const std::vector<SMESH_Group*>& groups)
|
|
{
|
|
_groups = groups;
|
|
|
|
_resultGroups.clear();
|
|
size_t i = 0;
|
|
while ( i < _resultGroupsStorage.size() )
|
|
{
|
|
int key1 = _resultGroupsStorage[i++];
|
|
int key2 = _resultGroupsStorage[i++];
|
|
pair<int, int> resMapKey( key1, key2 );
|
|
SMESH_Mesh* mesh = getTgtMeshByKey( resMapKey, _gen->GetStudyContext());
|
|
// restore mesh ids at least
|
|
_resultGroups.insert( make_pair (resMapKey,vector<SMESH_Group*>() ));
|
|
|
|
int nbGroups = _resultGroupsStorage[i++];
|
|
for ( int j = 0; j < nbGroups; ++j )
|
|
{
|
|
string::size_type nameSize = _resultGroupsStorage[i++];
|
|
string groupName(nameSize, '\0');
|
|
for ( unsigned k = 0; k < nameSize; ++k )
|
|
groupName[k] = (char) _resultGroupsStorage[i++];
|
|
|
|
// find a group by name
|
|
if ( mesh )
|
|
{
|
|
SMESH_Group* group = 0;
|
|
SMESH_Mesh::GroupIteratorPtr gIt = mesh->GetGroups();
|
|
while ( !group && gIt->more() )
|
|
{
|
|
group = gIt->next();
|
|
if ( !group->GetGroupDS() || groupName != group->GetGroupDS()->GetStoreName() )
|
|
group = 0;
|
|
}
|
|
if ( group )
|
|
_resultGroups[ resMapKey ].push_back( group );
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
//================================================================================
|
|
/*!
|
|
* \brief Remember groups imported from other mesh
|
|
* \param groups - result groups
|
|
* \param srcMesh - source mesh
|
|
* \param tgtMesh - destination mesh
|
|
*/
|
|
//================================================================================
|
|
|
|
void StdMeshers_ImportSource1D::StoreResultGroups(const std::vector<SMESH_Group*>& groups,
|
|
const SMESHDS_Mesh& srcMesh,
|
|
const SMESHDS_Mesh& tgtMesh)
|
|
{
|
|
_resultGroups[ getResMapKey(srcMesh,tgtMesh) ] = groups;
|
|
}
|
|
|
|
//================================================================================
|
|
/*!
|
|
* \brief Return groups imported from other mesh
|
|
* \param srcMesh - source mesh
|
|
* \param tgtMesh - destination mesh
|
|
* \retval const std::vector<SMESH_Group*>& - groups
|
|
*/
|
|
//================================================================================
|
|
|
|
std::vector<SMESH_Group*>*
|
|
StdMeshers_ImportSource1D::GetResultGroups(const SMESHDS_Mesh& srcMesh,
|
|
const SMESHDS_Mesh& tgtMesh)
|
|
{
|
|
TResGroupMap::iterator key2groups = _resultGroups.find( getResMapKey(srcMesh,tgtMesh ));
|
|
if ( key2groups == _resultGroups.end() )
|
|
return 0;
|
|
vector<SMESH_Group*> vec = getValidGroups((*key2groups).second,
|
|
_gen->GetStudyContext() );
|
|
if ( vec.size() != key2groups->second.size())
|
|
key2groups->second = vec;
|
|
|
|
return & key2groups->second;
|
|
}
|
|
|
|
//================================================================================
|
|
/*!
|
|
* \brief Initialize ImportSource value by the mesh built on the geometry
|
|
* \param theMesh - the built mesh
|
|
* \param theShape - the geometry of interest
|
|
* \retval bool - true if parameter values have been successfully defined
|
|
*/
|
|
//================================================================================
|
|
|
|
bool StdMeshers_ImportSource1D::SetParametersByMesh(const SMESH_Mesh*, const TopoDS_Shape&)
|
|
{
|
|
return false;
|
|
}
|
|
|
|
//================================================================================
|
|
/*!
|
|
* \brief Initialize my parameter values by default parameters.
|
|
* \retval bool - true if parameter values have been successfully defined
|
|
*/
|
|
//================================================================================
|
|
|
|
bool StdMeshers_ImportSource1D::SetParametersByDefaults(const TDefaults&, const SMESH_Mesh* )
|
|
{
|
|
return false;
|
|
}
|