1 # Copyright (C) 2014-2019 CEA/DEN, EDF R&D
3 # This library is free software; you can redistribute it and/or
4 # modify it under the terms of the GNU Lesser General Public
5 # License as published by the Free Software Foundation; either
6 # version 2.1 of the License, or (at your option) any later version.
8 # This library is distributed in the hope that it will be useful,
9 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 # Lesser General Public License for more details.
13 # You should have received a copy of the GNU Lesser General Public
14 # License along with this library; if not, write to the Free Software
15 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 # ExportFeature class definition
28 from salome.geom import geomBuilder
30 from salome.shaper import model
35 # Feature to export all shapes and groups into the GEOM module
36 class ExportFeature(ModelAPI.ModelAPI_Feature):
40 ModelAPI.ModelAPI_Feature.__init__(self)
44 ## Export kind. Static.
48 ## Returns the kind of a feature.
50 return ExportFeature.ID()
52 ## This feature is action: has no property panel and executes immediately.
56 ## This feature has no attributes, as it is action.
57 def initAttributes(self):
60 ## Export the results, groups and fields via XAO
61 def exportViaXAO(self):
62 # if part-set is active, iterate also parts
63 for isPart in (True, False):
64 aResultType = model.ModelAPI_ResultBody_group()
66 aResultType = model.ModelAPI_ResultPart_group()
67 # iterate all results of Part, export one by one due to issue 2882
68 for aResIndex in range(self.Part.size(aResultType)):
69 anObject = self.Part.object(aResultType, aResIndex)
70 aResult = model.objectToResult(anObject)
71 if not aResult is None:
72 if (not aResult.shape() or aResult.shape().isNull()) and isPart:
73 aPart = model.modelAPI_ResultPart(aResult)
74 aPartDoc = aPart.partDoc()
75 if not aPartDoc or not aPartDoc.isOpened():
76 EventsAPI.Events_InfoMessage("ExportToGEOM", "For export to GEOM some Part is not activated", self).send()
79 if not aResult.shape() or aResult.shape().isNull():
81 tmpXAOFile = model.getTmpFileName("shaper_", ".xao")
82 self.tmpXAOFile = tmpXAOFile
83 #print "Export to %s"%tmpXAOFile
84 exportXAO = ExchangeAPI.exportToXAO(self.Part, tmpXAOFile, model.selection(aResult), "automatic_shaper_export_to_XAO")
85 if not os.path.exists(tmpXAOFile) or os.stat(tmpXAOFile).st_size == 0:
86 exportXAO.feature().setError("Error in exportToXAO. No XAO file has been created.")
88 imported, shape, subShapes, groups, fields = self.geompy.ImportXAO(tmpXAOFile)
89 self.geompy.addToStudy( shape, shape.GetName() )
90 # add sub-shapes and groups to the object browser
91 for obj in subShapes + groups:
93 self.geompy.addToStudyInFather(shape, obj, name)
94 # add fields to the object browser
96 name = field.GetName()
97 self.geompy.addToStudyInFather(shape, field, name)
98 # add steps to the object browser
99 steps = field.getSteps()
101 step = field.getStep(i_step)
102 i_stamp = step.GetStamp()
103 step_name = "Step %i %i"%(i_step, i_stamp)
104 self.geompy.addToStudyInFather( field, step, step_name )
105 # Remove the temporary file
106 os.remove(tmpXAOFile)
111 ## Exports all shapes and groups into the GEOM module.
113 aSession = ModelAPI.ModelAPI_Session.get()
114 ## Get active document
115 self.Part = aSession.activeDocument()
116 ## List of objects created in the old geom for later use
117 self.geomObjects = []
119 salome.salome_init(1)
120 self.geompy = geomBuilder.New()