mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-27 15:40:32 +05:00
parent
e60bcaf4a9
commit
8db3567826
BIN
doc/gui/images/reload_mesh_modif_mesh.png
Normal file
BIN
doc/gui/images/reload_mesh_modif_mesh.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 9.3 KiB |
BIN
doc/gui/images/reload_mesh_modif_mesh_props.png
Normal file
BIN
doc/gui/images/reload_mesh_modif_mesh_props.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 22 KiB |
BIN
doc/gui/images/reload_mesh_orig_mesh.png
Normal file
BIN
doc/gui/images/reload_mesh_orig_mesh.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 10 KiB |
BIN
doc/gui/images/reload_mesh_result.png
Normal file
BIN
doc/gui/images/reload_mesh_result.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 37 KiB |
41
doc/gui/input/reload_mesh_from_file.rst
Normal file
41
doc/gui/input/reload_mesh_from_file.rst
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
.. _reload_mesh_from_file_page:
|
||||||
|
|
||||||
|
*******************
|
||||||
|
Reload mesh from file
|
||||||
|
*******************
|
||||||
|
|
||||||
|
This operation allows reload original imported mesh, which was modified by different dedicated tools
|
||||||
|
|
||||||
|
*Reload mesh from file:*
|
||||||
|
|
||||||
|
|
||||||
|
#. Select a mesh(es) (and display it in the 3D Viewer if you are going to pick elements by mouse).
|
||||||
|
#. From popup menu click on the *Reload from file* item
|
||||||
|
|
||||||
|
Each selected mesh will be updated to orignal state with saving display properties
|
||||||
|
|
||||||
|
.. image:: ../images/reload_mesh_orig_mesh.png
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
.. centered::
|
||||||
|
Original mesh
|
||||||
|
|
||||||
|
|
|
||||||
|
|
||||||
|
.. image:: ../images/reload_mesh_modif_mesh.png
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
.. centered::
|
||||||
|
Same mesh after apply "Merge Nodes"
|
||||||
|
|
||||||
|
.. image:: ../images/reload_mesh_modif_mesh_props.png
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
.. centered::
|
||||||
|
Set display properties
|
||||||
|
|
||||||
|
.. image:: ../images/reload_mesh_result.png
|
||||||
|
:align: center
|
||||||
|
|
||||||
|
.. centered::
|
||||||
|
Result after reload mesh
|
@ -258,6 +258,9 @@ module SMESH
|
|||||||
SMESH_Mesh CreateEmptyMesh()
|
SMESH_Mesh CreateEmptyMesh()
|
||||||
raises ( SALOME::SALOME_Exception );
|
raises ( SALOME::SALOME_Exception );
|
||||||
|
|
||||||
|
SMESH_Mesh ReloadMeshFromFile(in SMESH_Mesh sourceMesh)
|
||||||
|
raises(SALOME::SALOME_Exception);
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Create Mesh object importing data from given UNV file
|
* Create Mesh object importing data from given UNV file
|
||||||
* (UNV supported version is I-DEAS 10)
|
* (UNV supported version is I-DEAS 10)
|
||||||
@ -302,6 +305,7 @@ module SMESH
|
|||||||
out SMESH::DriverMED_ReadStatus theStatus)
|
out SMESH::DriverMED_ReadStatus theStatus)
|
||||||
raises (SALOME::SALOME_Exception);
|
raises (SALOME::SALOME_Exception);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Create a dual mesh of a Tetrahedron mesh
|
* Create a dual mesh of a Tetrahedron mesh
|
||||||
* \param mesh - TetraHedron mesh to create dual from
|
* \param mesh - TetraHedron mesh to create dual from
|
||||||
|
@ -122,6 +122,9 @@
|
|||||||
|
|
||||||
#include "SMESH_version.h"
|
#include "SMESH_version.h"
|
||||||
|
|
||||||
|
#include "SMESHDS_Mesh.hxx"
|
||||||
|
#include "SMESH_Mesh.hxx"
|
||||||
|
|
||||||
#include "SMESH_Actor.h"
|
#include "SMESH_Actor.h"
|
||||||
#include "SMESH_ActorUtils.h"
|
#include "SMESH_ActorUtils.h"
|
||||||
#include "SMESH_Client.hxx"
|
#include "SMESH_Client.hxx"
|
||||||
@ -221,6 +224,8 @@ namespace
|
|||||||
|
|
||||||
void ExportMeshToFile(int theCommandID);
|
void ExportMeshToFile(int theCommandID);
|
||||||
|
|
||||||
|
void ReloadMeshFromFile(int theCommandID);
|
||||||
|
|
||||||
void SetDisplayMode(int theCommandID, VTK::MarkerMap& theMarkerMap);
|
void SetDisplayMode(int theCommandID, VTK::MarkerMap& theMarkerMap);
|
||||||
|
|
||||||
void SetDisplayEntity(int theCommandID);
|
void SetDisplayEntity(int theCommandID);
|
||||||
@ -1076,6 +1081,84 @@ namespace
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//================================================================================
|
||||||
|
/*!
|
||||||
|
* \brief Reload selected mesh from file a file
|
||||||
|
*/
|
||||||
|
//================================================================================
|
||||||
|
void ReloadMeshFromFile(int theCommandID)
|
||||||
|
{
|
||||||
|
LightApp_SelectionMgr* aSel = SMESHGUI::selectionMgr();
|
||||||
|
SALOME_ListIO selected;
|
||||||
|
if (aSel)
|
||||||
|
aSel->selectedObjects(selected);
|
||||||
|
|
||||||
|
QList< QPair< SMESH::SMESH_IDSource_var, QString > > aMeshList;
|
||||||
|
QList< QPair< SMESH::SMESH_IDSource_var, QString > >::iterator aMeshIter;
|
||||||
|
SALOME_ListIteratorOfListIO It(selected);
|
||||||
|
|
||||||
|
// Iterate by all selected
|
||||||
|
for (; It.More(); It.Next())
|
||||||
|
{
|
||||||
|
Handle(SALOME_InteractiveObject) anIObject = It.Value();
|
||||||
|
SMESH::SMESH_IDSource_var aMeshItem =
|
||||||
|
SMESH::IObjectToInterface<SMESH::SMESH_IDSource>(anIObject);
|
||||||
|
|
||||||
|
if (aMeshItem->_is_nil()) {
|
||||||
|
SUIT_MessageBox::warning(SMESHGUI::desktop(),
|
||||||
|
QObject::tr("SMESH_WRN_WARNING"),
|
||||||
|
QObject::tr("SMESH_BAD_MESH_SELECTION"));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_var aMeshByIO = SMESH::GetMeshByIO(anIObject);
|
||||||
|
SMESH::SelectionProxy aMesh = SMESH::SelectionProxy(aMeshItem);
|
||||||
|
SMESH::MedInfo anInfo = aMesh.medFileInfo();
|
||||||
|
if (!anInfo.isValid())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
SMESH::ListOfGroups aGroups = *aMeshByIO->GetGroups();
|
||||||
|
for (int i = 0; i < aGroups.length(); ++i)
|
||||||
|
{
|
||||||
|
auto X = aGroups[i];
|
||||||
|
_PTR(SObject) aGroupSObject = SMESH::FindSObject(X);
|
||||||
|
SMESH_Actor* anActor = SMESH::FindActorByEntry(aGroupSObject->GetID().c_str());
|
||||||
|
SMESH::smIdType_array aMeshInfo = *X->GetMeshInfo();
|
||||||
|
|
||||||
|
if (anActor)
|
||||||
|
{
|
||||||
|
vtkTypeBool isVisib = anActor->GetVisibility();
|
||||||
|
SMESH::UpdateView(!isVisib ? SMESH::eDisplay : SMESH::eErase, aGroupSObject->GetID().c_str());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
SMESH::UpdateView(SMESH::eErase, aGroupSObject->GetID().c_str());
|
||||||
|
}
|
||||||
|
|
||||||
|
SMESH::mesh_array_var aMeshes = new SMESH::mesh_array;
|
||||||
|
{
|
||||||
|
// re-import mesh
|
||||||
|
SMESH::SMESH_Mesh_var aReloadedMesh = SMESHGUI::GetSMESHGen()->ReloadMeshFromFile(aMeshByIO);
|
||||||
|
|
||||||
|
QStringList anEntryList;
|
||||||
|
|
||||||
|
_PTR(SObject) aMeshSO = SMESH::FindSObject(aReloadedMesh);
|
||||||
|
if (aMeshSO) {
|
||||||
|
anEntryList.append(aMeshSO->GetID().c_str());
|
||||||
|
}
|
||||||
|
SMESHGUI::GetSMESHGUI()->updateObjBrowser();
|
||||||
|
if (LightApp_Application* anApp =
|
||||||
|
dynamic_cast<LightApp_Application*>(SUIT_Session::session()->activeApplication()))
|
||||||
|
anApp->browseObjects(anEntryList);
|
||||||
|
}
|
||||||
|
|
||||||
|
SMESH::SMESH_GroupBase_var aGroup = SMESH::SMESH_GroupBase::_narrow(aMeshItem);
|
||||||
|
QString aMeshName = anIObject->getName();
|
||||||
|
aMeshList.append(QPair< SMESH::SMESH_IDSource_var, QString >(aMeshItem, aMeshName));
|
||||||
|
|
||||||
|
}
|
||||||
|
SMESH::UpdateView();
|
||||||
|
}
|
||||||
|
|
||||||
inline void InverseEntityMode(unsigned int& theOutputMode,
|
inline void InverseEntityMode(unsigned int& theOutputMode,
|
||||||
unsigned int theMode)
|
unsigned int theMode)
|
||||||
{
|
{
|
||||||
@ -2688,7 +2771,12 @@ bool SMESHGUI::OnGUIEvent( int theCommandID )
|
|||||||
::ImportMeshesFromFile(GetSMESHGen(),theCommandID);
|
::ImportMeshesFromFile(GetSMESHGen(),theCommandID);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case SMESHOp::OpReloadFromFile:
|
||||||
|
{
|
||||||
|
if (isStudyLocked()) break;
|
||||||
|
::ReloadMeshFromFile(theCommandID);
|
||||||
|
break;
|
||||||
|
}
|
||||||
case SMESHOp::OpFileInformation:
|
case SMESHOp::OpFileInformation:
|
||||||
{
|
{
|
||||||
SALOME_ListIO selected;
|
SALOME_ListIO selected;
|
||||||
@ -3481,7 +3569,6 @@ bool SMESHGUI::OnGUIEvent( int theCommandID )
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
case SMESHOp::OpFindElementByPoint:
|
case SMESHOp::OpFindElementByPoint:
|
||||||
{
|
{
|
||||||
startOperation( theCommandID );
|
startOperation( theCommandID );
|
||||||
@ -4317,6 +4404,7 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
//createSMESHAction( SMESHOp::OpStdInfo, "STD_INFO", "ICON_STD_INFO" );
|
//createSMESHAction( SMESHOp::OpStdInfo, "STD_INFO", "ICON_STD_INFO" );
|
||||||
//createSMESHAction( SMESHOp::OpWhatIs, "WHAT_IS", "ICON_WHAT_IS" ); // VSR: issue #0021242 (eliminate "Mesh Element Information" command)
|
//createSMESHAction( SMESHOp::OpWhatIs, "WHAT_IS", "ICON_WHAT_IS" ); // VSR: issue #0021242 (eliminate "Mesh Element Information" command)
|
||||||
createSMESHAction( SMESHOp::OpFindElementByPoint, "FIND_ELEM", "ICON_FIND_ELEM" );
|
createSMESHAction( SMESHOp::OpFindElementByPoint, "FIND_ELEM", "ICON_FIND_ELEM" );
|
||||||
|
createSMESHAction( SMESHOp::OpReloadFromFile, "RELOAD_FROM_FILE");
|
||||||
//update
|
//update
|
||||||
createSMESHAction( SMESHOp::OpFreeNode, "FREE_NODE", "ICON_FREE_NODE", 0, true );
|
createSMESHAction( SMESHOp::OpFreeNode, "FREE_NODE", "ICON_FREE_NODE", 0, true );
|
||||||
createSMESHAction( SMESHOp::OpEqualNode, "EQUAL_NODE", "ICON_EQUAL_NODE", 0, true );
|
createSMESHAction( SMESHOp::OpEqualNode, "EQUAL_NODE", "ICON_EQUAL_NODE", 0, true );
|
||||||
@ -4929,6 +5017,7 @@ void SMESHGUI::initialize( CAM_Application* app )
|
|||||||
createPopupItem( SMESHOp::OpFileInformation, OB, mesh, "&& selcount=1 && isImported" );
|
createPopupItem( SMESHOp::OpFileInformation, OB, mesh, "&& selcount=1 && isImported" );
|
||||||
createPopupItem( SMESHOp::OpMeshInformation, OB, mesh_part );
|
createPopupItem( SMESHOp::OpMeshInformation, OB, mesh_part );
|
||||||
createPopupItem( SMESHOp::OpFindElementByPoint,OB, mesh_group, "&& selcount=1 && " + hasElems );
|
createPopupItem( SMESHOp::OpFindElementByPoint,OB, mesh_group, "&& selcount=1 && " + hasElems );
|
||||||
|
createPopupItem( SMESHOp::OpReloadFromFile, OB, mesh, "&& isImported");
|
||||||
createPopupItem( SMESHOp::OpOverallMeshQuality,OB, mesh_part );
|
createPopupItem( SMESHOp::OpOverallMeshQuality,OB, mesh_part );
|
||||||
popupMgr()->insert( separator(), -1, 0 );
|
popupMgr()->insert( separator(), -1, 0 );
|
||||||
createPopupItem( SMESHOp::OpCreateGroup, OB, mesh, "&& selcount=1" );
|
createPopupItem( SMESHOp::OpCreateGroup, OB, mesh, "&& selcount=1" );
|
||||||
|
@ -94,6 +94,7 @@ namespace SMESHOp {
|
|||||||
OpWhatIs = 2101, // MENU MESH - MESH ELEMENT INFORMATION
|
OpWhatIs = 2101, // MENU MESH - MESH ELEMENT INFORMATION
|
||||||
OpStdInfo = 2102, // MENU MESH - MESH STANDARD INFORMATION
|
OpStdInfo = 2102, // MENU MESH - MESH STANDARD INFORMATION
|
||||||
OpFindElementByPoint = 2103, // MENU MESH - FIND ELEMENT BY POINT
|
OpFindElementByPoint = 2103, // MENU MESH - FIND ELEMENT BY POINT
|
||||||
|
OpReloadFromFile = 2104, // MENU MESH - RELOAD MESH FROM FILE
|
||||||
OpUpdate = 2200, // POPUP MENU - UPDATE
|
OpUpdate = 2200, // POPUP MENU - UPDATE
|
||||||
// Controls -----------------------//--------------------------------
|
// Controls -----------------------//--------------------------------
|
||||||
OpFreeNode = 3000, // MENU CONTROLS - FREE NODES
|
OpFreeNode = 3000, // MENU CONTROLS - FREE NODES
|
||||||
|
@ -272,6 +272,10 @@
|
|||||||
<source>MEN_ADV_INFO</source>
|
<source>MEN_ADV_INFO</source>
|
||||||
<translation>Mesh Information</translation>
|
<translation>Mesh Information</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>MEN_ALL</source>
|
<source>MEN_ALL</source>
|
||||||
<translation>All</translation>
|
<translation>All</translation>
|
||||||
@ -3332,6 +3336,10 @@ Use Display Entity menu command to show them.
|
|||||||
<source>STB_ADV_INFO</source>
|
<source>STB_ADV_INFO</source>
|
||||||
<translation>Show base information about the mesh object</translation>
|
<translation>Show base information about the mesh object</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>STB_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload original mesh from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>STB_ALL</source>
|
<source>STB_ALL</source>
|
||||||
<translation>All</translation>
|
<translation>All</translation>
|
||||||
@ -4072,6 +4080,10 @@ Use Display Entity menu command to show them.
|
|||||||
<source>TOP_ADV_INFO</source>
|
<source>TOP_ADV_INFO</source>
|
||||||
<translation>Mesh Information</translation>
|
<translation>Mesh Information</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>TOP_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>TOP_ALL</source>
|
<source>TOP_ALL</source>
|
||||||
<translation>All</translation>
|
<translation>All</translation>
|
||||||
|
@ -268,6 +268,10 @@
|
|||||||
<source>MEN_ADV_INFO</source>
|
<source>MEN_ADV_INFO</source>
|
||||||
<translation>Informations sur le maillage</translation>
|
<translation>Informations sur le maillage</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>MEN_ALL</source>
|
<source>MEN_ALL</source>
|
||||||
<translation>Tous</translation>
|
<translation>Tous</translation>
|
||||||
@ -3331,6 +3335,10 @@ Utilisez le menu "Visualiser une entité" pour les afficher.
|
|||||||
<source>STB_ALL</source>
|
<source>STB_ALL</source>
|
||||||
<translation>Tous</translation>
|
<translation>Tous</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>STB_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload original mesh from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>STB_AREA</source>
|
<source>STB_AREA</source>
|
||||||
<translation>Aire</translation>
|
<translation>Aire</translation>
|
||||||
@ -4067,6 +4075,10 @@ Utilisez le menu "Visualiser une entité" pour les afficher.
|
|||||||
<source>TOP_ADV_INFO</source>
|
<source>TOP_ADV_INFO</source>
|
||||||
<translation>Informations sur le maillage</translation>
|
<translation>Informations sur le maillage</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>TOP_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>TOP_ALL</source>
|
<source>TOP_ALL</source>
|
||||||
<translation>Tous</translation>
|
<translation>Tous</translation>
|
||||||
|
@ -251,6 +251,10 @@
|
|||||||
<source>MEN_ADV_INFO</source>
|
<source>MEN_ADV_INFO</source>
|
||||||
<translation>メッシュに関する情報</translation>
|
<translation>メッシュに関する情報</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>MEN_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>MEN_ALL</source>
|
<source>MEN_ALL</source>
|
||||||
<translation>すべて</translation>
|
<translation>すべて</translation>
|
||||||
@ -2979,6 +2983,10 @@ pip install meshio[all]</translation>
|
|||||||
<source>STB_ADV_INFO</source>
|
<source>STB_ADV_INFO</source>
|
||||||
<translation>メッシュ上の基本的な情報を得る</translation>
|
<translation>メッシュ上の基本的な情報を得る</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>STB_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload original mesh from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>STB_ALL</source>
|
<source>STB_ALL</source>
|
||||||
<translation>すべて</translation>
|
<translation>すべて</translation>
|
||||||
@ -3663,6 +3671,10 @@ pip install meshio[all]</translation>
|
|||||||
<source>TOP_ADV_INFO</source>
|
<source>TOP_ADV_INFO</source>
|
||||||
<translation>メッシュに関する情報</translation>
|
<translation>メッシュに関する情報</translation>
|
||||||
</message>
|
</message>
|
||||||
|
<message>
|
||||||
|
<source>TOP_RELOAD_FROM_FILE</source>
|
||||||
|
<translation>Reload from file</translation>
|
||||||
|
</message>
|
||||||
<message>
|
<message>
|
||||||
<source>TOP_ALL</source>
|
<source>TOP_ALL</source>
|
||||||
<translation>すべて</translation>
|
<translation>すべて</translation>
|
||||||
|
@ -1013,6 +1013,7 @@ void _pyGen::Process( const Handle(_pyCommand)& theCommand )
|
|||||||
{
|
{
|
||||||
// there are methods to convert:
|
// there are methods to convert:
|
||||||
// CreateMesh( shape )
|
// CreateMesh( shape )
|
||||||
|
// ReloadMesh( shape )
|
||||||
// Concatenate( [mesh1, ...], ... )
|
// Concatenate( [mesh1, ...], ... )
|
||||||
// CreateHypothesis( theHypType, theLibName )
|
// CreateHypothesis( theHypType, theLibName )
|
||||||
// Compute( mesh, geom )
|
// Compute( mesh, geom )
|
||||||
@ -1067,6 +1068,13 @@ void _pyGen::Process( const Handle(_pyCommand)& theCommand )
|
|||||||
Handle(_pyMesh) mesh = new _pyMesh( theCommand, entries.front() );
|
Handle(_pyMesh) mesh = new _pyMesh( theCommand, entries.front() );
|
||||||
AddObject( mesh );
|
AddObject( mesh );
|
||||||
}
|
}
|
||||||
|
if (method == "ReloadMeshFromFile")
|
||||||
|
{
|
||||||
|
std::cout << "WhatIS" << std::endl;
|
||||||
|
Handle(_pyMesh) mesh = new _pyMesh(theCommand, theCommand->GetResultValue());
|
||||||
|
AddObject(mesh);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// CreateHypothesis()
|
// CreateHypothesis()
|
||||||
if ( method == "CreateHypothesis" )
|
if ( method == "CreateHypothesis" )
|
||||||
|
@ -153,6 +153,7 @@
|
|||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
#include <QStringList>
|
||||||
|
|
||||||
#include <boost/archive/text_oarchive.hpp>
|
#include <boost/archive/text_oarchive.hpp>
|
||||||
#include <boost/serialization/list.hpp>
|
#include <boost/serialization/list.hpp>
|
||||||
@ -1330,6 +1331,61 @@ SMESH::SMESH_Mesh_ptr SMESH_Gen_i::CreateEmptyMesh()
|
|||||||
return mesh._retn();
|
return mesh._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr SMESH_Gen_i::ReloadMeshFromFile(SMESH::SMESH_Mesh_ptr theMesh)
|
||||||
|
{
|
||||||
|
SMESH::mesh_array_var aMeshes = new SMESH::mesh_array;
|
||||||
|
|
||||||
|
SMESH::MedFileInfo* aMedInfo = theMesh->GetMEDFileInfo();
|
||||||
|
|
||||||
|
// Get file path and re-import mesh
|
||||||
|
QString aPath = QString(aMedInfo->fileName);
|
||||||
|
QStringList aSplit = aPath.split('.');
|
||||||
|
QStringList anEntryList;
|
||||||
|
|
||||||
|
auto aStudy = getStudyServant();
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr aNewMesh;
|
||||||
|
|
||||||
|
SMESH_Mesh* aMesh = reinterpret_cast<SMESH_Mesh*> (theMesh->GetMeshPtr());
|
||||||
|
aMesh->GetMeshDS()->ClearMesh();
|
||||||
|
|
||||||
|
if (aSplit.last() == "cgns")
|
||||||
|
{
|
||||||
|
SMESH::DriverMED_ReadStatus res;
|
||||||
|
aMeshes = ReloadMeshesFromCGNS(aPath.toUtf8().constData(), theMesh, res);
|
||||||
|
|
||||||
|
aNewMesh = aMeshes[0];
|
||||||
|
|
||||||
|
}
|
||||||
|
else if (aSplit.last().contains("stl", Qt::CaseSensitivity::CaseInsensitive))
|
||||||
|
{
|
||||||
|
aNewMesh = ReloadMeshesFromSTL(aPath.toUtf8().constData(), theMesh);
|
||||||
|
}
|
||||||
|
else if (aSplit.last().contains("unv", Qt::CaseSensitivity::CaseInsensitive))
|
||||||
|
{
|
||||||
|
aNewMesh = ReloadMeshesFromUNV(aPath.toUtf8().constData(), theMesh);
|
||||||
|
}
|
||||||
|
else if (aSplit.last().contains("mesh", Qt::CaseSensitivity::CaseInsensitive))
|
||||||
|
{
|
||||||
|
SMESH::ComputeError_var res;
|
||||||
|
aNewMesh = ReloadMeshesFromGMF(aPath.toUtf8().constData(), theMesh, true, res.out());
|
||||||
|
}
|
||||||
|
else if (aSplit.last().contains("med", Qt::CaseSensitivity::CaseInsensitive))
|
||||||
|
{
|
||||||
|
SMESH::DriverMED_ReadStatus res;
|
||||||
|
aMeshes = ReloadMeshesFromMED(aPath.toUtf8().constData(), theMesh, res);
|
||||||
|
|
||||||
|
aNewMesh = aMeshes[0];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// MeshIO
|
||||||
|
}
|
||||||
|
|
||||||
|
theMesh = SMESH::SMESH_Mesh::_duplicate(aNewMesh);
|
||||||
|
return theMesh;
|
||||||
|
}
|
||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
//================================================================================
|
//================================================================================
|
||||||
@ -1428,6 +1484,36 @@ SMESH::SMESH_Mesh_ptr SMESH_Gen_i::CreateMeshesFromUNV( const char* theFileName
|
|||||||
return aMesh._retn();
|
return aMesh._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr SMESH_Gen_i::ReloadMeshesFromUNV(const char* theFileName, SMESH::SMESH_Mesh_ptr sourceMesh)
|
||||||
|
{
|
||||||
|
Unexpect aCatch(SALOME_SalomeException);
|
||||||
|
|
||||||
|
checkFileReadable(theFileName);
|
||||||
|
|
||||||
|
string aFileName;
|
||||||
|
// publish mesh in the study
|
||||||
|
if (CanPublishInStudy(sourceMesh)) {
|
||||||
|
SALOMEDS::StudyBuilder_var aStudyBuilder = getStudyServant()->NewBuilder();
|
||||||
|
aStudyBuilder->NewCommand(); // There is a transaction
|
||||||
|
SALOMEDS::SObject_wrap aSO = PublishMesh(sourceMesh, aFileName.c_str());
|
||||||
|
aStudyBuilder->CommitCommand();
|
||||||
|
if (!aSO->_is_nil()) {
|
||||||
|
// Update Python script
|
||||||
|
TPythonDump(this) << aSO << " = " << this << ".ReloadMeshesFromUNV(r'" << theFileName << "')";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SMESH_Mesh_i* aServant = dynamic_cast<SMESH_Mesh_i*>(GetServant(sourceMesh).in());
|
||||||
|
ASSERT(aServant);
|
||||||
|
aServant->ImportUNVFile(theFileName);
|
||||||
|
|
||||||
|
// Dump creation of groups
|
||||||
|
SMESH::ListOfGroups_var groups = aServant->GetGroups();
|
||||||
|
|
||||||
|
aServant->GetImpl().GetMeshDS()->Modified();
|
||||||
|
return sourceMesh;
|
||||||
|
}
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
/*!
|
/*!
|
||||||
* SMESH_Gen_i::CreateMeshFromMED
|
* SMESH_Gen_i::CreateMeshFromMED
|
||||||
@ -1511,6 +1597,92 @@ SMESH::mesh_array* SMESH_Gen_i::CreateMeshesFromMED( const char*
|
|||||||
return aResult._retn();
|
return aResult._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SMESH::mesh_array* SMESH_Gen_i::ReloadMeshesFromMED(const char* theFileName, SMESH::SMESH_Mesh_ptr sourceMesh, SMESH::DriverMED_ReadStatus& theStatus)
|
||||||
|
{
|
||||||
|
SMESH::ListOfGroups anOldGroups = *sourceMesh->GetGroups();
|
||||||
|
checkFileReadable(theFileName);
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
char bname[_MAX_FNAME];
|
||||||
|
_splitpath(theFileName, NULL, NULL, bname, NULL);
|
||||||
|
string aFileName = bname;
|
||||||
|
#else
|
||||||
|
string aFileName = basename(const_cast<char*>(theFileName));
|
||||||
|
#endif
|
||||||
|
// Retrieve mesh names from the file
|
||||||
|
DriverMED_R_SMESHDS_Mesh myReader;
|
||||||
|
myReader.SetFile(theFileName);
|
||||||
|
myReader.SetMeshId(-1);
|
||||||
|
Driver_Mesh::Status aStatus;
|
||||||
|
list<string> aNames = myReader.GetMeshNames(aStatus);
|
||||||
|
SMESH::mesh_array_var aResult = new SMESH::mesh_array();
|
||||||
|
theStatus = (SMESH::DriverMED_ReadStatus)aStatus;
|
||||||
|
|
||||||
|
{ // open a new scope to make aPythonDump die before PythonDump in SMESH_Mesh::GetGroups()
|
||||||
|
|
||||||
|
// Python Dump
|
||||||
|
TPythonDump aPythonDump(this);
|
||||||
|
aPythonDump << "([";
|
||||||
|
|
||||||
|
if (theStatus == SMESH::DRS_OK)
|
||||||
|
{
|
||||||
|
SALOMEDS::StudyBuilder_var aStudyBuilder;
|
||||||
|
aStudyBuilder = getStudyServant()->NewBuilder();
|
||||||
|
aStudyBuilder->NewCommand(); // There is a transaction
|
||||||
|
|
||||||
|
aResult->length(aNames.size());
|
||||||
|
int i = 0;
|
||||||
|
|
||||||
|
// Iterate through all meshes and create mesh objects
|
||||||
|
for (const std::string& meshName : aNames)
|
||||||
|
{
|
||||||
|
// Python Dump
|
||||||
|
if (i > 0) aPythonDump << ", ";
|
||||||
|
|
||||||
|
// publish mesh in the study
|
||||||
|
SALOMEDS::SObject_wrap aSO;
|
||||||
|
if (CanPublishInStudy(sourceMesh))
|
||||||
|
aSO = PublishMesh(sourceMesh, meshName.c_str());
|
||||||
|
|
||||||
|
// Python Dump
|
||||||
|
if (!aSO->_is_nil()) {
|
||||||
|
aPythonDump << aSO;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
aPythonDump << "mesh_" << i;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read mesh data (groups are published automatically by ImportMEDFile())
|
||||||
|
SMESH_Mesh_i* meshServant = dynamic_cast<SMESH_Mesh_i*>(GetServant(sourceMesh).in());
|
||||||
|
ASSERT(meshServant);
|
||||||
|
SMESH::DriverMED_ReadStatus status1 =
|
||||||
|
meshServant->ImportMEDFile(theFileName, meshName.c_str());
|
||||||
|
if (status1 > theStatus)
|
||||||
|
theStatus = status1;
|
||||||
|
|
||||||
|
for (unsigned int i = 0; i < anOldGroups.length(); ++i)
|
||||||
|
{
|
||||||
|
//auto X = anOldGroups[i];
|
||||||
|
sourceMesh->RemoveGroup(anOldGroups[i]);
|
||||||
|
}
|
||||||
|
aResult[i++] = SMESH::SMESH_Mesh::_duplicate(sourceMesh);
|
||||||
|
|
||||||
|
meshServant->GetImpl().GetMeshDS()->Modified();
|
||||||
|
}
|
||||||
|
if (!aStudyBuilder->_is_nil())
|
||||||
|
aStudyBuilder->CommitCommand();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update Python script
|
||||||
|
aPythonDump << "], status) = " << this << ".ReloadMeshesFromMED( r'" << theFileName << "' )";
|
||||||
|
}
|
||||||
|
// Dump creation of groups
|
||||||
|
for (CORBA::ULong i = 0; i < aResult->length(); ++i)
|
||||||
|
SMESH::ListOfGroups_var groups = aResult[i]->GetGroups();
|
||||||
|
|
||||||
|
return aResult._retn();
|
||||||
|
}
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
/*!
|
/*!
|
||||||
* SMESH_Gen_i::CreateMeshFromSTL
|
* SMESH_Gen_i::CreateMeshFromSTL
|
||||||
@ -1554,6 +1726,37 @@ SMESH::SMESH_Mesh_ptr SMESH_Gen_i::CreateMeshesFromSTL( const char* theFileName
|
|||||||
return aMesh._retn();
|
return aMesh._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr SMESH_Gen_i::ReloadMeshesFromSTL(const char* theFileName, SMESH::SMESH_Mesh_ptr sourceMesh)
|
||||||
|
{
|
||||||
|
Unexpect aCatch(SALOME_SalomeException);
|
||||||
|
checkFileReadable(theFileName);
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
char bname[_MAX_FNAME];
|
||||||
|
_splitpath(theFileName, NULL, NULL, bname, NULL);
|
||||||
|
string aFileName = bname;
|
||||||
|
#else
|
||||||
|
string aFileName = basename(const_cast<char*>(theFileName));
|
||||||
|
#endif
|
||||||
|
// publish mesh in the study
|
||||||
|
if (CanPublishInStudy(sourceMesh)) {
|
||||||
|
SALOMEDS::StudyBuilder_var aStudyBuilder = getStudyServant()->NewBuilder();
|
||||||
|
aStudyBuilder->NewCommand(); // There is a transaction
|
||||||
|
SALOMEDS::SObject_wrap aSO = PublishInStudy(SALOMEDS::SObject::_nil(), sourceMesh, aFileName.c_str());
|
||||||
|
aStudyBuilder->CommitCommand();
|
||||||
|
if (!aSO->_is_nil()) {
|
||||||
|
// Update Python script
|
||||||
|
TPythonDump(this) << aSO << " = " << this << ".ReloadMeshFromSTL(r'" << theFileName << "')";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
SMESH_Mesh_i* aServant = dynamic_cast<SMESH_Mesh_i*>(GetServant(sourceMesh).in());
|
||||||
|
ASSERT(aServant);
|
||||||
|
aServant->ImportSTLFile(theFileName);
|
||||||
|
aServant->GetImpl().GetMeshDS()->Modified();
|
||||||
|
return sourceMesh;
|
||||||
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief Create meshes and import data from the CGSN file
|
* \brief Create meshes and import data from the CGSN file
|
||||||
@ -1639,6 +1842,85 @@ SMESH::mesh_array* SMESH_Gen_i::CreateMeshesFromCGNS( const char*
|
|||||||
return aResult._retn();
|
return aResult._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SMESH::mesh_array* SMESH_Gen_i::ReloadMeshesFromCGNS(const char* theFileName,
|
||||||
|
SMESH::SMESH_Mesh_ptr sourceMesh,
|
||||||
|
SMESH::DriverMED_ReadStatus& theStatus)
|
||||||
|
{
|
||||||
|
Unexpect aCatch(SALOME_SalomeException);
|
||||||
|
checkFileReadable(theFileName);
|
||||||
|
|
||||||
|
SMESH::mesh_array_var aResult = new SMESH::mesh_array();
|
||||||
|
|
||||||
|
#ifdef WITH_CGNS
|
||||||
|
// Retrieve nb meshes from the file
|
||||||
|
DriverCGNS_Read myReader;
|
||||||
|
myReader.SetFile(theFileName);
|
||||||
|
Driver_Mesh::Status aStatus;
|
||||||
|
int nbMeshes = myReader.GetNbMeshes(aStatus);
|
||||||
|
theStatus = (SMESH::DriverMED_ReadStatus)aStatus;
|
||||||
|
|
||||||
|
aResult->length(nbMeshes);
|
||||||
|
|
||||||
|
{ // open a new scope to make aPythonDump die before PythonDump in SMESH_Mesh::GetGroups()
|
||||||
|
|
||||||
|
// Python Dump
|
||||||
|
TPythonDump aPythonDump(this);
|
||||||
|
aPythonDump << "([";
|
||||||
|
|
||||||
|
if (theStatus == SMESH::DRS_OK)
|
||||||
|
{
|
||||||
|
SALOMEDS::StudyBuilder_var aStudyBuilder = getStudyServant()->NewBuilder();
|
||||||
|
aStudyBuilder->NewCommand(); // There is a transaction
|
||||||
|
|
||||||
|
int i = 0;
|
||||||
|
|
||||||
|
// Iterate through all meshes and create mesh objects
|
||||||
|
for (; i < nbMeshes; ++i)
|
||||||
|
{
|
||||||
|
// Python Dump
|
||||||
|
if (i > 0) aPythonDump << ", ";
|
||||||
|
|
||||||
|
// create mesh
|
||||||
|
aResult[i] = SMESH::SMESH_Mesh::_duplicate(sourceMesh);
|
||||||
|
|
||||||
|
// Read mesh data (groups are published automatically by ImportMEDFile())
|
||||||
|
SMESH_Mesh_i* meshServant = dynamic_cast<SMESH_Mesh_i*>(GetServant(sourceMesh).in());
|
||||||
|
ASSERT(meshServant);
|
||||||
|
string meshName;
|
||||||
|
SMESH::DriverMED_ReadStatus status1 =
|
||||||
|
meshServant->ImportCGNSFile(theFileName, i, meshName);
|
||||||
|
if (status1 > theStatus)
|
||||||
|
theStatus = status1;
|
||||||
|
|
||||||
|
meshServant->GetImpl().GetMeshDS()->Modified();
|
||||||
|
// publish mesh in the study
|
||||||
|
SALOMEDS::SObject_wrap aSO;
|
||||||
|
if (CanPublishInStudy(sourceMesh))
|
||||||
|
aSO = PublishMesh(sourceMesh, meshName.c_str());
|
||||||
|
|
||||||
|
// Python Dump
|
||||||
|
if (!aSO->_is_nil()) {
|
||||||
|
aPythonDump << aSO;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
aPythonDump << "mesh_" << i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
aStudyBuilder->CommitCommand();
|
||||||
|
}
|
||||||
|
|
||||||
|
aPythonDump << "], status) = " << this << ".ReloadMeshesFromCGNS(r'" << theFileName << "')";
|
||||||
|
}
|
||||||
|
// Dump creation of groups
|
||||||
|
for (CORBA::ULong i = 0; i < aResult->length(); ++i)
|
||||||
|
SMESH::ListOfGroups_var groups = aResult[i]->GetGroups();
|
||||||
|
#else
|
||||||
|
THROW_SALOME_CORBA_EXCEPTION("CGNS library is unavailable", SALOME::INTERNAL_ERROR);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return aResult._retn();
|
||||||
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief Create a mesh and import data from a GMF file
|
* \brief Create a mesh and import data from a GMF file
|
||||||
@ -1682,6 +1964,38 @@ SMESH_Gen_i::CreateMeshesFromGMF( const char* theFileName,
|
|||||||
return aMesh._retn();
|
return aMesh._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr SMESH_Gen_i::ReloadMeshesFromGMF(const char* theFileName, SMESH::SMESH_Mesh_ptr sourceMesh, CORBA::Boolean theMakeRequiredGroups, SMESH::ComputeError_out theError)
|
||||||
|
{
|
||||||
|
Unexpect aCatch(SALOME_SalomeException);
|
||||||
|
checkFileReadable(theFileName);
|
||||||
|
|
||||||
|
#ifdef WIN32
|
||||||
|
char bname[_MAX_FNAME];
|
||||||
|
_splitpath(theFileName, NULL, NULL, bname, NULL);
|
||||||
|
string aFileName = bname;
|
||||||
|
#else
|
||||||
|
string aFileName = basename(const_cast<char*>(theFileName));
|
||||||
|
#endif
|
||||||
|
// publish mesh in the study
|
||||||
|
if (CanPublishInStudy(sourceMesh)) {
|
||||||
|
SALOMEDS::StudyBuilder_var aStudyBuilder = getStudyServant()->NewBuilder();
|
||||||
|
aStudyBuilder->NewCommand(); // There is a transaction
|
||||||
|
SALOMEDS::SObject_wrap aSO = PublishInStudy(SALOMEDS::SObject::_nil(), sourceMesh, aFileName.c_str());
|
||||||
|
aStudyBuilder->CommitCommand();
|
||||||
|
if (!aSO->_is_nil()) {
|
||||||
|
// Update Python script
|
||||||
|
TPythonDump(this) << "(" << aSO << ", error) = " << this << ".ReloadMeshesFromGMF(r'"
|
||||||
|
<< theFileName << "', "
|
||||||
|
<< theMakeRequiredGroups << " )";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
SMESH_Mesh_i* aServant = dynamic_cast<SMESH_Mesh_i*>(GetServant(sourceMesh).in());
|
||||||
|
ASSERT(aServant);
|
||||||
|
theError = aServant->ImportGMFFile(theFileName, theMakeRequiredGroups);
|
||||||
|
aServant->GetImpl().GetMeshDS()->Modified();
|
||||||
|
return sourceMesh;
|
||||||
|
}
|
||||||
|
|
||||||
//================================================================================
|
//================================================================================
|
||||||
/*!
|
/*!
|
||||||
* \brief Create a mesh and import data from any file supported by meshio library
|
* \brief Create a mesh and import data from any file supported by meshio library
|
||||||
@ -1768,6 +2082,82 @@ SMESH::mesh_array* SMESH_Gen_i::CreateMeshesFromMESHIO(const char* theFileName,
|
|||||||
return aResult._retn();
|
return aResult._retn();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SMESH::mesh_array* SMESH_Gen_i::ReloadMeshesFromMESHIO(const char* theFileName, SMESH::SMESH_Mesh_ptr sourceMesh, SMESH::DriverMED_ReadStatus& theStatus)
|
||||||
|
{
|
||||||
|
Unexpect aCatch(SALOME_SalomeException);
|
||||||
|
checkFileReadable(theFileName);
|
||||||
|
|
||||||
|
MESSAGE("Import part with meshio through an intermediate MED file");
|
||||||
|
|
||||||
|
// Create an object that holds a temp file name and
|
||||||
|
// removes the file when goes out of scope.
|
||||||
|
SMESH_Meshio meshio;
|
||||||
|
const QString tempFileName = meshio.CreateTempFileName(theFileName);
|
||||||
|
|
||||||
|
// Convert temp file into a target one with meshio command
|
||||||
|
meshio.Convert(theFileName, tempFileName);
|
||||||
|
|
||||||
|
// We don't need a python dump from SMESH_Gen_i::CreateMeshesFromMED(), so
|
||||||
|
// we can't use this method as is here. The followed code is an edited part of
|
||||||
|
// copy pasted CreateMeshesFromMED().
|
||||||
|
|
||||||
|
// Retrieve mesh names from the file
|
||||||
|
DriverMED_R_SMESHDS_Mesh myReader;
|
||||||
|
myReader.SetFile(tempFileName.toStdString());
|
||||||
|
myReader.SetMeshId(-1);
|
||||||
|
Driver_Mesh::Status aStatus;
|
||||||
|
list<string> aNames = myReader.GetMeshNames(aStatus);
|
||||||
|
SMESH::mesh_array_var aResult = new SMESH::mesh_array();
|
||||||
|
theStatus = (SMESH::DriverMED_ReadStatus)aStatus;
|
||||||
|
|
||||||
|
if (theStatus == SMESH::DRS_OK)
|
||||||
|
{
|
||||||
|
SALOMEDS::StudyBuilder_var aStudyBuilder;
|
||||||
|
aStudyBuilder = getStudyServant()->NewBuilder();
|
||||||
|
aStudyBuilder->NewCommand(); // There is a transaction
|
||||||
|
|
||||||
|
aResult->length(aNames.size());
|
||||||
|
std::vector<SALOMEDS::SObject_wrap> sobjects;
|
||||||
|
int i = 0;
|
||||||
|
|
||||||
|
// Iterate through all meshes and create mesh objects
|
||||||
|
for (const std::string& meshName : aNames)
|
||||||
|
{
|
||||||
|
// publish mesh in the study
|
||||||
|
SALOMEDS::SObject_wrap aSO;
|
||||||
|
if (CanPublishInStudy(sourceMesh))
|
||||||
|
aSO = PublishMesh(sourceMesh, meshName.c_str());
|
||||||
|
|
||||||
|
// Save SO to use in a python dump
|
||||||
|
sobjects.emplace_back(aSO);
|
||||||
|
|
||||||
|
// Read mesh data (groups are published automatically by ImportMEDFile())
|
||||||
|
SMESH_Mesh_i* meshServant = dynamic_cast<SMESH_Mesh_i*>(GetServant(sourceMesh).in());
|
||||||
|
ASSERT(meshServant);
|
||||||
|
SMESH::DriverMED_ReadStatus status1 =
|
||||||
|
meshServant->ImportMEDFile(tempFileName.toUtf8().data(), meshName.c_str());
|
||||||
|
if (status1 > theStatus)
|
||||||
|
theStatus = status1;
|
||||||
|
|
||||||
|
aResult[i++] = SMESH::SMESH_Mesh::_duplicate(sourceMesh);
|
||||||
|
meshServant->GetImpl().GetMeshDS()->Modified();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!aStudyBuilder->_is_nil())
|
||||||
|
aStudyBuilder->CommitCommand();
|
||||||
|
|
||||||
|
// Python dump
|
||||||
|
const std::string functionName = std::string(".ReloadMeshesFromMESHIO(r'") + theFileName + "')";
|
||||||
|
functionToPythonDump(this, functionName, sobjects);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Dump creation of groups
|
||||||
|
for (CORBA::ULong i = 0; i < aResult->length(); ++i)
|
||||||
|
SMESH::ListOfGroups_var groups = aResult[i]->GetGroups();
|
||||||
|
|
||||||
|
return aResult._retn();
|
||||||
|
}
|
||||||
|
|
||||||
//=============================================================================
|
//=============================================================================
|
||||||
/*!
|
/*!
|
||||||
* SMESH_Gen_i::IsReadyToCompute
|
* SMESH_Gen_i::IsReadyToCompute
|
||||||
|
@ -237,29 +237,54 @@ public:
|
|||||||
// Create empty mesh
|
// Create empty mesh
|
||||||
SMESH::SMESH_Mesh_ptr CreateEmptyMesh();
|
SMESH::SMESH_Mesh_ptr CreateEmptyMesh();
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr ReloadMeshFromFile(SMESH::SMESH_Mesh_ptr theMesh);
|
||||||
|
|
||||||
// Create a mesh and import data from an UNV file
|
// Create a mesh and import data from an UNV file
|
||||||
SMESH::SMESH_Mesh_ptr CreateMeshesFromUNV( const char* theFileName );
|
SMESH::SMESH_Mesh_ptr CreateMeshesFromUNV( const char* theFileName );
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr ReloadMeshesFromUNV(const char* theFileName,
|
||||||
|
SMESH::SMESH_Mesh_ptr sourceMesh);
|
||||||
|
|
||||||
// Create mesh(es) and import data from MED file
|
// Create mesh(es) and import data from MED file
|
||||||
SMESH::mesh_array* CreateMeshesFromMED( const char* theFileName,
|
SMESH::mesh_array* CreateMeshesFromMED( const char* theFileName,
|
||||||
SMESH::DriverMED_ReadStatus& theStatus );
|
SMESH::DriverMED_ReadStatus& theStatus );
|
||||||
|
|
||||||
|
SMESH::mesh_array* ReloadMeshesFromMED(const char* theFileName,
|
||||||
|
SMESH::SMESH_Mesh_ptr sourceMesh,
|
||||||
|
SMESH::DriverMED_ReadStatus& theStatus);
|
||||||
|
|
||||||
// Create a mesh and import data from a STL file
|
// Create a mesh and import data from a STL file
|
||||||
SMESH::SMESH_Mesh_ptr CreateMeshesFromSTL( const char* theFileName );
|
SMESH::SMESH_Mesh_ptr CreateMeshesFromSTL( const char* theFileName );
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr ReloadMeshesFromSTL(const char* theFileName,
|
||||||
|
SMESH::SMESH_Mesh_ptr sourceMesh);
|
||||||
|
|
||||||
// Create mesh(es) and import data from CGNS file
|
// Create mesh(es) and import data from CGNS file
|
||||||
SMESH::mesh_array* CreateMeshesFromCGNS( const char* theFileName,
|
SMESH::mesh_array* CreateMeshesFromCGNS( const char* theFileName,
|
||||||
SMESH::DriverMED_ReadStatus& theStatus );
|
SMESH::DriverMED_ReadStatus& theStatus );
|
||||||
|
|
||||||
|
SMESH::mesh_array* ReloadMeshesFromCGNS(const char* theFileName,
|
||||||
|
SMESH::SMESH_Mesh_ptr sourceMesh,
|
||||||
|
SMESH::DriverMED_ReadStatus& theStatus);
|
||||||
|
|
||||||
// Create a mesh and import data from a GMF file
|
// Create a mesh and import data from a GMF file
|
||||||
SMESH::SMESH_Mesh_ptr CreateMeshesFromGMF( const char* theFileName,
|
SMESH::SMESH_Mesh_ptr CreateMeshesFromGMF( const char* theFileName,
|
||||||
CORBA::Boolean theMakeRequiredGroups,
|
CORBA::Boolean theMakeRequiredGroups,
|
||||||
SMESH::ComputeError_out theError);
|
SMESH::ComputeError_out theError);
|
||||||
|
|
||||||
|
SMESH::SMESH_Mesh_ptr ReloadMeshesFromGMF(const char* theFileName,
|
||||||
|
SMESH::SMESH_Mesh_ptr sourceMesh,
|
||||||
|
CORBA::Boolean theMakeRequiredGroups,
|
||||||
|
SMESH::ComputeError_out theError);
|
||||||
|
|
||||||
// Create a mesh and import data from any file supported by meshio library
|
// Create a mesh and import data from any file supported by meshio library
|
||||||
SMESH::mesh_array* CreateMeshesFromMESHIO(const char* theFileName,
|
SMESH::mesh_array* CreateMeshesFromMESHIO(const char* theFileName,
|
||||||
SMESH::DriverMED_ReadStatus& theStatus);
|
SMESH::DriverMED_ReadStatus& theStatus);
|
||||||
|
|
||||||
|
SMESH::mesh_array* ReloadMeshesFromMESHIO(const char* theFileName,
|
||||||
|
SMESH::SMESH_Mesh_ptr sourceMesh,
|
||||||
|
SMESH::DriverMED_ReadStatus& theStatus);
|
||||||
|
|
||||||
// Create dual mesh of a tetrahedron mesh
|
// Create dual mesh of a tetrahedron mesh
|
||||||
SMESH::SMESH_Mesh_ptr CreateDualMesh(SMESH::SMESH_IDSource_ptr meshPart,
|
SMESH::SMESH_Mesh_ptr CreateDualMesh(SMESH::SMESH_IDSource_ptr meshPart,
|
||||||
const char* meshName,
|
const char* meshName,
|
||||||
|
@ -675,6 +675,14 @@ class smeshBuilder( SMESH._objref_SMESH_Gen, object ):
|
|||||||
global notebook
|
global notebook
|
||||||
notebook = salome_notebook.NoteBook( theIsEnablePublish )
|
notebook = salome_notebook.NoteBook( theIsEnablePublish )
|
||||||
|
|
||||||
|
def ReloadMeshFromFile(self, theMesh):
|
||||||
|
"""
|
||||||
|
Desc for method,
|
||||||
|
"""
|
||||||
|
|
||||||
|
aSmeshMesh = SMESH._objref_SMESH_Gen.ReloadMeshFromFile(self, theMesh)
|
||||||
|
aMesh = Mesh(self, self.geompyD, aSmeshMesh)
|
||||||
|
return aMesh
|
||||||
|
|
||||||
def CreateMeshesFromUNV( self,theFileName ):
|
def CreateMeshesFromUNV( self,theFileName ):
|
||||||
"""
|
"""
|
||||||
|
Loading…
Reference in New Issue
Block a user