// 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 #include #include #include #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 #include #include #include #include "GEOM_Function.hxx" #include "GEOM_PythonDump.hxx" #include "Xao.hxx" #include "Geometry.hxx" #include "Group.hxx" #include "XaoUtils.hxx" #include #include /*@@ insert new functions before this line @@ do not remove this line @@ do not remove this line @@*/ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include // 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 groupList, std::list 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::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::iterator itG = groupList.begin(); pd << (*itG++); while (itG != groupList.end()) { pd << ", " << (*itG++); } } pd << "], ["; if (fieldList.size() > 0) { std::list::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 @@*/