mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-03-24 16:27:56 +05:00
399 lines
13 KiB
C++
399 lines
13 KiB
C++
// Copyright (C) 2013 CEA/DEN, EDF R&D, OPEN CASCADE
|
|
//
|
|
// 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.
|
|
//
|
|
// 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
|
|
|
|
#include <cmath>
|
|
#include <iostream>
|
|
#include <sstream>
|
|
|
|
#include <Standard_Stream.hxx>
|
|
|
|
#include "GEOMImpl_Types.hxx"
|
|
#include "GEOMImpl_IImportExportOperations.hxx"
|
|
#include "GEOMImpl_IBasicOperations.hxx"
|
|
#include "GEOMImpl_IBooleanOperations.hxx"
|
|
#include "GEOMImpl_IShapesOperations.hxx"
|
|
#include "GEOMImpl_ITransformOperations.hxx"
|
|
#include "GEOMImpl_IBlocksOperations.hxx"
|
|
#include "GEOMImpl_I3DPrimOperations.hxx"
|
|
#include "GEOMImpl_ILocalOperations.hxx"
|
|
#include "GEOMImpl_IHealingOperations.hxx"
|
|
|
|
#include "GEOMImpl_Gen.hxx"
|
|
|
|
#include <Basics_OCCTVersion.hxx>
|
|
|
|
#include <utilities.h>
|
|
#include <OpUtil.hxx>
|
|
#include <Utils_ExceptHandlers.hxx>
|
|
|
|
#include "GEOM_Function.hxx"
|
|
#include "GEOM_PythonDump.hxx"
|
|
|
|
#include "Xao.hxx"
|
|
#include "Geometry.hxx"
|
|
#include "Group.hxx"
|
|
#include "XaoUtils.hxx"
|
|
|
|
#include <GEOMImpl_XAODriver.hxx>
|
|
#include <GEOMImpl_IImportExportXAO.hxx>
|
|
/*@@ insert new functions before this line @@ do not remove this line @@ do not remove this line @@*/
|
|
|
|
#include <TopExp.hxx>
|
|
#include <TopExp_Explorer.hxx>
|
|
#include <TopoDS.hxx>
|
|
#include <TopoDS_Shape.hxx>
|
|
#include <TopoDS_Vertex.hxx>
|
|
#include <TopAbs.hxx>
|
|
#include <TopTools_IndexedMapOfShape.hxx>
|
|
|
|
#include <TCollection_AsciiString.hxx>
|
|
|
|
#include <TColStd_HSequenceOfTransient.hxx>
|
|
#include <Standard_Transient.hxx>
|
|
|
|
#include <gp_Pnt.hxx>
|
|
#include <gp_Vec.hxx>
|
|
#include <gp_Ax3.hxx>
|
|
#include <BRepBuilderAPI_Transform.hxx>
|
|
#include <BRep_Tool.hxx>
|
|
#include <BRep_Builder.hxx>
|
|
#include <BRepTools.hxx>
|
|
|
|
|
|
#include <TFunction_DriverTable.hxx>
|
|
#include <TFunction_Driver.hxx>
|
|
#include <TFunction_Logbook.hxx>
|
|
#include <TDataStd_Integer.hxx>
|
|
#include <TDF_Tool.hxx>
|
|
#include <Standard_Failure.hxx>
|
|
#include <Standard_ErrorHandler.hxx> // CAREFUL ! position of this file is critic : see Lucien PIGNOLONI / OCC
|
|
//=============================================================================
|
|
/*!
|
|
* Constructor
|
|
*/
|
|
//=============================================================================
|
|
GEOMImpl_IImportExportOperations::GEOMImpl_IImportExportOperations(GEOM_Engine* engine, int docID) :
|
|
GEOM_IOperations(engine, docID)
|
|
{
|
|
MESSAGE("GEOMImpl_IImportExportOperations::GEOMImpl_IImportExportOperations");
|
|
m_shapesOperations = new GEOMImpl_IShapesOperations(GetEngine(), GetDocID());
|
|
m_groupOperations = new GEOMImpl_IGroupOperations(GetEngine(), GetDocID());
|
|
}
|
|
|
|
//=============================================================================
|
|
/*!
|
|
* Destructor
|
|
*/
|
|
//=============================================================================
|
|
GEOMImpl_IImportExportOperations::~GEOMImpl_IImportExportOperations()
|
|
{
|
|
MESSAGE("GEOMImpl_IImportExportOperations::~GEOMImpl_IImportExportOperations");
|
|
delete m_shapesOperations;
|
|
delete m_groupOperations;
|
|
}
|
|
|
|
TopAbs_ShapeEnum getGroupDimension(XAO::Group* group)
|
|
{
|
|
XAO::Dimension dim = group->getDimension();
|
|
if (dim == XAO::VERTEX)
|
|
return TopAbs_VERTEX;
|
|
if (dim == XAO::EDGE)
|
|
return TopAbs_EDGE;
|
|
if (dim == XAO::FACE)
|
|
return TopAbs_FACE;
|
|
if (dim == XAO::SOLID)
|
|
return TopAbs_SOLID;
|
|
return TopAbs_COMPOUND;
|
|
}
|
|
|
|
//=============================================================================
|
|
/*!
|
|
* Export a shape to XAO format
|
|
* \param shape The shape to export
|
|
* \param groups The list of groups to export
|
|
* \param fields The list of fields to export
|
|
* \param fileName The name of the file to exported
|
|
* \return boolean indicating if export was succeful.
|
|
*/
|
|
//=============================================================================
|
|
bool GEOMImpl_IImportExportOperations::ExportXAO(Handle(GEOM_Object) shape,
|
|
std::list<Handle(GEOM_Object)> groupList,
|
|
std::list<Handle(GEOM_Object)> fieldList,
|
|
const char* author,
|
|
const char* fileName)
|
|
{
|
|
SetErrorCode(KO);
|
|
|
|
if (shape.IsNull()) return false;
|
|
|
|
// add a new shape function with parameters
|
|
Handle(GEOM_Function) lastFunction = shape->GetLastFunction();
|
|
if (lastFunction.IsNull()) return false;
|
|
|
|
// add a new result object
|
|
Handle(GEOM_Object) result = GetEngine()->AddObject(GetDocID(), GEOM_IMPORT);
|
|
|
|
// add an Export function
|
|
Handle(GEOM_Function) exportFunction = result->AddFunction(GEOMImpl_XAODriver::GetID(), IMPORTEXPORT_EXPORTXAO);
|
|
if (exportFunction.IsNull()) return false;
|
|
if (exportFunction->GetDriverGUID() != GEOMImpl_XAODriver::GetID()) return false;
|
|
|
|
// Build the XAO
|
|
XAO::Xao* xaoObject = new XAO::Xao();
|
|
xaoObject->setAuthor(author);
|
|
|
|
XAO::Geometry* geometry = new XAO::Geometry();
|
|
TopoDS_Shape topoShape = shape->GetValue();
|
|
exportFunction->SetValue(topoShape);
|
|
geometry->setShape(topoShape);
|
|
geometry->setName(shape->GetName());
|
|
|
|
Handle(TColStd_HSequenceOfTransient) subObjects = m_shapesOperations->GetExistingSubObjects(shape, false);
|
|
int nbSubObjects = subObjects->Length();
|
|
|
|
// set the names of the sub shapes
|
|
int tmpIndex;
|
|
for (int i = 1; i <= nbSubObjects; i++)
|
|
{
|
|
Handle(Standard_Transient) transientSubObject = subObjects->Value(i);
|
|
if (transientSubObject.IsNull())
|
|
continue;
|
|
|
|
Handle(GEOM_Object) subObject = Handle(GEOM_Object)::DownCast(transientSubObject);
|
|
if (subObject->GetType() != GEOM_GROUP)
|
|
{
|
|
int subIndex = m_shapesOperations->GetSubShapeIndex(shape, subObject);
|
|
// convert index to a string
|
|
std::stringstream str;
|
|
str << subIndex;
|
|
std::string strIndex = str.str();
|
|
|
|
switch (subObject->GetValue().ShapeType())
|
|
{
|
|
case TopAbs_VERTEX:
|
|
tmpIndex = geometry->getVertexIndexByReference(strIndex.c_str());
|
|
geometry->setVertexName(tmpIndex, subObject->GetName());
|
|
break;
|
|
case TopAbs_EDGE:
|
|
tmpIndex = geometry->getEdgeIndexByReference(strIndex.c_str());
|
|
geometry->setEdgeName(tmpIndex, subObject->GetName());
|
|
break;
|
|
case TopAbs_FACE:
|
|
tmpIndex = geometry->getFaceIndexByReference(strIndex.c_str());
|
|
geometry->setFaceName(tmpIndex, subObject->GetName());
|
|
break;
|
|
case TopAbs_SOLID:
|
|
tmpIndex = geometry->getSolidIndexByReference(strIndex.c_str());
|
|
geometry->setSolidName(tmpIndex, subObject->GetName());
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
xaoObject->setGeometry(geometry);
|
|
|
|
// add the groups
|
|
std::list<Handle(GEOM_Object)>::iterator groupIterator = groupList.begin();
|
|
while (groupIterator != groupList.end())
|
|
{
|
|
Handle(GEOM_Object) currGroup = (*groupIterator++);
|
|
Handle(TColStd_HArray1OfInteger) groupIds = m_groupOperations->GetObjects(currGroup);
|
|
XAO::Group* group = new XAO::Group();
|
|
group->setName(currGroup->GetName());
|
|
|
|
TopAbs_ShapeEnum shapeGroup = m_groupOperations->GetType(currGroup);
|
|
switch (shapeGroup)
|
|
{
|
|
case TopAbs_VERTEX:
|
|
group->setDimension(XAO::VERTEX);
|
|
for (int i = 1; i <= groupIds->Length(); i++)
|
|
{
|
|
const char* ref = XAO::XaoUtils::intToString(groupIds->Value(i));
|
|
const int index = geometry->getVertexIndexByReference(ref);
|
|
group->addElement(index);
|
|
}
|
|
break;
|
|
case TopAbs_EDGE:
|
|
group->setDimension(XAO::EDGE);
|
|
for (int i = 1; i <= groupIds->Length(); i++)
|
|
{
|
|
const char* ref = XAO::XaoUtils::intToString(groupIds->Value(i));
|
|
const int index = geometry->getEdgeIndexByReference(ref);
|
|
group->addElement(index);
|
|
}
|
|
break;
|
|
case TopAbs_FACE:
|
|
group->setDimension(XAO::FACE);
|
|
for (int i = 1; i <= groupIds->Length(); i++)
|
|
{
|
|
const char* ref = XAO::XaoUtils::intToString(groupIds->Value(i));
|
|
const int index = geometry->getFaceIndexByReference(ref);
|
|
group->addElement(index);
|
|
}
|
|
break;
|
|
case TopAbs_SOLID:
|
|
group->setDimension(XAO::SOLID);
|
|
for (int i = 1; i <= groupIds->Length(); i++)
|
|
{
|
|
const char* ref = XAO::XaoUtils::intToString(groupIds->Value(i));
|
|
const int index = geometry->getSolidIndexByReference(ref);
|
|
group->addElement(index);
|
|
}
|
|
break;
|
|
}
|
|
|
|
xaoObject->addGroup(group);
|
|
}
|
|
|
|
// TODO: add the fields
|
|
|
|
// export the XAO to the file
|
|
xaoObject->exportXAO(fileName);
|
|
delete xaoObject;
|
|
|
|
// make a Python command
|
|
GEOM::TPythonDump pd(exportFunction);
|
|
pd << "exported = geompy.ExportXAO(";
|
|
|
|
pd << shape;
|
|
pd << ", [";
|
|
|
|
if (groupList.size() > 0)
|
|
{
|
|
std::list<Handle(GEOM_Object)>::iterator itG = groupList.begin();
|
|
pd << (*itG++);
|
|
while (itG != groupList.end())
|
|
{
|
|
pd << ", " << (*itG++);
|
|
}
|
|
}
|
|
pd << "], [";
|
|
if (fieldList.size() > 0)
|
|
{
|
|
std::list<Handle(GEOM_Object)>::iterator itF = fieldList.begin();
|
|
pd << (*itF++);
|
|
while (itF != fieldList.end())
|
|
{
|
|
pd << ", " << (*itF++);
|
|
}
|
|
}
|
|
pd << "], ";
|
|
pd << author << ", \"" << fileName << "\")";
|
|
|
|
SetErrorCode(OK);
|
|
|
|
return true;
|
|
}
|
|
|
|
//=============================================================================
|
|
/*!
|
|
* Import a shape from XAO format
|
|
* \param fileName The name of the file to import
|
|
* \param shape The imported shape
|
|
* \param groups The list of imported groups
|
|
* \param fields The list of imported fields
|
|
* \return boolean indicating if import was succeful.
|
|
*/
|
|
//=============================================================================
|
|
bool GEOMImpl_IImportExportOperations::ImportXAO(const char* fileName,
|
|
Handle(GEOM_Object)& shape,
|
|
Handle(TColStd_HSequenceOfTransient)& groupList,
|
|
Handle(TColStd_HSequenceOfTransient)& fieldList)
|
|
{
|
|
SetErrorCode(KO);
|
|
|
|
if (fileName == NULL || groupList.IsNull() || fieldList.IsNull())
|
|
return false;
|
|
|
|
// Read the XAO
|
|
XAO::Xao* xaoObject = new XAO::Xao();
|
|
xaoObject->importXAO(fileName);
|
|
|
|
XAO::Geometry* xaoGeometry = xaoObject->getGeometry();
|
|
if (xaoGeometry == NULL)
|
|
return false;
|
|
|
|
// create the shape
|
|
shape = GetEngine()->AddObject(GetDocID(), GEOM_IMPORT);
|
|
Handle(GEOM_Function) function = shape->AddFunction(GEOMImpl_XAODriver::GetID(), IMPORTEXPORT_EXPORTXAO);
|
|
if (function.IsNull()) return false;
|
|
if (function->GetDriverGUID() != GEOMImpl_XAODriver::GetID()) return false;
|
|
|
|
// set the geometry
|
|
TopoDS_Shape geomShape = xaoGeometry->getShape();
|
|
function->SetValue(geomShape);
|
|
shape->SetName(xaoGeometry->getName());
|
|
|
|
// TODO: create sub shapes with names
|
|
|
|
// create groups
|
|
int nbGroups = xaoObject->countGroups();
|
|
for (int i = 0; i < nbGroups; ++i)
|
|
{
|
|
XAO::Group* xaoGroup = xaoObject->getGroup(i);
|
|
|
|
// build an array with the indexes of the sub shapes
|
|
int nbElt = xaoGroup->getCount();
|
|
Handle(TColStd_HArray1OfInteger) array = new TColStd_HArray1OfInteger(1, nbElt);
|
|
for (int j = 0; j < nbElt; j++)
|
|
{
|
|
int index = xaoGroup->getElement(j);
|
|
const char* ref = xaoGeometry->getElementReference(xaoGroup->getDimension(), index);
|
|
array->SetValue(j + 1, atoi(ref));
|
|
}
|
|
|
|
// create the group with the array of sub shapes indexes
|
|
Handle(GEOM_Object) group = GetEngine()->AddSubShape(shape, array);
|
|
group->SetType(GEOM_GROUP);
|
|
group->SetName(xaoGroup->getName());
|
|
|
|
// Set a sub-shape type
|
|
TDF_Label freeLabel = group->GetFreeLabel();
|
|
TDataStd_Integer::Set(freeLabel, (Standard_Integer) getGroupDimension(xaoGroup));
|
|
groupList->Append(group);
|
|
|
|
function = group->GetLastFunction();
|
|
}
|
|
|
|
// TODO: create the fields
|
|
|
|
// make a Python command
|
|
GEOM::TPythonDump pd(function);
|
|
pd << "(imported, " << shape << ", ";
|
|
|
|
pd << "[";
|
|
if (nbGroups > 0)
|
|
{
|
|
for (int i = 1; i <= nbGroups; i++)
|
|
{
|
|
Handle(GEOM_Object) obj = Handle(GEOM_Object)::DownCast(groupList->Value(i));
|
|
pd << obj << ((i < nbGroups) ? ", " : "");
|
|
}
|
|
}
|
|
pd << "], []";
|
|
|
|
pd << ") = geompy.ImportXAO(\"" << fileName << "\")";
|
|
|
|
delete xaoObject;
|
|
SetErrorCode(OK);
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
/*@@ insert new functions before this line @@ do not remove this line @@ do not remove this line @@*/
|