Mantis issue 0021511: EDF 2153 GEOM: Choose to take units into account or not when importing a STEP file

This commit is contained in:
jfa 2012-11-01 08:24:37 +00:00
parent 19973ebc85
commit 368a824418
9 changed files with 95 additions and 52 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.3 KiB

After

Width:  |  Height:  |  Size: 10 KiB

View File

@ -22,10 +22,10 @@ Select the required file and click \b Open. Your file will be imported in
the module and its contents (geometrical object) will be displayed in the module and its contents (geometrical object) will be displayed in
the <b>Object Browser</b>. the <b>Object Browser</b>.
\note If the selected file is in IGES format and the length is not \note If the selected file is in IGES or in STEP format and the length
expressed in meters, it will be suggested to scale the model into the is not expressed in meters, it will be asked to take or not these
metric system (see the picture below). This feature can be helpful if units into account (see the picture below). This feature can be
some wrong units have been written to the IGES file by a helpful if some wrong units have been written to the IGES file by a
3rd-party software. 3rd-party software.
\image html iges_unit.png \image html iges_unit.png

View File

@ -3289,8 +3289,9 @@ module GEOM
* \param theFileName The file, containing the shape. * \param theFileName The file, containing the shape.
* \param theFormatName Specify format for the file reading. * \param theFormatName Specify format for the file reading.
* Available formats can be obtained with <VAR>ImportTranslators()</VAR> method. * Available formats can be obtained with <VAR>ImportTranslators()</VAR> method.
* If format 'IGES_SCALE' is used instead 'IGES' length unit will be * If format 'IGES_SCALE' is used instead of 'IGES' or
* set to 'meter' and result model will be scaled. * format 'STEP_SCALE' is used instead of 'STEP',
* file length unit will be ignored (set to 'meter') and result model will be scaled.
* \return New GEOM_Object, containing the imported shape. * \return New GEOM_Object, containing the imported shape.
*/ */
GEOM_Object ImportFile (in string theFileName, in string theFormatName); GEOM_Object ImportFile (in string theFileName, in string theFormatName);

View File

@ -246,9 +246,22 @@ Handle(GEOM_Object) GEOMImpl_IInsertOperations::Import
} }
//Make a Python command //Make a Python command
if( theFormatName != "IGES_UNIT" ) { if (theFormatName != "IGES_UNIT") {
GEOM::TPythonDump(aFunction) << result << " = geompy.ImportFile(\"" GEOM::TPythonDump pd (aFunction);
<< theFileName.ToCString() << "\", \"" << theFormatName.ToCString() << "\")"; if (theFormatName == "BREP")
pd << result << " = geompy.ImportBREP(\"" << theFileName.ToCString() << "\")";
else if (theFormatName == "IGES")
pd << result << " = geompy.ImportIGES(\"" << theFileName.ToCString() << "\")";
else if (theFormatName == "IGES_SCALE")
pd << result << " = geompy.ImportIGES(\"" << theFileName.ToCString() << "\", True)";
else if (theFormatName == "STEP")
pd << result << " = geompy.ImportSTEP(\"" << theFileName.ToCString() << "\")";
else if (theFormatName == "STEP_SCALE")
pd << result << " = geompy.ImportSTEP(\"" << theFileName.ToCString() << "\", True)";
else {
pd << result << " = geompy.ImportFile(\""
<< theFileName.ToCString() << "\", \"" << theFormatName.ToCString() << "\")";
}
} }
SetErrorCode(OK); SetErrorCode(OK);
@ -260,9 +273,9 @@ Handle(GEOM_Object) GEOMImpl_IInsertOperations::Import
gp_Pnt P = BRep_Tool::Pnt(V); gp_Pnt P = BRep_Tool::Pnt(V);
double scale = P.X(); double scale = P.X();
TCollection_AsciiString aUnitName = "UNIT_M"; TCollection_AsciiString aUnitName = "UNIT_M";
if( fabs(scale-0.01) < 1.e-6 ) if (fabs(scale-0.01) < 1.e-6)
aUnitName = "UNIT_CM"; aUnitName = "UNIT_CM";
else if( fabs(scale-0.001) < 1.e-6 ) else if (fabs(scale-0.001) < 1.e-6)
aUnitName = "UNIT_MM"; aUnitName = "UNIT_MM";
//cout<<"IIO: aUnitName = "<<aUnitName.ToCString()<<endl; //cout<<"IIO: aUnitName = "<<aUnitName.ToCString()<<endl;
SetErrorCode(aUnitName); SetErrorCode(aUnitName);

