2012-06-05 17:33:32 +06:00
|
|
|
// Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
|
2005-12-05 21:23:52 +05:00
|
|
|
//
|
2011-06-06 13:23:11 +06:00
|
|
|
// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
|
|
|
|
// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
|
2005-12-05 21:23:52 +05:00
|
|
|
//
|
2011-06-06 13:23:11 +06:00
|
|
|
// 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.
|
2009-02-13 17:16:39 +05:00
|
|
|
//
|
2011-06-06 13:23:11 +06:00
|
|
|
// 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.
|
2009-02-13 17:16:39 +05:00
|
|
|
//
|
2011-06-06 13:23:11 +06:00
|
|
|
// 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
|
2009-02-13 17:16:39 +05:00
|
|
|
//
|
2011-06-06 13:23:11 +06:00
|
|
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
2012-06-05 17:33:32 +06:00
|
|
|
//
|
2010-05-14 21:15:28 +06:00
|
|
|
|
2009-12-25 16:28:58 +05:00
|
|
|
// File: IGESExport.cxx
|
|
|
|
// Created: Wed May 19 14:49:45 2004
|
|
|
|
// Author: Pavel TELKOV
|
2011-09-21 17:37:07 +06:00
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
#include "utilities.h"
|
|
|
|
|
2009-12-08 17:05:55 +05:00
|
|
|
#include <Basics_Utils.hxx>
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
#include <IGESControl_Controller.hxx>
|
|
|
|
#include <IGESControl_Writer.hxx>
|
|
|
|
#include <Interface_Static.hxx>
|
|
|
|
|
|
|
|
#include <TopoDS_Shape.hxx>
|
2012-03-07 14:05:30 +06:00
|
|
|
#include <TopoDS_Iterator.hxx>
|
|
|
|
|
|
|
|
#include <TCollection_AsciiString.hxx>
|
|
|
|
|
|
|
|
#include <Standard_Failure.hxx>
|
2004-12-01 15:39:14 +05:00
|
|
|
|
2005-08-11 10:43:57 +06:00
|
|
|
#ifdef WNT
|
2009-03-06 20:52:44 +05:00
|
|
|
#if defined IGESEXPORT_EXPORTS || defined IGESExport_EXPORTS
|
2008-03-07 12:45:34 +05:00
|
|
|
#if defined WIN32
|
|
|
|
#define IGESEXPORT_EXPORT __declspec( dllexport )
|
|
|
|
#else
|
|
|
|
#define IGESEXPORT_EXPORT
|
|
|
|
#endif
|
|
|
|
#else
|
|
|
|
#if defined WIN32
|
|
|
|
#define IGESEXPORT_EXPORT __declspec( dllimport )
|
|
|
|
#else
|
|
|
|
#define IGESEXPORT_EXPORT
|
|
|
|
#endif
|
|
|
|
#endif
|
2005-08-11 10:43:57 +06:00
|
|
|
#else
|
2008-03-07 12:45:34 +05:00
|
|
|
#define IGESEXPORT_EXPORT
|
2005-08-11 10:43:57 +06:00
|
|
|
#endif
|
|
|
|
|
2012-03-07 14:05:30 +06:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
* KindOfBRep
|
|
|
|
* \return 0 if theShape contains only simple entities (wires, edges and vertices),
|
|
|
|
* 1 if theShape contains only complex entities (shells, solids and compsolids)
|
|
|
|
* 2 if theShape contains only indifferent entities (faces)
|
|
|
|
* -1 if theShape contains both simple and complex entities (and in this case it
|
|
|
|
* cannot be saved without any loss neither in BRepMode == 0 nor in BRepMode == 1)
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
int KindOfBRep (const TopoDS_Shape& theShape)
|
|
|
|
{
|
|
|
|
int aKind = 2;
|
|
|
|
|
|
|
|
switch (theShape.ShapeType())
|
|
|
|
{
|
|
|
|
case TopAbs_COMPOUND:
|
|
|
|
{
|
|
|
|
bool isSimple = false;
|
|
|
|
bool isComplex = false;
|
|
|
|
TopoDS_Iterator anIt (theShape, Standard_True, Standard_True);
|
|
|
|
for (; anIt.More(); anIt.Next()) {
|
|
|
|
TopoDS_Shape aS = anIt.Value();
|
|
|
|
int aKindSub = KindOfBRep(aS);
|
|
|
|
if (aKindSub == 0)
|
|
|
|
isSimple = true;
|
|
|
|
else if (aKindSub == 1)
|
|
|
|
isComplex = true;
|
|
|
|
else if (aKindSub == -1) {
|
|
|
|
return -1; // heterogeneous
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (isSimple && isComplex)
|
|
|
|
aKind = -1; // heterogeneous
|
|
|
|
else if (isSimple)
|
|
|
|
aKind = 0;
|
|
|
|
else if (isComplex)
|
|
|
|
aKind = 1;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case TopAbs_COMPSOLID:
|
|
|
|
case TopAbs_SOLID:
|
|
|
|
case TopAbs_SHELL:
|
|
|
|
aKind = 1;
|
|
|
|
break;
|
|
|
|
case TopAbs_WIRE:
|
|
|
|
case TopAbs_EDGE:
|
|
|
|
case TopAbs_VERTEX:
|
|
|
|
aKind = 0;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
aKind = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
return aKind;
|
|
|
|
}
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
//=============================================================================
|
|
|
|
/*!
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
//=============================================================================
|
|
|
|
|
|
|
|
extern "C"
|
|
|
|
{
|
2008-03-07 12:45:34 +05:00
|
|
|
IGESEXPORT_EXPORT
|
|
|
|
int Export( const TopoDS_Shape& theShape,
|
|
|
|
const TCollection_AsciiString& theFileName,
|
|
|
|
const TCollection_AsciiString& theFormatName )
|
2004-12-01 15:39:14 +05:00
|
|
|
{
|
2012-03-07 14:05:30 +06:00
|
|
|
bool ok = false;
|
|
|
|
|
|
|
|
// define, whether to write only faces (5.1 IGES format)
|
|
|
|
// or shells and solids also (5.3 IGES format)
|
|
|
|
int aBrepMode = 0;
|
|
|
|
if (theFormatName.IsEqual("IGES_5_3"))
|
|
|
|
aBrepMode = 1;
|
|
|
|
|
2004-12-01 15:39:14 +05:00
|
|
|
MESSAGE("Export IGES into file " << theFileName.ToCString());
|
2012-03-07 14:05:30 +06:00
|
|
|
|
|
|
|
// Mantis issue 0021350: check being exported shape, as some standalone
|
|
|
|
// entities (edges, wires and vertices) cannot be saved in BRepMode
|
|
|
|
if (aBrepMode == 1) {
|
|
|
|
int aKind = KindOfBRep(theShape);
|
|
|
|
if (aKind == -1)
|
|
|
|
Standard_Failure::Raise("EXPORT_IGES_HETEROGENEOUS_COMPOUND");
|
|
|
|
else if (aKind == 2)
|
|
|
|
aBrepMode = 1;
|
|
|
|
else
|
|
|
|
aBrepMode = aKind;
|
|
|
|
}
|
|
|
|
|
2011-09-21 17:37:07 +06:00
|
|
|
// commented for 0021350: Please don't catch exceptions silently and send an
|
|
|
|
// inappropriate error message instead, it is disturbing for the user and for us
|
|
|
|
//try
|
2006-05-06 14:44:32 +06:00
|
|
|
{
|
2009-12-08 17:05:55 +05:00
|
|
|
// Set "C" numeric locale to save numbers correctly
|
|
|
|
Kernel_Utils::Localizer loc;
|
|
|
|
|
2006-05-06 14:44:32 +06:00
|
|
|
// initialize writer
|
|
|
|
IGESControl_Controller::Init();
|
|
|
|
//IGESControl_Writer ICW (Interface_Static::CVal("write.iges.unit"),
|
2009-12-25 16:28:58 +05:00
|
|
|
// Interface_Static::IVal("write.iges.brep.mode"));
|
2009-09-15 19:05:29 +06:00
|
|
|
IGESControl_Writer ICW ("M", aBrepMode); // "write.iges.unit" ->> VSR 15.09.09: export explicitly in meters
|
2009-09-16 14:45:00 +06:00
|
|
|
Interface_Static::SetCVal("xstep.cascade.unit","M");
|
2006-05-06 14:44:32 +06:00
|
|
|
|
2010-05-14 21:15:28 +06:00
|
|
|
// 09.03.2010 skl for bug 0020726
|
|
|
|
// change default value "Average" to "Max"
|
|
|
|
Interface_Static::SetCVal("write.precision.mode","Max");
|
|
|
|
|
2006-05-06 14:44:32 +06:00
|
|
|
// perform shape writing
|
2012-03-07 14:05:30 +06:00
|
|
|
if (ICW.AddShape( theShape )) {
|
|
|
|
ICW.ComputeModel();
|
|
|
|
ok = ICW.Write( theFileName.ToCString() );
|
|
|
|
}
|
2006-05-06 14:44:32 +06:00
|
|
|
}
|
2011-09-21 17:37:07 +06:00
|
|
|
//catch(Standard_Failure)
|
|
|
|
//{
|
|
|
|
//}
|
2012-03-07 14:05:30 +06:00
|
|
|
return ok;
|
2004-12-01 15:39:14 +05:00
|
|
|
}
|
|
|
|
}
|