View File

@ -651,7 +651,7 @@ bool GEOMToolsGUI::Import()
CORBA::String_var aUnits = aInsOp->ReadValue(fileN, fileT, "LEN_UNITS"); CORBA::String_var aUnits = aInsOp->ReadValue(fileN, fileT, "LEN_UNITS");
TCollection_AsciiString aUnitsStr (aUnits.in()); TCollection_AsciiString aUnitsStr (aUnits.in());
bool needConvert = true; bool needConvert = true;
if (aUnitsStr.IsEmpty() || aUnitsStr == "UNIT_M") if (aUnitsStr.IsEmpty() || aUnitsStr == "M")
needConvert = false; needConvert = false;
if (needConvert) { if (needConvert) {

View File

@ -78,16 +78,25 @@ def TestExportImport (geompy, shape):
# Import # Import
Import = geompy.ImportFile(fileExportImport, "BREP") Import = geompy.ImportFile(fileExportImport, "BREP")
id_Import = geompy.addToStudy(Import, "Import") geompy.addToStudy(Import, "Import")
# ImportBREP, ImportIGES, ImportSTEP # ImportBREP, ImportIGES, ImportSTEP
ImportBREP = geompy.ImportBREP(fileExportImportBREP) ImportBREP = geompy.ImportBREP(fileExportImportBREP)
ImportIGES = geompy.ImportIGES(fileExportImportIGES) ImportIGES = geompy.ImportIGES(fileExportImportIGES)
ImportSTEP = geompy.ImportSTEP(fileExportImportSTEP) ImportSTEP = geompy.ImportSTEP(fileExportImportSTEP)
id_ImportBREP = geompy.addToStudy(ImportBREP, "ImportBREP") geompy.addToStudy(ImportBREP, "ImportBREP")
id_ImportIGES = geompy.addToStudy(ImportIGES, "ImportIGES") geompy.addToStudy(ImportIGES, "ImportIGES")
id_ImportSTEP = geompy.addToStudy(ImportSTEP, "ImportSTEP") geompy.addToStudy(ImportSTEP, "ImportSTEP")
# GetIGESUnit and GetSTEPUnit
if geompy.GetIGESUnit(fileExportImportIGES) != "M":
ImportIGES_scaled = geompy.ImportIGES(fileExportImportIGES, True)
geompy.addToStudy(ImportIGES_scaled, "ImportIGES_scaled")
if geompy.GetSTEPUnit(fileExportImportSTEP) != "M":
ImportSTEP_scaled = geompy.ImportSTEP(fileExportImportSTEP, True)
geompy.addToStudy(ImportSTEP_scaled, "ImportSTEP_scaled")
# Remove files for Export/Import testing # Remove files for Export/Import testing
os.remove(fileExportImport) os.remove(fileExportImport)

View File

@ -7321,12 +7321,13 @@ class geompyDC(GEOM._objref_GEOM_Gen):
# @param theFileName The file, containing the shape. # @param theFileName The file, containing the shape.
# @param theFormatName Specify format for the file reading. # @param theFormatName Specify format for the file reading.
# Available formats can be obtained with InsertOp.ImportTranslators() method. # Available formats can be obtained with InsertOp.ImportTranslators() method.
# If format 'IGES_SCALE' is used instead 'IGES' length unit will be # If format 'IGES_SCALE' is used instead of 'IGES' or
# set to 'meter' and result model will be scaled. # format 'STEP_SCALE' is used instead of 'STEP',
# length unit will be set to 'meter' and result model will be scaled.
# @return New GEOM.GEOM_Object, containing the imported shape. # @return New GEOM.GEOM_Object, containing the imported shape.
# #
# @ref swig_Import_Export "Example" # @ref swig_Import_Export "Example"
def ImportFile(self,theFileName, theFormatName): def ImportFile(self, theFileName, theFormatName):
""" """
Import a shape from the BREP or IGES or STEP file Import a shape from the BREP or IGES or STEP file
(depends on given format) with given name. (depends on given format) with given name.
@ -7334,9 +7335,10 @@ class geompyDC(GEOM._objref_GEOM_Gen):
Parameters: Parameters:
theFileName The file, containing the shape. theFileName The file, containing the shape.
theFormatName Specify format for the file reading. theFormatName Specify format for the file reading.
Available formats can be obtained with geompy.InsertOp.ImportTranslators() method. Available formats can be obtained with geompy.InsertOp.ImportTranslators() method.
If format 'IGES_SCALE' is used instead 'IGES' length unit will be If format 'IGES_SCALE' is used instead of 'IGES' or
set to 'meter' and result model will be scaled. format 'STEP_SCALE' is used instead of 'STEP',
length unit will be set to 'meter' and result model will be scaled.
Returns: Returns:
New GEOM.GEOM_Object, containing the imported shape. New GEOM.GEOM_Object, containing the imported shape.
@ -7347,7 +7349,7 @@ class geompyDC(GEOM._objref_GEOM_Gen):
return anObj return anObj
## Deprecated analog of ImportFile() ## Deprecated analog of ImportFile()
def Import(self,theFileName, theFormatName): def Import(self, theFileName, theFormatName):
""" """
Deprecated analog of geompy.ImportFile Deprecated analog of geompy.ImportFile
""" """
@ -7359,7 +7361,7 @@ class geompyDC(GEOM._objref_GEOM_Gen):
## Shortcut to ImportFile() for BREP format ## Shortcut to ImportFile() for BREP format
# #
# @ref swig_Import_Export "Example" # @ref swig_Import_Export "Example"
def ImportBREP(self,theFileName): def ImportBREP(self, theFileName):
""" """
geompy.ImportFile(...) function for BREP format geompy.ImportFile(...) function for BREP format
""" """
@ -7367,49 +7369,67 @@ class geompyDC(GEOM._objref_GEOM_Gen):
return self.ImportFile(theFileName, "BREP") return self.ImportFile(theFileName, "BREP")
## Shortcut to ImportFile() for IGES format ## Shortcut to ImportFile() for IGES format
# @param doScale If True, file length units will be ignored (set to 'meter')
# and result model will be scaled.
# If False (default), file length units will be taken into account.
# #
# @ref swig_Import_Export "Example" # @ref swig_Import_Export "Example"
def ImportIGES(self,theFileName): def ImportIGES(self, theFileName, doScale = False):
""" """
geompy.ImportFile(...) function for IGES format geompy.ImportFile(...) function for IGES format
Parameters:
doScale If True, file length units will be ignored (set to 'meter')
and result model will be scaled.
If False (default), file length units will be taken into account.
""" """
# Example: see GEOM_TestOthers.py # Example: see GEOM_TestOthers.py
if doScale:
return self.ImportFile(theFileName, "IGES_SCALE")
return self.ImportFile(theFileName, "IGES") return self.ImportFile(theFileName, "IGES")
## Return length unit from given IGES file ## Return length unit from given IGES file
# @param doScale If True, file length units will be ignored (set to 'meter')
# and result model will be scaled.
# If False (default), file length units will be taken into account.
# #
# @ref swig_Import_Export "Example" # @ref swig_Import_Export "Example"
def GetIGESUnit(self,theFileName): def GetIGESUnit(self, theFileName, doScale = False):
""" """
Return length unit from given IGES file Return length units from given IGES file
""" """
# Example: see GEOM_TestOthers.py # Example: see GEOM_TestOthers.py
anObj = self.InsertOp.ImportFile(theFileName, "IGES_UNIT") aUnitName = self.InsertOp.ReadValue(theFileName, "IGES", "LEN_UNITS")
#RaiseIfFailed("Import", self.InsertOp) return aUnitName
# recieve name using returned vertex
UnitName = "M"
if anObj.GetShapeType() == GEOM.VERTEX:
vertices = [anObj]
else:
vertices = self.SubShapeAll(anObj,ShapeType["VERTEX"])
if len(vertices)>0:
p = self.PointCoordinates(vertices[0])
if abs(p[0]-0.01) < 1.e-6:
UnitName = "CM"
elif abs(p[0]-0.001) < 1.e-6:
UnitName = "MM"
return UnitName
## Shortcut to ImportFile() for STEP format ## Shortcut to ImportFile() for STEP format
# #
# @ref swig_Import_Export "Example" # @ref swig_Import_Export "Example"
def ImportSTEP(self,theFileName): def ImportSTEP(self, theFileName, doScale = False):
""" """
geompy.ImportFile(...) function for STEP format geompy.ImportFile(...) function for STEP format
Parameters:
doScale If True, file length units will be ignored (set to 'meter')
and result model will be scaled.
If False (default), file length units will be taken into account.
""" """
# Example: see GEOM_TestOthers.py # Example: see GEOM_TestOthers.py
if doScale:
return self.ImportFile(theFileName, "STEP_SCALE")
return self.ImportFile(theFileName, "STEP") return self.ImportFile(theFileName, "STEP")
## Return length unit from given IGES or STEP file
#
# @ref swig_Import_Export "Example"
def GetSTEPUnit(self, theFileName):
"""
Return length units from given STEP file
"""
# Example: see GEOM_TestOthers.py
aUnitName = self.InsertOp.ReadValue(theFileName, "STEP", "LEN_UNITS")
return aUnitName
## Read a shape from the binary stream, containing its bounding representation (BRep). ## Read a shape from the binary stream, containing its bounding representation (BRep).
# @note This method will not be dumped to the python script by DumpStudy functionality. # @note This method will not be dumped to the python script by DumpStudy functionality.
# @note GEOM.GEOM_Object.GetShapeStream() method can be used to obtain the shape's BRep stream. # @note GEOM.GEOM_Object.GetShapeStream() method can be used to obtain the shape's BRep stream.
@ -7442,7 +7462,7 @@ class geompyDC(GEOM._objref_GEOM_Gen):
# Available formats can be obtained with InsertOp.ImportTranslators() method. # Available formats can be obtained with InsertOp.ImportTranslators() method.
# #
# @ref swig_Import_Export "Example" # @ref swig_Import_Export "Example"
def Export(self,theObject, theFileName, theFormatName): def Export(self, theObject, theFileName, theFormatName):
""" """
Export the given shape into a file with given name. Export the given shape into a file with given name.

View File

@ -108,10 +108,10 @@ extern "C"
if (!aModel.IsNull()) { if (!aModel.IsNull()) {
aValue = aModel->GlobalSection().UnitName(); aValue = aModel->GlobalSection().UnitName();
if (!aValue.IsNull()) { //if (!aValue.IsNull()) {
Handle(TCollection_HAsciiString) aPrefix = new TCollection_HAsciiString ("UNIT_"); // Handle(TCollection_HAsciiString) aPrefix = new TCollection_HAsciiString ("UNIT_");
aValue->Prepend(aPrefix); // aValue->Prepend(aPrefix);
} //}
} }
} }
else { else {

View File

@ -124,13 +124,13 @@ extern "C"
if (anUnitLengthNames.Length() > 0) { if (anUnitLengthNames.Length() > 0) {
TCollection_AsciiString aLenUnits = anUnitLengthNames.First(); TCollection_AsciiString aLenUnits = anUnitLengthNames.First();
if (aLenUnits == "millimetre") if (aLenUnits == "millimetre")
aValue = new TCollection_HAsciiString ("UNIT_MM"); aValue = new TCollection_HAsciiString ("MM");
else if (aLenUnits == "centimetre") else if (aLenUnits == "centimetre")
aValue = new TCollection_HAsciiString ("UNIT_CM"); aValue = new TCollection_HAsciiString ("CM");
else if (aLenUnits == "metre") else if (aLenUnits == "metre")
aValue = new TCollection_HAsciiString ("UNIT_M"); aValue = new TCollection_HAsciiString ("M");
else if (aLenUnits == "INCH") else if (aLenUnits == "INCH")
aValue = new TCollection_HAsciiString ("UNIT_INCH"); aValue = new TCollection_HAsciiString ("INCH");
// TODO // TODO
//else if (aLenUnits == "") //else if (aLenUnits == "")
// aValue = new TCollection_HAsciiString (""); // aValue = new TCollection_HAsciiString ("");