From 5df609e75d9f1dd9e0b02f94b5c93134c757f060 Mon Sep 17 00:00:00 2001 From: gka Date: Mon, 18 Jan 2016 19:32:22 +0300 Subject: [PATCH] 0026827: Position and orientation for GD&T frames Implementation of graphical annotations of the PMI read from STEP --- src/BinMXCAFDoc/BinMXCAFDoc.cxx | 4 + src/BinMXCAFDoc/BinMXCAFDoc.hxx | 4 + .../BinMXCAFDoc_DimensionDriver.cxx | 68 ++++ .../BinMXCAFDoc_DimensionDriver.hxx | 56 ++++ .../BinMXCAFDoc_GeomToleranceDriver.cxx | 68 ++++ .../BinMXCAFDoc_GeomToleranceDriver.hxx | 56 ++++ src/BinMXCAFDoc/FILES | 4 + src/RWStepAP214/RWStepAP214_GeneralModule.cxx | 130 +++++++- .../RWStepAP214_ReadWriteModule.cxx | 187 ++++++++++- src/RWStepAP242/FILES | 2 + ...AP242_RWDraughtingModelItemAssociation.cxx | 124 ++++++++ ...AP242_RWDraughtingModelItemAssociation.hxx | 46 +++ src/RWStepVisual/FILES | 20 ++ ...StepVisual_RWAnnotationCurveOccurrence.cxx | 108 +++++++ ...StepVisual_RWAnnotationCurveOccurrence.hxx | 45 +++ .../RWStepVisual_RWAnnotationOccurrence.cxx | 107 +++++++ .../RWStepVisual_RWAnnotationOccurrence.hxx | 45 +++ .../RWStepVisual_RWAnnotationPlane.cxx | 133 ++++++++ .../RWStepVisual_RWAnnotationPlane.hxx | 45 +++ .../RWStepVisual_RWCoordinatesList.cxx | 115 +++++++ .../RWStepVisual_RWCoordinatesList.hxx | 46 +++ .../RWStepVisual_RWDraughtingCallout.cxx | 93 ++++++ .../RWStepVisual_RWDraughtingCallout.hxx | 45 +++ ...sual_RWTessellatedAnnotationOccurrence.cxx | 108 +++++++ ...sual_RWTessellatedAnnotationOccurrence.hxx | 45 +++ .../RWStepVisual_RWTessellatedCurveSet.cxx | 105 +++++++ .../RWStepVisual_RWTessellatedCurveSet.hxx | 47 +++ ...RWStepVisual_RWTessellatedGeometricSet.cxx | 96 ++++++ ...RWStepVisual_RWTessellatedGeometricSet.hxx | 48 +++ .../RWStepVisual_RWTessellatedItem.cxx | 59 ++++ .../RWStepVisual_RWTessellatedItem.hxx | 46 +++ src/STEPCAFControl/STEPCAFControl_Reader.cxx | 295 +++++++++++++++++- src/StepAP214/StepAP214_Protocol.cxx | 25 +- src/StepAP242/FILES | 2 + ...epAP242_DraughtingModelItemAssociation.cxx | 20 ++ ...epAP242_DraughtingModelItemAssociation.hxx | 37 +++ src/StepDimTol/StepDimTol_ToleranceZone.hxx | 2 +- src/StepVisual/FILES | 24 ++ .../StepVisual_AnnotationCurveOccurrence.cxx | 21 ++ .../StepVisual_AnnotationCurveOccurrence.hxx | 36 +++ .../StepVisual_AnnotationOccurrence.cxx | 2 + .../StepVisual_AnnotationOccurrence.hxx | 1 - src/StepVisual/StepVisual_AnnotationPlane.cxx | 38 +++ src/StepVisual/StepVisual_AnnotationPlane.hxx | 76 +++++ .../StepVisual_AnnotationPlaneElement.cxx | 45 +++ .../StepVisual_AnnotationPlaneElement.hxx | 50 +++ ...pVisual_Array1OfAnnotationPlaneElement.hxx | 23 ++ ...isual_Array1OfDraughtingCalloutElement.hxx | 23 ++ src/StepVisual/StepVisual_CoordinatesList.cxx | 31 ++ src/StepVisual/StepVisual_CoordinatesList.hxx | 45 +++ .../StepVisual_DraughtingCallout.cxx | 36 +++ .../StepVisual_DraughtingCallout.hxx | 77 +++++ .../StepVisual_DraughtingCalloutElement.cxx | 49 +++ .../StepVisual_DraughtingCalloutElement.hxx | 49 +++ ...Visual_HArray1OfAnnotationPlaneElement.hxx | 24 ++ ...sual_HArray1OfDraughtingCalloutElement.hxx | 24 ++ ...Visual_TessellatedAnnotationOccurrence.cxx | 21 ++ ...Visual_TessellatedAnnotationOccurrence.hxx | 36 +++ .../StepVisual_TessellatedCurveSet.cxx | 42 +++ .../StepVisual_TessellatedCurveSet.hxx | 60 ++++ .../StepVisual_TessellatedGeometricSet.cxx | 33 ++ .../StepVisual_TessellatedGeometricSet.hxx | 54 ++++ src/StepVisual/StepVisual_TessellatedItem.cxx | 20 ++ src/StepVisual/StepVisual_TessellatedItem.hxx | 37 +++ src/TKXDESTEP/EXTERNLIB | 1 + .../XCAFDimTolObjects_DatumObject.cxx | 9 + .../XCAFDimTolObjects_DatumObject.hxx | 70 ++++- .../XCAFDimTolObjects_DimensionObject.cxx | 6 + .../XCAFDimTolObjects_DimensionObject.hxx | 54 ++++ .../XCAFDimTolObjects_GeomToleranceObject.cxx | 15 +- .../XCAFDimTolObjects_GeomToleranceObject.hxx | 67 ++++ src/XCAFDoc/XCAFDoc_Datum.cxx | 126 +++++++- src/XCAFDoc/XCAFDoc_Datum.hxx | 1 + src/XCAFDoc/XCAFDoc_DimTolTool.cxx | 4 +- src/XCAFDoc/XCAFDoc_DimTolTool.hxx | 4 +- src/XCAFDoc/XCAFDoc_Dimension.cxx | 129 +++++++- src/XCAFDoc/XCAFDoc_GeomTolerance.cxx | 128 +++++++- 77 files changed, 4037 insertions(+), 40 deletions(-) create mode 100644 src/BinMXCAFDoc/BinMXCAFDoc_DimensionDriver.cxx create mode 100644 src/BinMXCAFDoc/BinMXCAFDoc_DimensionDriver.hxx create mode 100644 src/BinMXCAFDoc/BinMXCAFDoc_GeomToleranceDriver.cxx create mode 100644 src/BinMXCAFDoc/BinMXCAFDoc_GeomToleranceDriver.hxx create mode 100644 src/RWStepAP242/RWStepAP242_RWDraughtingModelItemAssociation.cxx create mode 100644 src/RWStepAP242/RWStepAP242_RWDraughtingModelItemAssociation.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWAnnotationCurveOccurrence.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWAnnotationCurveOccurrence.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWAnnotationOccurrence.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWAnnotationOccurrence.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWAnnotationPlane.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWAnnotationPlane.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWCoordinatesList.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWCoordinatesList.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWDraughtingCallout.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWDraughtingCallout.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWTessellatedAnnotationOccurrence.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWTessellatedAnnotationOccurrence.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWTessellatedCurveSet.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWTessellatedCurveSet.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWTessellatedGeometricSet.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWTessellatedGeometricSet.hxx create mode 100644 src/RWStepVisual/RWStepVisual_RWTessellatedItem.cxx create mode 100644 src/RWStepVisual/RWStepVisual_RWTessellatedItem.hxx create mode 100644 src/StepAP242/StepAP242_DraughtingModelItemAssociation.cxx create mode 100644 src/StepAP242/StepAP242_DraughtingModelItemAssociation.hxx create mode 100644 src/StepVisual/StepVisual_AnnotationCurveOccurrence.cxx create mode 100644 src/StepVisual/StepVisual_AnnotationCurveOccurrence.hxx create mode 100644 src/StepVisual/StepVisual_AnnotationPlane.cxx create mode 100644 src/StepVisual/StepVisual_AnnotationPlane.hxx create mode 100644 src/StepVisual/StepVisual_AnnotationPlaneElement.cxx create mode 100644 src/StepVisual/StepVisual_AnnotationPlaneElement.hxx create mode 100644 src/StepVisual/StepVisual_Array1OfAnnotationPlaneElement.hxx create mode 100644 src/StepVisual/StepVisual_Array1OfDraughtingCalloutElement.hxx create mode 100644 src/StepVisual/StepVisual_CoordinatesList.cxx create mode 100644 src/StepVisual/StepVisual_CoordinatesList.hxx create mode 100644 src/StepVisual/StepVisual_DraughtingCallout.cxx create mode 100644 src/StepVisual/StepVisual_DraughtingCallout.hxx create mode 100644 src/StepVisual/StepVisual_DraughtingCalloutElement.cxx create mode 100644 src/StepVisual/StepVisual_DraughtingCalloutElement.hxx create mode 100644 src/StepVisual/StepVisual_HArray1OfAnnotationPlaneElement.hxx create mode 100644 src/StepVisual/StepVisual_HArray1OfDraughtingCalloutElement.hxx create mode 100644 src/StepVisual/StepVisual_TessellatedAnnotationOccurrence.cxx create mode 100644 src/StepVisual/StepVisual_TessellatedAnnotationOccurrence.hxx create mode 100644 src/StepVisual/StepVisual_TessellatedCurveSet.cxx create mode 100644 src/StepVisual/StepVisual_TessellatedCurveSet.hxx create mode 100644 src/StepVisual/StepVisual_TessellatedGeometricSet.cxx create mode 100644 src/StepVisual/StepVisual_TessellatedGeometricSet.hxx create mode 100644 src/StepVisual/StepVisual_TessellatedItem.cxx create mode 100644 src/StepVisual/StepVisual_TessellatedItem.hxx diff --git a/src/BinMXCAFDoc/BinMXCAFDoc.cxx b/src/BinMXCAFDoc/BinMXCAFDoc.cxx index de00b93f79..7dd68a5d0f 100644 --- a/src/BinMXCAFDoc/BinMXCAFDoc.cxx +++ b/src/BinMXCAFDoc/BinMXCAFDoc.cxx @@ -22,6 +22,8 @@ #include #include #include +#include +#include #include #include #include @@ -61,6 +63,8 @@ void BinMXCAFDoc::AddDrivers(const Handle(BinMDF_ADriverTable)& theDriverTable, theDriverTable->AddDriver( aLocationDriver); theDriverTable->AddDriver( new BinMXCAFDoc_VolumeDriver (theMsgDrv)); theDriverTable->AddDriver( new BinMXCAFDoc_DatumDriver (theMsgDrv)); + theDriverTable->AddDriver( new BinMXCAFDoc_GeomToleranceDriver (theMsgDrv)); + theDriverTable->AddDriver( new BinMXCAFDoc_DimensionDriver (theMsgDrv)); theDriverTable->AddDriver( new BinMXCAFDoc_DimTolDriver (theMsgDrv)); theDriverTable->AddDriver( new BinMXCAFDoc_MaterialDriver (theMsgDrv)); diff --git a/src/BinMXCAFDoc/BinMXCAFDoc.hxx b/src/BinMXCAFDoc/BinMXCAFDoc.hxx index d0eca56625..571748edb3 100644 --- a/src/BinMXCAFDoc/BinMXCAFDoc.hxx +++ b/src/BinMXCAFDoc/BinMXCAFDoc.hxx @@ -29,6 +29,8 @@ class BinMXCAFDoc_GraphNodeDriver; class BinMXCAFDoc_LocationDriver; class BinMXCAFDoc_VolumeDriver; class BinMXCAFDoc_DatumDriver; +class BinMXCAFDoc_GeomToleranceDriver; +class BinMXCAFDoc_DimensionDriver; class BinMXCAFDoc_DimTolDriver; class BinMXCAFDoc_MaterialDriver; class BinMXCAFDoc_ColorToolDriver; @@ -71,6 +73,8 @@ friend class BinMXCAFDoc_GraphNodeDriver; friend class BinMXCAFDoc_LocationDriver; friend class BinMXCAFDoc_VolumeDriver; friend class BinMXCAFDoc_DatumDriver; +friend class BinMXCAFDoc_GeomToleranceDriver; +friend class BinMXCAFDoc_DimensionDriver; friend class BinMXCAFDoc_DimTolDriver; friend class BinMXCAFDoc_MaterialDriver; friend class BinMXCAFDoc_ColorToolDriver; diff --git a/src/BinMXCAFDoc/BinMXCAFDoc_DimensionDriver.cxx b/src/BinMXCAFDoc/BinMXCAFDoc_DimensionDriver.cxx new file mode 100644 index 0000000000..160abcc9da --- /dev/null +++ b/src/BinMXCAFDoc/BinMXCAFDoc_DimensionDriver.cxx @@ -0,0 +1,68 @@ +// Created on: +// Created by: +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +IMPLEMENT_STANDARD_RTTIEXT(BinMXCAFDoc_DimensionDriver,BinMDF_ADriver) + +//======================================================================= +//function : Constructor +//purpose : +//======================================================================= +BinMXCAFDoc_DimensionDriver::BinMXCAFDoc_DimensionDriver (const Handle(CDM_MessageDriver)& theMsgDriver) +: BinMDF_ADriver(theMsgDriver, STANDARD_TYPE(XCAFDoc_Dimension)->Name()) +{ +} + +//======================================================================= +//function : NewEmpty +//purpose : +//======================================================================= +Handle(TDF_Attribute) BinMXCAFDoc_DimensionDriver::NewEmpty() const +{ + return new XCAFDoc_Dimension(); +} + +//======================================================================= +//function : Paste +//purpose : +//======================================================================= +Standard_Boolean BinMXCAFDoc_DimensionDriver::Paste (const BinObjMgt_Persistent& /*theSource*/, + const Handle(TDF_Attribute)& /*theTarget*/, + BinObjMgt_RRelocationTable& /*theRelocTable*/) const +{ + //Handle(XCAFDoc_Dimension) anAtt = Handle(XCAFDoc_Dimension)::DownCast(theTarget); + return Standard_True; +} + +//======================================================================= +//function : Paste +//purpose : +//======================================================================= +void BinMXCAFDoc_DimensionDriver::Paste (const Handle(TDF_Attribute)& /*theSource*/, + BinObjMgt_Persistent& /*theTarget*/, + BinObjMgt_SRelocationTable& /*theRelocTable*/) const +{ + //Handle(XCAFDoc_Dimension) anAtt = Handle(XCAFDoc_Dimension)::DownCast(theSource); +} diff --git a/src/BinMXCAFDoc/BinMXCAFDoc_DimensionDriver.hxx b/src/BinMXCAFDoc/BinMXCAFDoc_DimensionDriver.hxx new file mode 100644 index 0000000000..3be43adede --- /dev/null +++ b/src/BinMXCAFDoc/BinMXCAFDoc_DimensionDriver.hxx @@ -0,0 +1,56 @@ +// Created on: +// Created by: +// Copyright (c) 20015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _BinMXCAFDoc_DimensionDriver_HeaderFile +#define _BinMXCAFDoc_DimensionDriver_HeaderFile + +#include +#include + +#include +#include +#include +#include + +class CDM_MessageDriver; +class TDF_Attribute; +class BinObjMgt_Persistent; + +class BinMXCAFDoc_DimensionDriver; +DEFINE_STANDARD_HANDLE(BinMXCAFDoc_DimensionDriver, BinMDF_ADriver) + +class BinMXCAFDoc_DimensionDriver : public BinMDF_ADriver +{ + +public: + + + Standard_EXPORT BinMXCAFDoc_DimensionDriver (const Handle(CDM_MessageDriver)& theMsgDriver); + + Standard_EXPORT virtual Handle(TDF_Attribute) NewEmpty() const Standard_OVERRIDE; + + Standard_EXPORT virtual Standard_Boolean Paste (const BinObjMgt_Persistent& theSource, + const Handle(TDF_Attribute)& theTarget, + BinObjMgt_RRelocationTable& theRelocTable) const Standard_OVERRIDE; + + Standard_EXPORT virtual void Paste (const Handle(TDF_Attribute)& theSource, + BinObjMgt_Persistent& theTarget, + BinObjMgt_SRelocationTable& theRelocTable) const Standard_OVERRIDE; + + DEFINE_STANDARD_RTTIEXT(BinMXCAFDoc_DimensionDriver,BinMDF_ADriver) + +}; + +#endif // _BinMXCAFDoc_DimensionDriver_HeaderFile diff --git a/src/BinMXCAFDoc/BinMXCAFDoc_GeomToleranceDriver.cxx b/src/BinMXCAFDoc/BinMXCAFDoc_GeomToleranceDriver.cxx new file mode 100644 index 0000000000..59bb73e05d --- /dev/null +++ b/src/BinMXCAFDoc/BinMXCAFDoc_GeomToleranceDriver.cxx @@ -0,0 +1,68 @@ +// Created on: +// Created by: +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +IMPLEMENT_STANDARD_RTTIEXT(BinMXCAFDoc_GeomToleranceDriver,BinMDF_ADriver) + +//======================================================================= +//function : Constructor +//purpose : +//======================================================================= +BinMXCAFDoc_GeomToleranceDriver::BinMXCAFDoc_GeomToleranceDriver (const Handle(CDM_MessageDriver)& theMsgDriver) +: BinMDF_ADriver(theMsgDriver, STANDARD_TYPE(XCAFDoc_GeomTolerance)->Name()) +{ +} + +//======================================================================= +//function : NewEmpty +//purpose : +//======================================================================= +Handle(TDF_Attribute) BinMXCAFDoc_GeomToleranceDriver::NewEmpty() const +{ + return new XCAFDoc_GeomTolerance(); +} + +//======================================================================= +//function : Paste +//purpose : +//======================================================================= +Standard_Boolean BinMXCAFDoc_GeomToleranceDriver::Paste (const BinObjMgt_Persistent& /*theSource*/, + const Handle(TDF_Attribute)& /*theTarget*/, + BinObjMgt_RRelocationTable& /*theRelocTable*/) const +{ + //Handle(XCAFDoc_GeomTolerance) anAtt = Handle(XCAFDoc_GeomTolerance)::DownCast(theTarget); + return Standard_True; +} + +//======================================================================= +//function : Paste +//purpose : +//======================================================================= +void BinMXCAFDoc_GeomToleranceDriver::Paste (const Handle(TDF_Attribute)& /*theSource*/, + BinObjMgt_Persistent& /*theTarget*/, + BinObjMgt_SRelocationTable& /*theRelocTable*/) const +{ + //Handle(XCAFDoc_GeomTolerance) anAtt = Handle(XCAFDoc_GeomTolerance)::DownCast(theSource); +} diff --git a/src/BinMXCAFDoc/BinMXCAFDoc_GeomToleranceDriver.hxx b/src/BinMXCAFDoc/BinMXCAFDoc_GeomToleranceDriver.hxx new file mode 100644 index 0000000000..0c01139dc6 --- /dev/null +++ b/src/BinMXCAFDoc/BinMXCAFDoc_GeomToleranceDriver.hxx @@ -0,0 +1,56 @@ +// Created on: +// Created by: +// Copyright (c) 20015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _BinMXCAFDoc_GeomToleranceDriver_HeaderFile +#define _BinMXCAFDoc_GeomToleranceDriver_HeaderFile + +#include +#include + +#include +#include +#include +#include + +class CDM_MessageDriver; +class TDF_Attribute; +class BinObjMgt_Persistent; + +class BinMXCAFDoc_GeomToleranceDriver; +DEFINE_STANDARD_HANDLE(BinMXCAFDoc_GeomToleranceDriver, BinMDF_ADriver) + +class BinMXCAFDoc_GeomToleranceDriver : public BinMDF_ADriver +{ + +public: + + + Standard_EXPORT BinMXCAFDoc_GeomToleranceDriver (const Handle(CDM_MessageDriver)& theMsgDriver); + + Standard_EXPORT virtual Handle(TDF_Attribute) NewEmpty() const Standard_OVERRIDE; + + Standard_EXPORT virtual Standard_Boolean Paste (const BinObjMgt_Persistent& theSource, + const Handle(TDF_Attribute)& theTarget, + BinObjMgt_RRelocationTable& theRelocTable) const Standard_OVERRIDE; + + Standard_EXPORT virtual void Paste (const Handle(TDF_Attribute)& theSource, + BinObjMgt_Persistent& theTarget, + BinObjMgt_SRelocationTable& theRelocTable) const Standard_OVERRIDE; + + DEFINE_STANDARD_RTTIEXT(BinMXCAFDoc_GeomToleranceDriver,BinMDF_ADriver) + +}; + +#endif // _BinMXCAFDoc_GeomToleranceDriver_HeaderFile diff --git a/src/BinMXCAFDoc/FILES b/src/BinMXCAFDoc/FILES index 83d4887e36..99b3cedc5e 100644 --- a/src/BinMXCAFDoc/FILES +++ b/src/BinMXCAFDoc/FILES @@ -10,12 +10,16 @@ BinMXCAFDoc_ColorToolDriver.cxx BinMXCAFDoc_ColorToolDriver.hxx BinMXCAFDoc_DatumDriver.cxx BinMXCAFDoc_DatumDriver.hxx +BinMXCAFDoc_DimensionDriver.cxx +BinMXCAFDoc_DimensionDriver.hxx BinMXCAFDoc_DimTolDriver.cxx BinMXCAFDoc_DimTolDriver.hxx BinMXCAFDoc_DimTolToolDriver.cxx BinMXCAFDoc_DimTolToolDriver.hxx BinMXCAFDoc_DocumentToolDriver.cxx BinMXCAFDoc_DocumentToolDriver.hxx +BinMXCAFDoc_GeomToleranceDriver.cxx +BinMXCAFDoc_GeomToleranceDriver.hxx BinMXCAFDoc_GraphNodeDriver.cxx BinMXCAFDoc_GraphNodeDriver.hxx BinMXCAFDoc_LayerToolDriver.cxx diff --git a/src/RWStepAP214/RWStepAP214_GeneralModule.cxx b/src/RWStepAP214/RWStepAP214_GeneralModule.cxx index df36679150..07ef03fe04 100644 --- a/src/RWStepAP214/RWStepAP214_GeneralModule.cxx +++ b/src/RWStepAP214/RWStepAP214_GeneralModule.cxx @@ -1093,6 +1093,19 @@ #include #include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include + + IMPLEMENT_STANDARD_RTTIEXT(RWStepAP214_GeneralModule,StepData_GeneralModule) //#define DeclareAndCast(atype,result,start) \ NON car Name @@ -1270,8 +1283,13 @@ IMPLEMENT_STANDARD_RTTIEXT(RWStepAP214_GeneralModule,StepData_GeneralModule) #include #include #include +#include #include #include +#include +#include +#include +#include #include #include @@ -1315,8 +1333,25 @@ IMPLEMENT_STANDARD_RTTIEXT(RWStepAP214_GeneralModule,StepData_GeneralModule) #include #include #include +#include #include #include +#include +#include +#include + +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include + static Standard_Integer catsh,catdr,catstr,catdsc,cataux; @@ -1393,10 +1428,17 @@ void RWStepAP214_GeneralModule::FillSharedCase(const Standard_Integer CN, tool.Share(anent,iter); } break; + case 4: + { + DeclareAndCast(StepVisual_AnnotationCurveOccurrence,anent,ent); + RWStepVisual_RWAnnotationCurveOccurrence tool; + tool.Share(anent,iter); + } + break; case 7: { - DeclareAndCast(StepVisual_StyledItem,anent,ent); - RWStepVisual_RWStyledItem tool; + DeclareAndCast(StepVisual_AnnotationOccurrence,anent,ent); + RWStepVisual_RWAnnotationOccurrence tool; tool.Share(anent,iter); } break; @@ -1865,6 +1907,13 @@ void RWStepAP214_GeneralModule::FillSharedCase(const Standard_Integer CN, tool.Share(anent,iter); } break; + case 107: + { + DeclareAndCast(StepVisual_DraughtingCallout,anent,ent); + RWStepVisual_RWDraughtingCallout tool; + tool.Share(anent,iter); + } + break; case 116: { DeclareAndCast(StepShape_EdgeCurve,anent,ent); @@ -4985,6 +5034,20 @@ void RWStepAP214_GeneralModule::FillSharedCase(const Standard_Integer CN, tool.Share(anent,iter); } break; + case 703: + { + DeclareAndCast(StepAP242_DraughtingModelItemAssociation,anent,ent); + RWStepAP242_RWDraughtingModelItemAssociation tool; + tool.Share(anent,iter); + } + break; + case 704: + { + DeclareAndCast(StepVisual_AnnotationPlane,anent,ent); + RWStepVisual_RWAnnotationPlane tool; + tool.Share(anent,iter); + } + break; case 705: { DeclareAndCast(StepDimTol_GeoTolAndGeoTolWthDatRefAndGeoTolWthMaxTol,anent,ent); @@ -4999,7 +5062,20 @@ void RWStepAP214_GeneralModule::FillSharedCase(const Standard_Integer CN, tool.Share(anent,iter); } break; - + case 707: + { + DeclareAndCast(StepVisual_TessellatedAnnotationOccurrence,anent,ent); + RWStepVisual_RWTessellatedAnnotationOccurrence tool; + tool.Share(anent,iter); + } + break; + case 709: + { + DeclareAndCast(StepVisual_TessellatedGeometricSet,anent,ent); + RWStepVisual_RWTessellatedGeometricSet tool; + tool.Share(anent,iter); + } + break; default : break; } } @@ -5153,6 +5229,9 @@ Standard_Boolean RWStepAP214_GeneralModule::NewVoid case 3 : ent = new StepShape_AdvancedFace; break; + case 4 : + ent = new StepVisual_AnnotationCurveOccurrence; + break; case 7 : ent = new StepVisual_AnnotationOccurrence; break; @@ -5414,6 +5493,9 @@ Standard_Boolean RWStepAP214_GeneralModule::NewVoid case 106 : ent = new StepVisual_AnnotationOccurrence; break; + case 107 : + ent = new StepVisual_DraughtingCallout; + break; case 108 : ent = new StepVisual_DraughtingPreDefinedColour; break; @@ -6949,13 +7031,39 @@ Standard_Boolean RWStepAP214_GeneralModule::NewVoid case 702: ent = new StepRepr_FeatureForDatumTargetRelationship; break; - case 705 : + case 703: + ent = new StepAP242_DraughtingModelItemAssociation; + break; + case 704: + ent = new StepVisual_AnnotationPlane; + break; + case 705: ent = new StepDimTol_GeoTolAndGeoTolWthDatRefAndGeoTolWthMaxTol; break; - case 706 : + case 706: ent = new StepDimTol_GeoTolAndGeoTolWthMaxTol; break; + case 707: + ent = new StepVisual_TessellatedAnnotationOccurrence; + break; + + case 708: + ent = new StepVisual_TessellatedItem; + break; + + case 709: + ent = new StepVisual_TessellatedGeometricSet; + break; + + case 710: + ent = new StepVisual_TessellatedCurveSet; + break; + + case 711: + ent = new StepVisual_CoordinatesList; + break; + default: return Standard_False; } @@ -7536,9 +7644,17 @@ Standard_Integer RWStepAP214_GeneralModule::CategoryNumber case 699: case 700: case 701: - case 702: return catdr; + case 702: + case 703: + case 704: return catdr; case 705: - case 706: return cataux; + case 706: + case 707: + case 708: + case 709: + case 710: + case 711: + return cataux; default : break; } diff --git a/src/RWStepAP214/RWStepAP214_ReadWriteModule.cxx b/src/RWStepAP214/RWStepAP214_ReadWriteModule.cxx index fc00a868ef..718eb4a9a6 100644 --- a/src/RWStepAP214/RWStepAP214_ReadWriteModule.cxx +++ b/src/RWStepAP214/RWStepAP214_ReadWriteModule.cxx @@ -1318,8 +1318,14 @@ Handle(atype) result = Handle(atype)::DownCast (start) #include #include #include +#include +#include #include #include +#include +#include +#include +#include #include #include @@ -1363,9 +1369,24 @@ Handle(atype) result = Handle(atype)::DownCast (start) #include #include #include +#include #include #include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include // -- General Declarations (Recognize, StepType) --- @@ -1994,7 +2015,13 @@ static TCollection_AsciiString Reco_GeneralDatumReference("GENERAL_DATUM_REFEREN static TCollection_AsciiString Reco_IntegerRepresentationItem("INTEGER_REPRESENTATION_ITEM"); static TCollection_AsciiString Reco_ValueRepresentationItem("VALUE_REPRESENTATION_ITEM"); static TCollection_AsciiString Reco_FeatureForDatumTargetRelationship("FEATURE_FOR_DATUM_TARGET_RELATIONSHIP"); +static TCollection_AsciiString Reco_DraughtingModelItemAssociation("DRAUGHTING_MODEL_ITEM_ASSOCIATION"); +static TCollection_AsciiString Reco_AnnotationPlane("ANNOTATION_PLANE"); +static TCollection_AsciiString Reco_TessellatedAnnotationOccurrence("TESSELLATED_ANNOTATION_OCCURRENCE"); +static TCollection_AsciiString Reco_TessellatedGeometricSet("TESSELLATED_GEOMETRIC_SET"); +static TCollection_AsciiString Reco_TessellatedCurveSet("TESSELLATED_CURVE_SET"); +static TCollection_AsciiString Reco_CoordinatesList("COORDINATES_LIST"); // -- Definition of the libraries -- static Handle(Dico_DictionaryOfInteger) typenums; @@ -2638,7 +2665,16 @@ RWStepAP214_ReadWriteModule::RWStepAP214_ReadWriteModule () typenums->SetItem (Reco_IntegerRepresentationItem, 700); typenums->SetItem (Reco_ValueRepresentationItem, 701); typenums->SetItem (Reco_FeatureForDatumTargetRelationship, 702); + typenums->SetItem (Reco_DraughtingModelItemAssociation, 703); + typenums->SetItem (Reco_AnnotationPlane, 704); + typenums->SetItem (Reco_TessellatedAnnotationOccurrence,707); + typenums->SetItem (Reco_TessellatedGeometricSet, 709); + + typenums->SetItem ( Reco_TessellatedCurveSet, 710); + typenums->SetItem ( Reco_CoordinatesList, 711); + + // SHORT NAMES // NB : la liste est celle de AP203 // Directement exploite pour les types simples @@ -3176,6 +3212,8 @@ RWStepAP214_ReadWriteModule::RWStepAP214_ReadWriteModule () typeshor->SetItem ("TLZNFR",684); typeshor->SetItem ("INRPIT",700); typeshor->SetItem ("VLRPIT",701); + typeshor->SetItem ("DMIA", 703); + typeshor->SetItem ("ANNPLN", 704); } @@ -4446,6 +4484,14 @@ const TCollection_AsciiString& RWStepAP214_ReadWriteModule::StepType case 700: return Reco_IntegerRepresentationItem; case 701: return Reco_ValueRepresentationItem; case 702: return Reco_FeatureForDatumTargetRelationship; + case 703: return Reco_DraughtingModelItemAssociation; + case 704: return Reco_AnnotationPlane; + + case 707 : return Reco_TessellatedAnnotationOccurrence; + case 709 : return Reco_TessellatedGeometricSet; + + case 710 : return Reco_TessellatedCurveSet; + case 711 : return Reco_CoordinatesList; default : return PasReco; } @@ -4799,11 +4845,17 @@ void RWStepAP214_ReadWriteModule::ReadStep(const Standard_Integer CN, tool.ReadStep (data,num,ach,anent); } break; - + case 4 : + { + DeclareAndCast(StepVisual_AnnotationCurveOccurrence, anent, ent); + RWStepVisual_RWAnnotationCurveOccurrence tool; + tool.ReadStep (data,num,ach,anent); + } + break; case 7 : { - DeclareAndCast(StepVisual_StyledItem, anent, ent); - RWStepVisual_RWStyledItem tool; + DeclareAndCast(StepVisual_AnnotationOccurrence, anent, ent); + RWStepVisual_RWAnnotationOccurrence tool; tool.ReadStep (data,num,ach,anent); } @@ -5494,6 +5546,13 @@ void RWStepAP214_ReadWriteModule::ReadStep(const Standard_Integer CN, tool.ReadStep (data,num,ach,anent); } + break; + case 107 : + { + DeclareAndCast(StepVisual_DraughtingCallout, anent, ent); + RWStepVisual_RWDraughtingCallout tool; + tool.ReadStep (data,num,ach,anent); + } break; case 108 : { @@ -9185,6 +9244,20 @@ void RWStepAP214_ReadWriteModule::ReadStep(const Standard_Integer CN, tool.ReadStep (data,num,ach,anent); } break; + case 703: + { + DeclareAndCast(StepAP242_DraughtingModelItemAssociation,anent,ent); + RWStepAP242_RWDraughtingModelItemAssociation tool; + tool.ReadStep (data,num,ach,anent); + } + break; + case 704: + { + DeclareAndCast(StepVisual_AnnotationPlane,anent,ent); + RWStepVisual_RWAnnotationPlane tool; + tool.ReadStep (data,num,ach,anent); + } + break; case 705: { DeclareAndCast(StepDimTol_GeoTolAndGeoTolWthDatRefAndGeoTolWthMaxTol,anent,ent); @@ -9199,6 +9272,43 @@ void RWStepAP214_ReadWriteModule::ReadStep(const Standard_Integer CN, tool.ReadStep (data,num,ach,anent); } break; + case 707: + { + DeclareAndCast(StepVisual_TessellatedAnnotationOccurrence,anent,ent); + RWStepVisual_RWTessellatedAnnotationOccurrence tool; + tool.ReadStep (data,num,ach,anent); + } + break; + + case 708: + { + DeclareAndCast(StepVisual_TessellatedItem,anent,ent); + RWStepVisual_RWTessellatedItem tool; + tool.ReadStep (data,num,ach,anent); + } + break; + + case 709: + { + DeclareAndCast(StepVisual_TessellatedGeometricSet,anent,ent); + RWStepVisual_RWTessellatedGeometricSet tool; + tool.ReadStep (data,num,ach,anent); + } + break; + case 710: + { + DeclareAndCast(StepVisual_TessellatedCurveSet,anent,ent); + RWStepVisual_RWTessellatedCurveSet tool; + tool.ReadStep (data,num,ach,anent); + } + break; + case 711: + { + DeclareAndCast(StepVisual_CoordinatesList,anent,ent); + RWStepVisual_RWCoordinatesList tool; + tool.ReadStep (data,num,ach,anent); + } + break; default: ach->AddFail("Type Mismatch when reading - Entity"); @@ -9244,12 +9354,18 @@ void RWStepAP214_ReadWriteModule::WriteStep(const Standard_Integer CN, tool.WriteStep (SW,anent); } + break; + case 4 : + { + DeclareAndCast(StepVisual_AnnotationCurveOccurrence, anent, ent); + RWStepVisual_RWAnnotationCurveOccurrence tool; + tool.WriteStep (SW,anent); + } break; case 7 : { - DeclareAndCast(StepVisual_StyledItem, anent, ent); - RWStepVisual_RWStyledItem tool; -// if (anent.IsNull()) return; + DeclareAndCast(StepVisual_AnnotationOccurrence, anent, ent); + RWStepVisual_RWAnnotationOccurrence tool; tool.WriteStep (SW,anent); } @@ -10027,6 +10143,13 @@ void RWStepAP214_ReadWriteModule::WriteStep(const Standard_Integer CN, tool.WriteStep (SW,anent); } + break; + case 107 : + { + DeclareAndCast(StepVisual_DraughtingCallout, anent, ent); + RWStepVisual_RWDraughtingCallout tool; + tool.WriteStep (SW,anent); + } break; case 108 : { @@ -13907,6 +14030,20 @@ void RWStepAP214_ReadWriteModule::WriteStep(const Standard_Integer CN, tool.WriteStep (SW,anent); } break; + case 703: + { + DeclareAndCast(StepAP242_DraughtingModelItemAssociation,anent,ent); + RWStepAP242_RWDraughtingModelItemAssociation tool; + tool.WriteStep (SW,anent); + } + break; + case 704: + { + DeclareAndCast(StepVisual_AnnotationPlane,anent,ent); + RWStepVisual_RWAnnotationPlane tool; + tool.WriteStep (SW,anent); + } + break; case 705: { DeclareAndCast(StepDimTol_GeoTolAndGeoTolWthDatRefAndGeoTolWthMaxTol,anent,ent); @@ -13921,6 +14058,44 @@ void RWStepAP214_ReadWriteModule::WriteStep(const Standard_Integer CN, tool.WriteStep (SW,anent); } break; + case 707: + { + DeclareAndCast(StepVisual_TessellatedAnnotationOccurrence,anent,ent); + RWStepVisual_RWTessellatedAnnotationOccurrence tool; + tool.WriteStep (SW,anent); + } + break; + + case 708: + { + DeclareAndCast(StepVisual_TessellatedItem,anent,ent); + RWStepVisual_RWTessellatedItem tool; + tool.WriteStep (SW,anent); + } + break; + + case 709: + { + DeclareAndCast(StepVisual_TessellatedGeometricSet,anent,ent); + RWStepVisual_RWTessellatedGeometricSet tool; + tool.WriteStep (SW,anent); + } + break; + case 710: + { + DeclareAndCast(StepVisual_TessellatedCurveSet,anent,ent); + RWStepVisual_RWTessellatedCurveSet tool; + tool.WriteStep (SW,anent); + } + break; + case 711: + { + DeclareAndCast(StepVisual_CoordinatesList,anent,ent); + RWStepVisual_RWCoordinatesList tool; + tool.WriteStep(SW,anent); + + } + break; default: return; diff --git a/src/RWStepAP242/FILES b/src/RWStepAP242/FILES index bf94f4dbf6..f1d2344738 100644 --- a/src/RWStepAP242/FILES +++ b/src/RWStepAP242/FILES @@ -1,3 +1,5 @@ +RWStepAP242_RWDraughtingModelItemAssociation.cxx +RWStepAP242_RWDraughtingModelItemAssociation.hxx RWStepAP242_RWGeometricItemSpecificUsage.cxx RWStepAP242_RWGeometricItemSpecificUsage.hxx RWStepAP242_RWIdAttribute.cxx diff --git a/src/RWStepAP242/RWStepAP242_RWDraughtingModelItemAssociation.cxx b/src/RWStepAP242/RWStepAP242_RWDraughtingModelItemAssociation.cxx new file mode 100644 index 0000000000..a1600f3a58 --- /dev/null +++ b/src/RWStepAP242/RWStepAP242_RWDraughtingModelItemAssociation.cxx @@ -0,0 +1,124 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepAP242_RWDraughtingModelItemAssociation +//purpose : +//======================================================================= +RWStepAP242_RWDraughtingModelItemAssociation::RWStepAP242_RWDraughtingModelItemAssociation () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepAP242_RWDraughtingModelItemAssociation::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepAP242_DraughtingModelItemAssociation)& ent) const +{ + // Number of Parameter Control + if (!data->CheckNbParams(num,5,ach,"geometric_item_specific_usage")) return; + + // Inherited fields of ItemIdentifiedRepresentationUsage + Handle(TCollection_HAsciiString) aName; + data->ReadString (num,1,"item_identified_representation_usage.name",ach,aName); + + Handle(TCollection_HAsciiString) aDescription; + if (data->IsParamDefined (num,2)) { + data->ReadString (num,2,"item_identified_representation_usage.description",ach,aDescription); + } + + StepAP242_ItemIdentifiedRepresentationUsageDefinition aDefinition; + data->ReadEntity(num,3,"item_identified_representation_usage.definition",ach,aDefinition); + + Handle(StepRepr_Representation) aRepresentation; + data->ReadEntity (num,4,"item_identified_representation_usage.used_representation",ach,STANDARD_TYPE(StepRepr_Representation), aRepresentation); + + Handle(StepRepr_HArray1OfRepresentationItem) anItems; + Handle(StepRepr_RepresentationItem) anEnt; + Standard_Integer nbSub; + Interface_ParamType aType = data->ParamType(num, 5); + if (aType == Interface_ParamIdent) { + data->ReadEntity(num, 5,"item_identified_representation_usage.identified_item", ach, STANDARD_TYPE(StepRepr_RepresentationItem), anEnt); + anItems = new StepRepr_HArray1OfRepresentationItem (1, 1); + anItems->SetValue(1, anEnt); + } + else if (data->ReadSubList (num,5,"item_identified_representation_usage.identified_item",ach,nbSub)) { + Standard_Integer nbElements = data->NbParams(nbSub); + anItems = new StepRepr_HArray1OfRepresentationItem (1, nbElements); + for (Standard_Integer i = 1; i <= nbElements; i++) { + if (data->ReadEntity(nbSub, i,"representation_item", ach, + STANDARD_TYPE(StepRepr_RepresentationItem), anEnt)) + anItems->SetValue(i, anEnt); + } + } + + // Initialisation of the read entity + ent->Init(aName, aDescription, aDefinition, aRepresentation, anItems); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepAP242_RWDraughtingModelItemAssociation::WriteStep + (StepData_StepWriter& SW, + const Handle(StepAP242_DraughtingModelItemAssociation)& ent) const +{ + // Inherited fields of ItemIdentifiedRepresentationUsage + SW.Send(ent->Name()); + + SW.Send(ent->Description()); + + SW.Send(ent->Definition().Value()); + + SW.Send(ent->UsedRepresentation()); + + if (ent->NbIdentifiedItem() == 1) + SW.Send(ent->IdentifiedItemValue(1)); + else { + SW.OpenSub(); + for (Standard_Integer i = 1; i <= ent->NbIdentifiedItem(); i++) { + SW.Send(ent->IdentifiedItemValue(i)); + } + SW.CloseSub(); + } +} + +//======================================================================= +//function : Share +//purpose : +//======================================================================= +void RWStepAP242_RWDraughtingModelItemAssociation::Share( + const Handle(StepAP242_DraughtingModelItemAssociation)& ent, + Interface_EntityIterator& iter) const +{ + // Inherited fields of ItemIdentifiedRepresentationUsage + + iter.AddItem(ent->Definition().Value()); + Standard_Integer i, nb = ent->NbIdentifiedItem(); + for (i = 1; i <= nb; i++) + iter.AddItem (ent->IdentifiedItemValue(i)); +} + diff --git a/src/RWStepAP242/RWStepAP242_RWDraughtingModelItemAssociation.hxx b/src/RWStepAP242/RWStepAP242_RWDraughtingModelItemAssociation.hxx new file mode 100644 index 0000000000..ecf710ae63 --- /dev/null +++ b/src/RWStepAP242/RWStepAP242_RWDraughtingModelItemAssociation.hxx @@ -0,0 +1,46 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepAP242_RWDraughtingModelItemAssociation_HeaderFile +#define _RWStepAP242_RWDraughtingModelItemAssociation_HeaderFile + +#include +#include +#include + +#include + +class StepData_StepReaderData; +class Interface_Check; +class StepAP242_DraughtingModelItemAssociation; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for DraughtingModelItemAssociation +class RWStepAP242_RWDraughtingModelItemAssociation +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepAP242_RWDraughtingModelItemAssociation(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, const Standard_Integer num, Handle(Interface_Check)& ach, const Handle(StepAP242_DraughtingModelItemAssociation)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepAP242_DraughtingModelItemAssociation)& ent) const; + + Standard_EXPORT void Share (const Handle(StepAP242_DraughtingModelItemAssociation)& ent, Interface_EntityIterator& iter) const; +}; +#endif // _RWStepAP242_RWDraughtingModelItemAssociation_HeaderFile diff --git a/src/RWStepVisual/FILES b/src/RWStepVisual/FILES index 2ead035db2..7208bb7023 100644 --- a/src/RWStepVisual/FILES +++ b/src/RWStepVisual/FILES @@ -1,3 +1,9 @@ +RWStepVisual_RWAnnotationCurveOccurrence.cxx +RWStepVisual_RWAnnotationCurveOccurrence.hxx +RWStepVisual_RWAnnotationOccurrence.cxx +RWStepVisual_RWAnnotationOccurrence.hxx +RWStepVisual_RWAnnotationPlane.cxx +RWStepVisual_RWAnnotationPlane.hxx RWStepVisual_RWAreaInSet.cxx RWStepVisual_RWAreaInSet.hxx RWStepVisual_RWBackgroundColour.cxx @@ -32,6 +38,8 @@ RWStepVisual_RWCurveStyleFont.cxx RWStepVisual_RWCurveStyleFont.hxx RWStepVisual_RWCurveStyleFontPattern.cxx RWStepVisual_RWCurveStyleFontPattern.hxx +RWStepVisual_RWDraughtingCallout.cxx +RWStepVisual_RWDraughtingCallout.hxx RWStepVisual_RWDraughtingModel.cxx RWStepVisual_RWDraughtingModel.hxx RWStepVisual_RWDraughtingPreDefinedColour.cxx @@ -116,3 +124,15 @@ RWStepVisual_RWTextStyleWithBoxCharacteristics.cxx RWStepVisual_RWTextStyleWithBoxCharacteristics.hxx RWStepVisual_RWViewVolume.cxx RWStepVisual_RWViewVolume.hxx +RWStepVisual_RWTessellatedItem.hxx +RWStepVisual_RWTessellatedItem.cxx +RWStepVisual_RWTessellatedAnnotationOccurrence.hxx +RWStepVisual_RWTessellatedAnnotationOccurrence.cxx +RWStepVisual_RWTessellatedGeometricSet.hxx +RWStepVisual_RWTessellatedGeometricSet.cxx +RWStepVisual_RWCoordinatesList.hxx +RWStepVisual_RWCoordinatesList.cxx +RWStepVisual_RWTessellatedCurveSet.hxx +RWStepVisual_RWTessellatedCurveSet.cxx + + diff --git a/src/RWStepVisual/RWStepVisual_RWAnnotationCurveOccurrence.cxx b/src/RWStepVisual/RWStepVisual_RWAnnotationCurveOccurrence.cxx new file mode 100644 index 0000000000..dce49234a2 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWAnnotationCurveOccurrence.cxx @@ -0,0 +1,108 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWAnnotationCurveOccurrence +//purpose : +//======================================================================= +RWStepVisual_RWAnnotationCurveOccurrence::RWStepVisual_RWAnnotationCurveOccurrence () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationCurveOccurrence::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_AnnotationCurveOccurrence)& ent) const +{ + + // Number of Parameter Control + if (!data->CheckNbParams(num, 3, ach, "styled_item")) return; + + // Inherited field : name + Handle(TCollection_HAsciiString) aName; + data->ReadString (num, 1, "name", ach, aName); + + // Inherited field : styles + Handle(StepVisual_HArray1OfPresentationStyleAssignment) aStyles; + Handle(StepVisual_PresentationStyleAssignment) anent2; + Standard_Integer nsub2; + if (data->ReadSubList (num,2,"styles",ach,nsub2)) { + Standard_Integer nb2 = data->NbParams(nsub2); + aStyles = new StepVisual_HArray1OfPresentationStyleAssignment (1, nb2); + for (Standard_Integer i2 = 1; i2 <= nb2; i2 ++) { + if (data->ReadEntity (nsub2, i2,"presentation_style_assignment", ach, + STANDARD_TYPE(StepVisual_PresentationStyleAssignment), anent2)) + aStyles->SetValue(i2, anent2); + } + } + + // Inherited field : item + Handle(StepRepr_RepresentationItem) aItem; + data->ReadEntity(num, 3,"item", ach, STANDARD_TYPE(StepRepr_RepresentationItem), aItem); + + // Initialisation of the read entity + ent->Init(aName, aStyles, aItem); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationCurveOccurrence::WriteStep + (StepData_StepWriter& SW, + const Handle(StepVisual_AnnotationCurveOccurrence)& ent) const +{ + //Inherited field : name + SW.Send(ent->Name()); + + // Inherited field : styles + SW.OpenSub(); + for (Standard_Integer i2 = 1; i2 <= ent->NbStyles(); i2 ++) { + SW.Send(ent->StylesValue(i2)); + } + SW.CloseSub(); + + // Inherited field : item + + SW.Send(ent->Item()); +} + +//======================================================================= +//function : Share +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationCurveOccurrence::Share(const Handle(StepVisual_AnnotationCurveOccurrence)& ent, Interface_EntityIterator& iter) const +{ + + Standard_Integer nbElem1 = ent->NbStyles(); + for (Standard_Integer is1=1; is1<=nbElem1; is1 ++) { + iter.GetOneItem(ent->StylesValue(is1)); + } + + iter.GetOneItem(ent->Item()); +} diff --git a/src/RWStepVisual/RWStepVisual_RWAnnotationCurveOccurrence.hxx b/src/RWStepVisual/RWStepVisual_RWAnnotationCurveOccurrence.hxx new file mode 100644 index 0000000000..d246c7770a --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWAnnotationCurveOccurrence.hxx @@ -0,0 +1,45 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWAnnotationCurveOccurrence_HeaderFile +#define _RWStepVisual_RWAnnotationCurveOccurrence_HeaderFile + +#include +#include +#include + +#include +class StepData_StepReaderData; +class Interface_Check; +class StepVisual_AnnotationCurveOccurrence; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for AnnotationCurveOccurrence +class RWStepVisual_RWAnnotationCurveOccurrence +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWAnnotationCurveOccurrence(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, const Standard_Integer num, Handle(Interface_Check)& ach, const Handle(StepVisual_AnnotationCurveOccurrence)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_AnnotationCurveOccurrence)& ent) const; + + Standard_EXPORT void Share (const Handle(StepVisual_AnnotationCurveOccurrence)& ent, Interface_EntityIterator& iter) const; +}; +#endif // _RWStepVisual_RWAnnotationCurveOccurrence_HeaderFile diff --git a/src/RWStepVisual/RWStepVisual_RWAnnotationOccurrence.cxx b/src/RWStepVisual/RWStepVisual_RWAnnotationOccurrence.cxx new file mode 100644 index 0000000000..8de83e803d --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWAnnotationOccurrence.cxx @@ -0,0 +1,107 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWAnnotationOccurrence +//purpose : +//======================================================================= +RWStepVisual_RWAnnotationOccurrence::RWStepVisual_RWAnnotationOccurrence () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationOccurrence::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_AnnotationOccurrence)& ent) const +{ + // Number of Parameter Control + if (!data->CheckNbParams(num, 3, ach, "annotation_occurrence")) return; + + // Inherited field : name + Handle(TCollection_HAsciiString) aName; + data->ReadString (num, 1, "name", ach, aName); + + // Inherited field : styles + Handle(StepVisual_HArray1OfPresentationStyleAssignment) aStyles; + Handle(StepVisual_PresentationStyleAssignment) anent2; + Standard_Integer nsub2; + if (data->ReadSubList (num,2,"styles",ach,nsub2)) { + Standard_Integer nb2 = data->NbParams(nsub2); + aStyles = new StepVisual_HArray1OfPresentationStyleAssignment (1, nb2); + for (Standard_Integer i2 = 1; i2 <= nb2; i2 ++) { + if (data->ReadEntity (nsub2, i2,"presentation_style_assignment", ach, + STANDARD_TYPE(StepVisual_PresentationStyleAssignment), anent2)) + aStyles->SetValue(i2, anent2); + } + } + + // Inherited field : item + Handle(StepRepr_RepresentationItem) aItem; + data->ReadEntity(num, 3, "item", ach, STANDARD_TYPE(StepRepr_RepresentationItem), aItem); + + // Initialisation of the read entity + ent->Init(aName, aStyles, aItem); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationOccurrence::WriteStep + (StepData_StepWriter& SW, + const Handle(StepVisual_AnnotationOccurrence)& ent) const +{ + // Inherited field : name + SW.Send(ent->Name()); + + // Inherited field : styles + + SW.OpenSub(); + for (Standard_Integer i2 = 1; i2 <= ent->NbStyles(); i2 ++) { + SW.Send(ent->StylesValue(i2)); + } + SW.CloseSub(); + + // Inherited field : item + + SW.Send(ent->Item()); +} + +//======================================================================= +//function : Share +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationOccurrence::Share(const Handle(StepVisual_AnnotationOccurrence)& ent, Interface_EntityIterator& iter) const +{ + Standard_Integer nbElem1 = ent->NbStyles(); + for (Standard_Integer is1=1; is1<=nbElem1; is1 ++) { + iter.GetOneItem(ent->StylesValue(is1)); + } + iter.GetOneItem(ent->Item()); +} diff --git a/src/RWStepVisual/RWStepVisual_RWAnnotationOccurrence.hxx b/src/RWStepVisual/RWStepVisual_RWAnnotationOccurrence.hxx new file mode 100644 index 0000000000..ca452c52a7 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWAnnotationOccurrence.hxx @@ -0,0 +1,45 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWAnnotationOccurrence_HeaderFile +#define _RWStepVisual_RWAnnotationOccurrence_HeaderFile + +#include +#include +#include + +#include +class StepData_StepReaderData; +class Interface_Check; +class StepVisual_AnnotationOccurrence; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for AnnotationOccurrence +class RWStepVisual_RWAnnotationOccurrence +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWAnnotationOccurrence(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, const Standard_Integer num, Handle(Interface_Check)& ach, const Handle(StepVisual_AnnotationOccurrence)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_AnnotationOccurrence)& ent) const; + + Standard_EXPORT void Share (const Handle(StepVisual_AnnotationOccurrence)& ent, Interface_EntityIterator& iter) const; +}; +#endif // _RWStepVisual_RWAnnotationOccurrence_HeaderFile diff --git a/src/RWStepVisual/RWStepVisual_RWAnnotationPlane.cxx b/src/RWStepVisual/RWStepVisual_RWAnnotationPlane.cxx new file mode 100644 index 0000000000..1f1f6d1bd0 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWAnnotationPlane.cxx @@ -0,0 +1,133 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWAnnotationPlane +//purpose : +//======================================================================= +RWStepVisual_RWAnnotationPlane::RWStepVisual_RWAnnotationPlane () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationPlane::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_AnnotationPlane)& ent) const +{ + // Number of Parameter Control + if (!data->CheckNbParams(num, 4, ach, "annotation_plane")) return; + + // Inherited field : name + Handle(TCollection_HAsciiString) aName; + data->ReadString (num, 1, "name", ach, aName); + + // Inherited field : styles + Handle(StepVisual_HArray1OfPresentationStyleAssignment) aStyles; + Handle(StepVisual_PresentationStyleAssignment) anent2; + Standard_Integer nsub2; + if (data->ReadSubList (num,2,"styles",ach,nsub2)) { + Standard_Integer nb2 = data->NbParams(nsub2); + aStyles = new StepVisual_HArray1OfPresentationStyleAssignment (1, nb2); + for (Standard_Integer i2 = 1; i2 <= nb2; i2 ++) { + if (data->ReadEntity (nsub2, i2,"presentation_style_assignment", ach, + STANDARD_TYPE(StepVisual_PresentationStyleAssignment), anent2)) + aStyles->SetValue(i2, anent2); + } + } + + // Inherited field : item + Handle(StepRepr_RepresentationItem) aItem; + data->ReadEntity(num, 3, "item", ach, STANDARD_TYPE(StepRepr_RepresentationItem), aItem); + + // Own field: elements + Handle(StepVisual_HArray1OfAnnotationPlaneElement) anElements; + StepVisual_AnnotationPlaneElement anEnt; + Standard_Integer nbSub; + if (data->ReadSubList (num, 4, "elements", ach, nbSub)) { + Standard_Integer nbElements = data->NbParams(nbSub); + anElements = new StepVisual_HArray1OfAnnotationPlaneElement (1, nbElements); + for (Standard_Integer i = 1; i <= nbElements; i++) { + if (data->ReadEntity(nbSub, i,"content", ach, anEnt)) + anElements->SetValue(i, anEnt); + } + } + + // Initialisation of the read entity + ent->Init(aName, aStyles, aItem, anElements); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationPlane::WriteStep + (StepData_StepWriter& SW, + const Handle(StepVisual_AnnotationPlane)& ent) const +{ + // Inherited field : name + + SW.Send(ent->Name()); + + // Inherited field : styles + + SW.OpenSub(); + for (Standard_Integer i2 = 1; i2 <= ent->NbStyles(); i2 ++) { + SW.Send(ent->StylesValue(i2)); + } + SW.CloseSub(); + + // Inherited field : item + SW.Send(ent->Item()); + + // Own field: elements + SW.OpenSub(); + for (Standard_Integer i = 1; i <= ent->NbElements(); i++) { + SW.Send(ent->ElementsValue(i).Value()); + } + SW.CloseSub(); +} + +//======================================================================= +//function : Share +//purpose : +//======================================================================= +void RWStepVisual_RWAnnotationPlane::Share(const Handle(StepVisual_AnnotationPlane)& ent, Interface_EntityIterator& iter) const +{ + Standard_Integer nbElem1 = ent->NbStyles(); + for (Standard_Integer is1=1; is1<=nbElem1; is1 ++) { + iter.GetOneItem(ent->StylesValue(is1)); + } + iter.GetOneItem(ent->Item()); + + // Own field: contents + Standard_Integer i, nb = ent->NbElements(); + for (i = 1; i <= nb; i++) + iter.AddItem (ent->ElementsValue(i).Value()); +} + diff --git a/src/RWStepVisual/RWStepVisual_RWAnnotationPlane.hxx b/src/RWStepVisual/RWStepVisual_RWAnnotationPlane.hxx new file mode 100644 index 0000000000..224e375866 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWAnnotationPlane.hxx @@ -0,0 +1,45 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWAnnotationPlane_HeaderFile +#define _RWStepVisual_RWAnnotationPlane_HeaderFile + +#include +#include +#include + +#include +class StepData_StepReaderData; +class Interface_Check; +class StepVisual_AnnotationPlane; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for AnnotationPlane +class RWStepVisual_RWAnnotationPlane +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWAnnotationPlane(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, const Standard_Integer num, Handle(Interface_Check)& ach, const Handle(StepVisual_AnnotationPlane)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_AnnotationPlane)& ent) const; + + Standard_EXPORT void Share (const Handle(StepVisual_AnnotationPlane)& ent, Interface_EntityIterator& iter) const; +}; +#endif // _RWStepVisual_RWAnnotationPlane_HeaderFile diff --git a/src/RWStepVisual/RWStepVisual_RWCoordinatesList.cxx b/src/RWStepVisual/RWStepVisual_RWCoordinatesList.cxx new file mode 100644 index 0000000000..2a8e6e159b --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWCoordinatesList.cxx @@ -0,0 +1,115 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWCoordinatesList +//purpose : +//======================================================================= +RWStepVisual_RWCoordinatesList::RWStepVisual_RWCoordinatesList () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWCoordinatesList::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_CoordinatesList)& ent) const +{ + // Number of Parameter Control + if (!data->CheckNbParams(num, 3, ach, "coordinate list")) return; + + // Inherited field : name + Handle(TCollection_HAsciiString) aName; + data->ReadString (num, 1, "name", ach, aName); + Standard_Integer nbP =0; + data->ReadInteger(num, 2, "number_points", ach,nbP); + + Handle(TColgp_HArray1OfXYZ) aPoints;// = new TColgp_HArray1OfXYZ(1, nbP); + Standard_Integer nsub2; + if (data->ReadSubList (num,3,"items",ach,nsub2)) + { + Standard_Integer nb2 = data->NbParams(nsub2); + if( !nb2) + return; + aPoints = new TColgp_HArray1OfXYZ(1, nb2); + for (Standard_Integer i = 1; i <= nb2; i++) + { + gp_XYZ aXYZ(0.,0.,0.); + Standard_Integer nsub3; + if (data->ReadSubList (nsub2,i,"coordinates",ach,nsub3)) { + Standard_Integer nb3 = data->NbParams(nsub3); + if(nb3 > 3) { + ach->AddWarning("More than 3 coordinates, ignored"); + } + Standard_Integer nbcoord = Min (nb3, 3); + for (Standard_Integer j = 1; j <= nbcoord; j++) { + Standard_Real aVal =0.; + if (data->ReadReal (nsub3,j,"coordinates",ach,aVal)) { + aXYZ.SetCoord(j, aVal); + } + } + + } + aPoints->SetValue(i, aXYZ); + } + } + + + //--- Initialisation of the read entity --- + + + ent->Init(aName, aPoints); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWCoordinatesList::WriteStep + (StepData_StepWriter& SW, const Handle(StepVisual_CoordinatesList)& ent) const +{ + // Inherited field : name + SW.Send(ent->Name()); + + // Own field : npoints + SW.Send(ent->Points()->Length()); + + // Own field : position_coords + SW.OpenSub(); + for (Standard_Integer i = 1; i <= ent->Points()->Length(); i++) { + SW.OpenSub(); + gp_XYZ aPoint = ent->Points()->Value(i); + SW.Send(aPoint.X()); + SW.Send(aPoint.Y()); + SW.Send(aPoint.Z()); + SW.CloseSub(); + } + SW.CloseSub(); +} diff --git a/src/RWStepVisual/RWStepVisual_RWCoordinatesList.hxx b/src/RWStepVisual/RWStepVisual_RWCoordinatesList.hxx new file mode 100644 index 0000000000..1d122062f4 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWCoordinatesList.hxx @@ -0,0 +1,46 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWCoordinatesList_HeaderFile +#define _RWStepVisual_RWCoordinatesList_HeaderFile + +#include +#include +#include + +#include +#include +class Interface_Check; +class StepVisual_CoordinatesList; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for AnnotationOccurrence +class RWStepVisual_RWCoordinatesList +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWCoordinatesList(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_CoordinatesList)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_CoordinatesList)& ent) const; +}; +#endif // _RWStepVisual_RWCoordinatesList_HeaderFile diff --git a/src/RWStepVisual/RWStepVisual_RWDraughtingCallout.cxx b/src/RWStepVisual/RWStepVisual_RWDraughtingCallout.cxx new file mode 100644 index 0000000000..a5ebadd6d3 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWDraughtingCallout.cxx @@ -0,0 +1,93 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWDraughtingCallout +//purpose : +//======================================================================= +RWStepVisual_RWDraughtingCallout::RWStepVisual_RWDraughtingCallout () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWDraughtingCallout::ReadStep(const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_DraughtingCallout)& ent) const +{ + if (!data->CheckNbParams(num, 2, ach, "draughting_callout")) return; + + // Inherited field : name + Handle(TCollection_HAsciiString) aName; + data->ReadString (num, 1, "name" ,ach, aName); + + // Own field: contents + Handle(StepVisual_HArray1OfDraughtingCalloutElement) aContents; + StepVisual_DraughtingCalloutElement anEnt; + Standard_Integer nbSub; + if (data->ReadSubList (num, 2, "contents", ach, nbSub)) { + Standard_Integer nbElements = data->NbParams(nbSub); + aContents = new StepVisual_HArray1OfDraughtingCalloutElement (1, nbElements); + for (Standard_Integer i = 1; i <= nbElements; i++) { + if (data->ReadEntity(nbSub, i,"content", ach, anEnt)) + aContents->SetValue(i, anEnt); + } + } + + // Initialisation of the read entity + ent->Init(aName, aContents); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWDraughtingCallout::WriteStep + (StepData_StepWriter& SW, + const Handle(StepVisual_DraughtingCallout)& ent) const +{ + // Inherited field: name + SW.Send(ent->Name()); + + // Own field: contents + SW.OpenSub(); + for (Standard_Integer i = 1; i <= ent->NbContents(); i++) { + SW.Send(ent->ContentsValue(i).Value()); + } + SW.CloseSub(); +} + +//======================================================================= +//function : Share +//purpose : +//======================================================================= + +void RWStepVisual_RWDraughtingCallout::Share (const Handle(StepVisual_DraughtingCallout) &ent, + Interface_EntityIterator& iter) const +{ + // Own field: contents + Standard_Integer i, nb = ent->NbContents(); + for (i = 1; i <= nb; i++) + iter.AddItem (ent->ContentsValue(i).Value()); +} + diff --git a/src/RWStepVisual/RWStepVisual_RWDraughtingCallout.hxx b/src/RWStepVisual/RWStepVisual_RWDraughtingCallout.hxx new file mode 100644 index 0000000000..9d561357d2 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWDraughtingCallout.hxx @@ -0,0 +1,45 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWDraughtingCallout_HeaderFile +#define _RWStepVisual_RWDraughtingCallout_HeaderFile + +#include +#include +#include + +#include +class Interface_EntityIterator; +class StepData_StepReaderData; +class Interface_Check; +class StepVisual_DraughtingCallout; +class StepData_StepWriter; + +//! Read & Write Module for DraughtingCallout +class RWStepVisual_RWDraughtingCallout +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWDraughtingCallout(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, const Standard_Integer num, Handle(Interface_Check)& ach, const Handle(StepVisual_DraughtingCallout)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_DraughtingCallout)& ent) const; + + Standard_EXPORT void Share (const Handle(StepVisual_DraughtingCallout)& ent, Interface_EntityIterator& iter) const; +}; +#endif // _RWStepVisual_RWDraughtingCallout_HeaderFile diff --git a/src/RWStepVisual/RWStepVisual_RWTessellatedAnnotationOccurrence.cxx b/src/RWStepVisual/RWStepVisual_RWTessellatedAnnotationOccurrence.cxx new file mode 100644 index 0000000000..cf34fc9361 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWTessellatedAnnotationOccurrence.cxx @@ -0,0 +1,108 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWTessellatedAnnotationOccurrence +//purpose : +//======================================================================= +RWStepVisual_RWTessellatedAnnotationOccurrence::RWStepVisual_RWTessellatedAnnotationOccurrence () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedAnnotationOccurrence::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_TessellatedAnnotationOccurrence)& ent) const +{ + + // Number of Parameter Control + if (!data->CheckNbParams(num, 3, ach, "styled_item")) return; + + // Inherited field : name + Handle(TCollection_HAsciiString) aName; + data->ReadString (num, 1, "name", ach, aName); + + // Inherited field : styles + Handle(StepVisual_HArray1OfPresentationStyleAssignment) aStyles; + Handle(StepVisual_PresentationStyleAssignment) anent2; + Standard_Integer nsub2; + if (data->ReadSubList (num,2,"styles",ach,nsub2)) { + Standard_Integer nb2 = data->NbParams(nsub2); + aStyles = new StepVisual_HArray1OfPresentationStyleAssignment (1, nb2); + for (Standard_Integer i2 = 1; i2 <= nb2; i2 ++) { + if (data->ReadEntity (nsub2, i2,"presentation_style_assignment", ach, + STANDARD_TYPE(StepVisual_PresentationStyleAssignment), anent2)) + aStyles->SetValue(i2, anent2); + } + } + + // Inherited field : item + Handle(StepRepr_RepresentationItem) aItem; + data->ReadEntity(num, 3,"item", ach, STANDARD_TYPE(StepRepr_RepresentationItem), aItem); + + // Initialisation of the read entity + ent->Init(aName, aStyles, aItem); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedAnnotationOccurrence::WriteStep + (StepData_StepWriter& SW, + const Handle(StepVisual_TessellatedAnnotationOccurrence)& ent) const +{ + //Inherited field : name + SW.Send(ent->Name()); + + // Inherited field : styles + SW.OpenSub(); + for (Standard_Integer i2 = 1; i2 <= ent->NbStyles(); i2 ++) { + SW.Send(ent->StylesValue(i2)); + } + SW.CloseSub(); + + // Inherited field : item + + SW.Send(ent->Item()); +} + +//======================================================================= +//function : Share +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedAnnotationOccurrence::Share(const Handle(StepVisual_TessellatedAnnotationOccurrence)& ent, Interface_EntityIterator& iter) const +{ + + Standard_Integer nbElem1 = ent->NbStyles(); + for (Standard_Integer is1=1; is1<=nbElem1; is1 ++) { + iter.GetOneItem(ent->StylesValue(is1)); + } + + iter.GetOneItem(ent->Item()); +} diff --git a/src/RWStepVisual/RWStepVisual_RWTessellatedAnnotationOccurrence.hxx b/src/RWStepVisual/RWStepVisual_RWTessellatedAnnotationOccurrence.hxx new file mode 100644 index 0000000000..99006f6b32 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWTessellatedAnnotationOccurrence.hxx @@ -0,0 +1,45 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWTessellatedAnnotationOccurrence_HeaderFile +#define _RWStepVisual_RWTessellatedAnnotationOccurrence_HeaderFile + +#include +#include +#include + +#include +class StepData_StepReaderData; +class Interface_Check; +class StepVisual_TessellatedAnnotationOccurrence; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for AnnotationOccurrence +class RWStepVisual_RWTessellatedAnnotationOccurrence +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWTessellatedAnnotationOccurrence(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, const Standard_Integer num, Handle(Interface_Check)& ach, const Handle(StepVisual_TessellatedAnnotationOccurrence)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_TessellatedAnnotationOccurrence)& ent) const; + + Standard_EXPORT void Share (const Handle(StepVisual_TessellatedAnnotationOccurrence)& ent, Interface_EntityIterator& iter) const; +}; +#endif // _RWStepVisual_RWTessellatedAnnotationOccurrence_HeaderFile diff --git a/src/RWStepVisual/RWStepVisual_RWTessellatedCurveSet.cxx b/src/RWStepVisual/RWStepVisual_RWTessellatedCurveSet.cxx new file mode 100644 index 0000000000..ec8326b8f8 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWTessellatedCurveSet.cxx @@ -0,0 +1,105 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWTessellatedCurveSet +//purpose : +//======================================================================= +RWStepVisual_RWTessellatedCurveSet::RWStepVisual_RWTessellatedCurveSet () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedCurveSet::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_TessellatedCurveSet)& ent) const +{ + // Number of Parameter Control + if (!data->CheckNbParams(num, 3, ach, "tessellated_curve_set")) return; + + // Inherited field : name + Handle(TCollection_HAsciiString) aName; + data->ReadString (num, 1, "name", ach, aName); + + Handle(StepVisual_CoordinatesList) aCoordList; + data->ReadEntity (num, 2,"coord_list",ach,STANDARD_TYPE(StepVisual_CoordinatesList), aCoordList); + //--- Initialisation of the read entity --- + Standard_Integer nsub2; + NCollection_Handle aCurves = new StepVisual_VectorOfHSequenceOfInteger; + if (data->ReadSubList (num,3,"curves",ach,nsub2)) + { + Standard_Integer nb2 = data->NbParams(nsub2); + if( !nb2) + return; + + for (Standard_Integer i = 1; i <= nb2; i++) + { + Handle(TColStd_HSequenceOfInteger) aCurve = new TColStd_HSequenceOfInteger; + Standard_Integer nsub3; + if (data->ReadSubList (nsub2,i,"number_coordinates",ach,nsub3)) { + Standard_Integer nb3 = data->NbParams(nsub3); + for (Standard_Integer j = 1; j <= nb3; j++) { + Standard_Integer aVal =0; + if (data->ReadInteger (nsub3,j,"coordinates",ach,aVal)) + aCurve->Append(aVal); + + } + aCurves->Append(aCurve); + + } + } + } + ent->Init(aName, aCoordList, aCurves); + +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedCurveSet::WriteStep + (StepData_StepWriter& SW, + const Handle(StepVisual_TessellatedCurveSet)& ent) const +{ + // Inherited field : name + SW.Send(ent->Name()); + + // Own filed : coordinates + SW.Send(ent->CoordList()); + + // Own field : line_strips + SW.OpenSub(); + for (Standard_Integer curveIt = 0; curveIt < ent->Curves()->Length(); curveIt++) { + Handle(TColStd_HSequenceOfInteger) aCurve = ent->Curves()->Value(curveIt); + SW.OpenSub(); + for (Standard_Integer i = 1; i <= aCurve->Length(); i++) + SW.Send(aCurve->Value(i)); + SW.CloseSub(); + } + SW.CloseSub(); +} diff --git a/src/RWStepVisual/RWStepVisual_RWTessellatedCurveSet.hxx b/src/RWStepVisual/RWStepVisual_RWTessellatedCurveSet.hxx new file mode 100644 index 0000000000..5f1a01f9bc --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWTessellatedCurveSet.hxx @@ -0,0 +1,47 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWTessellatedCurveSet_HeaderFile +#define _RWStepVisual_RWTessellatedCurveSet_HeaderFile + +#include +#include +#include + +#include +#include +class StepData_StepReaderData; +class Interface_Check; +//class StepVisual_TessellatedCurveSet; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for AnnotationOccurrence +class RWStepVisual_RWTessellatedCurveSet +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWTessellatedCurveSet(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_TessellatedCurveSet)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_TessellatedCurveSet)& ent) const; +}; +#endif // _RWStepVisual_RWTessellatedItem_HeaderFile diff --git a/src/RWStepVisual/RWStepVisual_RWTessellatedGeometricSet.cxx b/src/RWStepVisual/RWStepVisual_RWTessellatedGeometricSet.cxx new file mode 100644 index 0000000000..e1bfc63a07 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWTessellatedGeometricSet.cxx @@ -0,0 +1,96 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWTessellatedGeometricSet +//purpose : +//======================================================================= +RWStepVisual_RWTessellatedGeometricSet::RWStepVisual_RWTessellatedGeometricSet () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedGeometricSet::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_TessellatedGeometricSet)& ent) const +{ + // Number of Parameter Control + if (!data->CheckNbParams(num, 2, ach, "tessellated_geometric_set")) return; + + // Inherited field : name + Handle(TCollection_HAsciiString) aName; + data->ReadString (num, 1, "name", ach, aName); + + NCollection_Handle anItems; + Standard_Integer nsub2; + if (data->ReadSubList (num,2,"items",ach,nsub2)) { + Standard_Integer nb2 = data->NbParams(nsub2); + anItems = new StepVisual_Array1OfTessellaltedItem(1, nb2); + for (Standard_Integer i2 = 1; i2 <= nb2; i2 ++) { + Handle(StepVisual_TessellatedItem) anItem;// = new StepVisual_TesselatedItem; + if (data->ReadEntity (nsub2,i2,"item",ach,STANDARD_TYPE(StepVisual_TessellatedItem), anItem)) + anItems->SetValue(i2,anItem); + } + } + + //--- Initialisation of the read entity --- + + + ent->Init(aName, anItems); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedGeometricSet::WriteStep + (StepData_StepWriter& SW, + const Handle(StepVisual_TessellatedGeometricSet)& ent) const +{ + // Inherited field : name + SW.Send(ent->Name()); + + // Own field : children + SW.OpenSub(); + for (Standard_Integer i = 1; i <= ent->Items()->Length(); i++) + SW.Send(ent->Items()->Value(i)); + SW.CloseSub(); +} + +//======================================================================= +//function : Share +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedGeometricSet::Share(const Handle(StepVisual_TessellatedGeometricSet)& ent, Interface_EntityIterator& iter) const +{ + // Own field : children + for (Standard_Integer i = 1; i <= ent->Items()->Length(); i++) + iter.AddItem(ent->Items()->Value(i)); +} diff --git a/src/RWStepVisual/RWStepVisual_RWTessellatedGeometricSet.hxx b/src/RWStepVisual/RWStepVisual_RWTessellatedGeometricSet.hxx new file mode 100644 index 0000000000..22b04348be --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWTessellatedGeometricSet.hxx @@ -0,0 +1,48 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWTessellatedGeometricSet_HeaderFile +#define _RWStepVisual_RWTessellatedGeometricSet_HeaderFile + +#include +#include +#include + +#include +class StepData_StepReaderData; +class Interface_Check; +class StepVisual_TessellatedGeometricSet; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for AnnotationOccurrence +class RWStepVisual_RWTessellatedGeometricSet +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWTessellatedGeometricSet(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_TessellatedGeometricSet)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_TessellatedGeometricSet)& ent) const; + + Standard_EXPORT void Share (const Handle(StepVisual_TessellatedGeometricSet)& ent, Interface_EntityIterator& iter) const; +}; +#endif // _RWStepVisual_RWTessellatedItem_HeaderFile diff --git a/src/RWStepVisual/RWStepVisual_RWTessellatedItem.cxx b/src/RWStepVisual/RWStepVisual_RWTessellatedItem.cxx new file mode 100644 index 0000000000..57ddb5f639 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWTessellatedItem.cxx @@ -0,0 +1,59 @@ +// Copyright (c) 1999-2014 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +#include +#include + +//======================================================================= +//function : RWStepVisual_RWTessellatedItem +//purpose : +//======================================================================= +RWStepVisual_RWTessellatedItem::RWStepVisual_RWTessellatedItem () {} + +//======================================================================= +//function : ReadStep +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedItem::ReadStep + (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_TessellatedItem)& ent) const +{ + // --- Number of Parameter Control --- + if (!data->CheckNbParams(num,1,ach,"tessellated_item")) return; + + // --- inherited field : name --- + + Handle(TCollection_HAsciiString) aName; + data->ReadString (num,1,"name",ach,aName); + + //--- Initialisation of the read entity --- + ent->Init(aName); +} + +//======================================================================= +//function : WriteStep +//purpose : +//======================================================================= +void RWStepVisual_RWTessellatedItem::WriteStep + (StepData_StepWriter& SW, + const Handle(StepVisual_TessellatedItem)& ent) const +{ + // --- inherited field name --- + SW.Send(ent->Name()); +} diff --git a/src/RWStepVisual/RWStepVisual_RWTessellatedItem.hxx b/src/RWStepVisual/RWStepVisual_RWTessellatedItem.hxx new file mode 100644 index 0000000000..800eb25551 --- /dev/null +++ b/src/RWStepVisual/RWStepVisual_RWTessellatedItem.hxx @@ -0,0 +1,46 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _RWStepVisual_RWTessellatedItem_HeaderFile +#define _RWStepVisual_RWTessellatedItem_HeaderFile + +#include +#include +#include + +#include +class StepData_StepReaderData; +class Interface_Check; +class StepVisual_TessellatedItem; +class StepData_StepWriter; +class Interface_EntityIterator; + +//! Read & Write Module for AnnotationOccurrence +class RWStepVisual_RWTessellatedItem +{ +public: + + DEFINE_STANDARD_ALLOC + + Standard_EXPORT RWStepVisual_RWTessellatedItem(); + + Standard_EXPORT void ReadStep (const Handle(StepData_StepReaderData)& data, + const Standard_Integer num, + Handle(Interface_Check)& ach, + const Handle(StepVisual_TessellatedItem)& ent) const; + + Standard_EXPORT void WriteStep (StepData_StepWriter& SW, const Handle(StepVisual_TessellatedItem)& ent) const; +}; +#endif // _RWStepVisual_RWTessellatedItem_HeaderFile diff --git a/src/STEPCAFControl/STEPCAFControl_Reader.cxx b/src/STEPCAFControl/STEPCAFControl_Reader.cxx index ee7b30bd3f..9065cb9cf7 100644 --- a/src/STEPCAFControl/STEPCAFControl_Reader.cxx +++ b/src/STEPCAFControl/STEPCAFControl_Reader.cxx @@ -96,6 +96,9 @@ #include #include #include +#include +#include +#include #include #include #include @@ -144,6 +147,7 @@ #include #include #include +#include #include #include #include @@ -164,8 +168,13 @@ #include #include #include +#include +#include +#include +#include #include #include +#include #include #include #include @@ -187,6 +196,7 @@ #include #include #include +#include #include #include #include @@ -219,9 +229,25 @@ #include #include #include +#include #include #include #include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include + // skl 21.08.2003 for reading G&DT //#include //#include @@ -1691,6 +1717,262 @@ static Standard_Boolean GetMassConversionFactor(Handle(StepBasic_NamedUnit)& NU, return Standard_True; } +//======================================================================= +//function : readAnnotation +//purpose : return annotation plane and position for given GDT +// (Dimension, Geometric_Tolerance, Datum_Feature or Placed_Datum_Target_Feature) +//======================================================================= +void readAnnotation(const Handle(XSControl_TransferReader)& theTR, + const Handle(Standard_Transient) theGDT, + const Handle(Standard_Transient)& theDimObject) +{ + Handle(TCollection_HAsciiString) aPresentName; + TopoDS_Compound aResAnnotation; + Handle(Transfer_TransientProcess) aTP = theTR->TransientProcess(); + const Interface_Graph& aGraph = aTP->Graph(); + // find the proper DraughtingModelItemAssociation + Interface_EntityIterator subs = aGraph.Sharings(theGDT); + Handle(StepAP242_DraughtingModelItemAssociation) aDMIA; + for (subs.Start(); subs.More() && aDMIA.IsNull(); subs.Next()) { + if (!subs.Value()->IsKind(STANDARD_TYPE(StepAP242_DraughtingModelItemAssociation))) + continue; + aDMIA = Handle(StepAP242_DraughtingModelItemAssociation)::DownCast(subs.Value()); + Handle(TCollection_HAsciiString) aName = aDMIA->Name(); + aName->LowerCase(); + if (!aName->Search(new TCollection_HAsciiString("pmi representation to presentation link"))) { + aDMIA = NULL; + } + } + if (aDMIA.IsNull() || aDMIA->NbIdentifiedItem() == 0) + return; + + // retrieve AnnotationPlane + Standard_Boolean isHasPlane = Standard_False; + gp_Ax2 aPlaneAxes; + Handle(StepRepr_RepresentationItem) aDMIAE = aDMIA->IdentifiedItemValue(1); + if (aDMIAE.IsNull()) + return; + subs = aGraph.Sharings(aDMIAE); + Handle(StepVisual_AnnotationPlane) anAnPlane; + for (subs.Start(); subs.More() && anAnPlane.IsNull(); subs.Next()) { + anAnPlane = Handle(StepVisual_AnnotationPlane)::DownCast(subs.Value()); + } + if (!anAnPlane.IsNull()) { + Handle(StepRepr_RepresentationItem) aPlaneItem = anAnPlane->Item(); + Handle(StepGeom_Axis2Placement3d) aA2P3D; + //retrieve axes from AnnotationPlane + if (aPlaneItem->IsKind(STANDARD_TYPE(StepGeom_Plane))) { + Handle(StepGeom_Plane) aPlane = Handle(StepGeom_Plane)::DownCast(aPlaneItem); + aA2P3D = aPlane->Position(); + } + else if (aPlaneItem->IsKind(STANDARD_TYPE(StepVisual_PlanarBox))) { + Handle(StepVisual_PlanarBox) aBox = Handle(StepVisual_PlanarBox)::DownCast(aPlaneItem); + aA2P3D = aBox->Placement().Axis2Placement3d(); + } + // build gp_Ax2 from axes + if (!aA2P3D.IsNull()) + { + Handle(StepGeom_Direction) anAxis = aA2P3D->Axis(), + aRefDir = aA2P3D->RefDirection(); + if (!anAxis.IsNull() && !aRefDir.IsNull()) { + Handle(TColStd_HArray1OfReal) aCoords; + aCoords = anAxis->DirectionRatios(); + gp_Dir aXDir(aCoords->Value(1), aCoords->Value(2), aCoords->Value(3)); + aCoords = aRefDir->DirectionRatios(); + gp_Dir aYDir(aCoords->Value(1), aCoords->Value(2), aCoords->Value(3)); + aPlaneAxes.SetDirection(aXDir.Crossed(aYDir)); + aPlaneAxes.SetYDirection(aYDir); + //set location of the annotation plane + Handle(TColStd_HArray1OfReal) aLocCoords; + Handle(StepGeom_CartesianPoint) aLoc = aA2P3D->Location(); + gp_Pnt aLocPos( aLoc->CoordinatesValue (1), aLoc->CoordinatesValue (2), aLoc->CoordinatesValue (3)); + aPlaneAxes.SetLocation(aLocPos); + isHasPlane = Standard_True; + } + } + } + + // set plane axes to XCAF + if (isHasPlane) { + if (theDimObject->IsKind(STANDARD_TYPE(XCAFDimTolObjects_DimensionObject))) { + Handle(XCAFDimTolObjects_DimensionObject) anObj = + Handle(XCAFDimTolObjects_DimensionObject)::DownCast(theDimObject); + + Handle(TColgp_HArray1OfPnt) aPnts = new TColgp_HArray1OfPnt(1, 1); + anObj->SetPlane(aPlaneAxes); + + + } + else if (theDimObject->IsKind(STANDARD_TYPE(XCAFDimTolObjects_DatumObject))) { + Handle(XCAFDimTolObjects_DatumObject) anObj = + Handle(XCAFDimTolObjects_DatumObject)::DownCast(theDimObject); + anObj->SetPlane(aPlaneAxes); + + } + else if (theDimObject->IsKind(STANDARD_TYPE(XCAFDimTolObjects_GeomToleranceObject))) { + Handle(XCAFDimTolObjects_GeomToleranceObject) anObj = + Handle(XCAFDimTolObjects_GeomToleranceObject)::DownCast(theDimObject); + anObj->SetPlane(aPlaneAxes); + + } + } + + + // Retrieve presentation + Handle(StepVisual_AnnotationCurveOccurrence) anACO; + NCollection_Vector aTesselations; + NCollection_Vector anAnnotations; + if (aDMIAE->IsKind(STANDARD_TYPE(StepVisual_AnnotationCurveOccurrence))) + { + anACO = Handle(StepVisual_AnnotationCurveOccurrence)::DownCast(aDMIAE); + if( !anACO.IsNull()) + anAnnotations.Append(anACO); + } + + else if (aDMIAE->IsKind(STANDARD_TYPE(StepVisual_DraughtingCallout))) + { + Handle(StepVisual_DraughtingCallout) aDCallout = + Handle(StepVisual_DraughtingCallout)::DownCast(aDMIAE); + for (Standard_Integer i = 1; i <= aDCallout->NbContents() && anACO.IsNull(); i++) { + anACO = aDCallout->ContentsValue(i).AnnotationCurveOccurrence(); + if(!anACO.IsNull()) + { + anAnnotations.Append(anACO); + continue; + } + Handle(StepVisual_TessellatedAnnotationOccurrence) aTesselation = + aDCallout->ContentsValue(i).TessellatedAnnotationOccurrence(); + if( !aTesselation.IsNull()) + anAnnotations.Append(aTesselation); + } + } + + if (!anAnnotations.Length()) + return; + + + BRep_Builder aB; + aB.MakeCompound(aResAnnotation); + + Standard_Integer i =0; + Bnd_Box aBox; + Standard_Integer nbShapes =0; + for( ; i < anAnnotations.Length(); i++) + { + Handle(StepVisual_StyledItem) anItem = anAnnotations(i); + + aPresentName = anItem->Name(); + + anACO = Handle(StepVisual_AnnotationCurveOccurrence)::DownCast(anItem); + TopoDS_Shape anAnnotationShape; + if(!anACO.IsNull()) + { + Handle(StepRepr_RepresentationItem) aCurveItem = anACO->Item(); + anAnnotationShape = STEPConstruct::FindShape (aTP,aCurveItem); + if( anAnnotationShape.IsNull()) + { + Handle(Transfer_Binder) binder = theTR->Actor()->Transfer(aCurveItem, aTP); + if ( ! binder.IsNull() && binder->HasResult() ) { + anAnnotationShape = TransferBRep::ShapeResult ( aTP, binder ); + } + } + } + //case of tesselated entities + else + { + Handle(StepRepr_RepresentationItem) aTessItem = anItem->Item(); + if(aTessItem.IsNull()) + continue; + Handle(StepVisual_TessellatedGeometricSet) aTessSet = Handle(StepVisual_TessellatedGeometricSet)::DownCast(aTessItem); + if( aTessSet.IsNull()) + continue; + NCollection_Handle aListItems = aTessSet->Items(); + Standard_Integer nb = aListItems.IsNull() ? 0 : aListItems->Length(); + Handle(StepVisual_TessellatedCurveSet) aTessCurve; + for (Standard_Integer n = 1; n <= nb && aTessCurve.IsNull(); n++) + { + aTessCurve = Handle(StepVisual_TessellatedCurveSet)::DownCast(aListItems->Value(n)); + } + if( aTessCurve.IsNull()) + continue; + Handle(StepVisual_CoordinatesList) aCoordList = aTessCurve->CoordList(); + if( aCoordList.IsNull()) + continue; + Handle(TColgp_HArray1OfXYZ) aPoints = aCoordList->Points(); + + if (aPoints.IsNull() || aPoints->Length() == 0) + continue; + NCollection_Handle aCurves = aTessCurve->Curves(); + Standard_Integer aNbC = (aCurves.IsNull() ? 0 : aCurves->Length()); + TopoDS_Compound aComp; + aB.MakeCompound(aComp); + + Standard_Integer k = 0; + for( ; k < aNbC; k++) + { + Handle(TColStd_HSequenceOfInteger) anIndexes = aCurves->Value(k); + TopoDS_Wire aCurW; + aB.MakeWire(aCurW); + + for(Standard_Integer n = 1; n < anIndexes->Length(); n++) + { + Standard_Integer ind = anIndexes->Value(n); + Standard_Integer indnext = anIndexes->Value(n + 1); + if( ind > aPoints->Length() || indnext > aPoints->Length()) + continue; + gp_Pnt aP1(aPoints->Value(ind)); + gp_Pnt aP2(aPoints->Value(indnext)); + BRepBuilderAPI_MakeEdge aMaker(aP1, aP2); + if( aMaker.IsDone()) + { + TopoDS_Edge aCurE = aMaker.Edge(); + aB.Add(aCurW, aCurE); + } + } + aB.Add(aComp, aCurW); + } + anAnnotationShape = aComp; + } + if(!anAnnotationShape.IsNull()) + { + nbShapes++; + aB.Add(aResAnnotation, anAnnotationShape); + if( i == anAnnotations.Length() - 1) + BRepBndLib::AddClose(anAnnotationShape, aBox); + } + } + + if(!nbShapes) + return; + gp_Pnt aPtext(0., 0., 0.); + if(!aBox.IsVoid()) + { + Standard_Real aXmin, aYmin, aZmin,aXmax, aYmax, aZmax; + aBox.Get(aXmin, aYmin, aZmin,aXmax, aYmax, aZmax); + aPtext = gp_Pnt((aXmin + aXmax) * 0.5, (aYmin + aYmax) * 0.5, (aZmin + aZmax) * 0.5); + } + + // set point to XCAF + if (theDimObject->IsKind(STANDARD_TYPE(XCAFDimTolObjects_DimensionObject))) { + Handle(XCAFDimTolObjects_DimensionObject) anObj = + Handle(XCAFDimTolObjects_DimensionObject)::DownCast(theDimObject); + anObj->SetPointTextAttach(aPtext); + anObj->SetPresentation(aResAnnotation, aPresentName); + } + else if (theDimObject->IsKind(STANDARD_TYPE(XCAFDimTolObjects_DatumObject))) { + Handle(XCAFDimTolObjects_DatumObject) anObj = + Handle(XCAFDimTolObjects_DatumObject)::DownCast(theDimObject); + anObj->SetPointTextAttach(aPtext); + anObj->SetPresentation(aResAnnotation, aPresentName); + } + else if (theDimObject->IsKind(STANDARD_TYPE(XCAFDimTolObjects_GeomToleranceObject))) { + Handle(XCAFDimTolObjects_GeomToleranceObject) anObj = + Handle(XCAFDimTolObjects_GeomToleranceObject)::DownCast(theDimObject); + anObj->SetPointTextAttach(aPtext); + anObj->SetPresentation(aResAnnotation, aPresentName); + } + return; +} //======================================================================= //function : ReadDatums @@ -1699,7 +1981,7 @@ static Standard_Boolean GetMassConversionFactor(Handle(StepBasic_NamedUnit)& NU, static Standard_Boolean ReadDatums(const Handle(XCAFDoc_ShapeTool) &STool, const Handle(XCAFDoc_DimTolTool) &DGTTool, const Interface_Graph &graph, - Handle(Transfer_TransientProcess) &TP, + const Handle(Transfer_TransientProcess) &TP, const TDF_Label TolerL, const Handle(StepDimTol_GeometricToleranceWithDatumReference) GTWDR) { @@ -1982,8 +2264,10 @@ static Standard_Boolean setDatumToXCAF(const Handle(StepDimTol_Datum)& theDat, aDatObj->SetModifierWithValue(aXCAFModifWithVal, aModifValue); aDGTTool->SetDatumToGeomTol(aDatL, theGDTL); } - if(!aDatObj.IsNull()) + if(!aDatObj.IsNull()) { + readAnnotation(aTR, aSAR->RelatingShapeAspect(), aDatObj); aDat->SetObject(aDatObj); + } } return !aDat.IsNull(); } @@ -2942,11 +3226,15 @@ static void setDimObjectToXCAF(const Handle(Standard_Transient)& theEnt, } aDimObj->SetType(aType); + if(!aDimObj.IsNull()) { + Handle(XCAFDoc_Dimension) aDim; + if(aDimL.FindAttribute(XCAFDoc_Dimension::GetID(),aDim)) { + readAnnotation(aTR, theEnt, aDimObj); aDim->SetObject(aDimObj); } } @@ -3211,7 +3499,8 @@ static void setGeomTolObjectToXCAF(const Handle(Standard_Transient)& theEnt, if(GetAngleConversionFactor(NU,aFact)) aVal=aVal*aFact; aTolObj->SetMaxValueModifier(aVal); } - + + readAnnotation(aTR, theEnt, aTolObj); aGTol->SetObject(aTolObj); } diff --git a/src/StepAP214/StepAP214_Protocol.cxx b/src/StepAP214/StepAP214_Protocol.cxx index 28e8560439..fc9830cfb5 100644 --- a/src/StepAP214/StepAP214_Protocol.cxx +++ b/src/StepAP214/StepAP214_Protocol.cxx @@ -725,10 +725,20 @@ static Standard_CString schemaAP203 = "CONFIG_CONTROL_DESIGN"; #include #include #include +#include #include #include +#include +#include +#include +#include +#include +#include +#include +#include + static int init = 0; static Interface_DataMapOfTransientInteger types(800); @@ -745,7 +755,7 @@ StepAP214_Protocol::StepAP214_Protocol () types.Bind (STANDARD_TYPE(StepBasic_Address), 1); types.Bind (STANDARD_TYPE(StepShape_AdvancedBrepShapeRepresentation), 2); types.Bind (STANDARD_TYPE(StepShape_AdvancedFace), 3); -// types.Bind (STANDARD_TYPE(StepVisual_AnnotationCurveOccurrence), 4); + types.Bind (STANDARD_TYPE(StepVisual_AnnotationCurveOccurrence), 4); // types.Bind (STANDARD_TYPE(StepVisual_AnnotationFillArea), 5); // types.Bind (STANDARD_TYPE(StepVisual_AnnotationFillAreaOccurrence), 6); types.Bind (STANDARD_TYPE(StepVisual_AnnotationOccurrence), 7); @@ -845,7 +855,7 @@ StepAP214_Protocol::StepAP214_Protocol () types.Bind (STANDARD_TYPE(StepBasic_DimensionalExponents), 104); types.Bind (STANDARD_TYPE(StepGeom_Direction), 105); types.Bind (STANDARD_TYPE(StepVisual_DraughtingAnnotationOccurrence), 106); -// types.Bind (STANDARD_TYPE(StepVisual_DraughtingCallout), 107); + types.Bind (STANDARD_TYPE(StepVisual_DraughtingCallout), 107); types.Bind (STANDARD_TYPE(StepVisual_DraughtingPreDefinedColour), 108); types.Bind (STANDARD_TYPE(StepVisual_DraughtingPreDefinedCurveFont), 109); // types.Bind (STANDARD_TYPE(StepVisual_DraughtingSubfigureRepresentation), 110); @@ -1417,10 +1427,21 @@ StepAP214_Protocol::StepAP214_Protocol () types.Bind (STANDARD_TYPE(StepRepr_IntegerRepresentationItem), 700); types.Bind (STANDARD_TYPE(StepRepr_ValueRepresentationItem), 701); types.Bind (STANDARD_TYPE(StepRepr_FeatureForDatumTargetRelationship), 702); + types.Bind (STANDARD_TYPE(StepAP242_DraughtingModelItemAssociation), 703); + types.Bind (STANDARD_TYPE(StepVisual_AnnotationPlane), 704); types.Bind (STANDARD_TYPE(StepDimTol_GeoTolAndGeoTolWthDatRefAndGeoTolWthMaxTol), 705); types.Bind (STANDARD_TYPE(StepDimTol_GeoTolAndGeoTolWthMaxTol), 706); + //AP242 tesselated + types.Bind (STANDARD_TYPE(StepVisual_TessellatedAnnotationOccurrence), 707); + types.Bind (STANDARD_TYPE(StepVisual_TessellatedItem), 708); + types.Bind (STANDARD_TYPE(StepVisual_TessellatedGeometricSet), 709); + types.Bind (STANDARD_TYPE(StepVisual_TessellatedCurveSet), 710); + + types.Bind (STANDARD_TYPE(StepVisual_CoordinatesList), 711); } + + //======================================================================= //function : TypeNumber //purpose : diff --git a/src/StepAP242/FILES b/src/StepAP242/FILES index fafc0face4..9a10cbbc30 100644 --- a/src/StepAP242/FILES +++ b/src/StepAP242/FILES @@ -1,3 +1,5 @@ +StepAP242_DraughtingModelItemAssociation.cxx +StepAP242_DraughtingModelItemAssociation.hxx StepAP242_GeometricItemSpecificUsage.cxx StepAP242_GeometricItemSpecificUsage.hxx StepAP242_IdAttribute.cxx diff --git a/src/StepAP242/StepAP242_DraughtingModelItemAssociation.cxx b/src/StepAP242/StepAP242_DraughtingModelItemAssociation.cxx new file mode 100644 index 0000000000..582378e5aa --- /dev/null +++ b/src/StepAP242/StepAP242_DraughtingModelItemAssociation.cxx @@ -0,0 +1,20 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include + +IMPLEMENT_STANDARD_RTTIEXT(StepAP242_DraughtingModelItemAssociation,StepAP242_ItemIdentifiedRepresentationUsage) + +StepAP242_DraughtingModelItemAssociation::StepAP242_DraughtingModelItemAssociation () { } diff --git a/src/StepAP242/StepAP242_DraughtingModelItemAssociation.hxx b/src/StepAP242/StepAP242_DraughtingModelItemAssociation.hxx new file mode 100644 index 0000000000..5e13b661ad --- /dev/null +++ b/src/StepAP242/StepAP242_DraughtingModelItemAssociation.hxx @@ -0,0 +1,37 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepAP242_DraughtingModelItemAssociation_HeaderFile +#define _StepAP242_DraughtingModelItemAssociation_HeaderFile + +#include +#include + +#include + +class StepAP242_DraughtingModelItemAssociation; +DEFINE_STANDARD_HANDLE(StepAP242_DraughtingModelItemAssociation, StepAP242_ItemIdentifiedRepresentationUsage) +//! Added for Dimensional Tolerances +class StepAP242_DraughtingModelItemAssociation : public StepAP242_ItemIdentifiedRepresentationUsage +{ + +public: + + Standard_EXPORT StepAP242_DraughtingModelItemAssociation(); + + DEFINE_STANDARD_RTTIEXT(StepAP242_DraughtingModelItemAssociation, StepAP242_ItemIdentifiedRepresentationUsage) + +}; +#endif // _StepAP242_DraughtingModelItemAssociation_HeaderFile diff --git a/src/StepDimTol/StepDimTol_ToleranceZone.hxx b/src/StepDimTol/StepDimTol_ToleranceZone.hxx index 49ddde966a..37f796136b 100644 --- a/src/StepDimTol/StepDimTol_ToleranceZone.hxx +++ b/src/StepDimTol/StepDimTol_ToleranceZone.hxx @@ -55,7 +55,7 @@ public: } //! Set field DefiningTolerance - inline void SetModifiers (const Handle(StepDimTol_HArray1OfToleranceZoneTarget) &theDefiningTolerance) + inline void SetDefiningTolerance (const Handle(StepDimTol_HArray1OfToleranceZoneTarget) &theDefiningTolerance) { myDefiningTolerance = theDefiningTolerance; } diff --git a/src/StepVisual/FILES b/src/StepVisual/FILES index 042a91b104..7368423c57 100644 --- a/src/StepVisual/FILES +++ b/src/StepVisual/FILES @@ -1,5 +1,11 @@ +StepVisual_AnnotationCurveOccurrence.cxx +StepVisual_AnnotationCurveOccurrence.hxx StepVisual_AnnotationOccurrence.cxx StepVisual_AnnotationOccurrence.hxx +StepVisual_AnnotationPlane.cxx +StepVisual_AnnotationPlane.hxx +StepVisual_AnnotationPlaneElement.cxx +StepVisual_AnnotationPlaneElement.hxx StepVisual_AnnotationText.cxx StepVisual_AnnotationText.hxx StepVisual_AnnotationTextOccurrence.cxx @@ -8,9 +14,11 @@ StepVisual_AreaInSet.cxx StepVisual_AreaInSet.hxx StepVisual_AreaOrView.cxx StepVisual_AreaOrView.hxx +StepVisual_Array1OfAnnotationPlaneElement.hxx StepVisual_Array1OfBoxCharacteristicSelect.hxx StepVisual_Array1OfCurveStyleFontPattern.hxx StepVisual_Array1OfDirectionCountSelect.hxx +StepVisual_Array1OfDraughtingCalloutElement.hxx StepVisual_Array1OfFillStyleSelect.hxx StepVisual_Array1OfInvisibleItem.hxx StepVisual_Array1OfLayeredItem.hxx @@ -64,6 +72,10 @@ StepVisual_DirectionCountSelect.cxx StepVisual_DirectionCountSelect.hxx StepVisual_DraughtingAnnotationOccurrence.cxx StepVisual_DraughtingAnnotationOccurrence.hxx +StepVisual_DraughtingCallout.cxx +StepVisual_DraughtingCallout.hxx +StepVisual_DraughtingCalloutElement.cxx +StepVisual_DraughtingCalloutElement.hxx StepVisual_DraughtingModel.cxx StepVisual_DraughtingModel.hxx StepVisual_DraughtingPreDefinedColour.cxx @@ -82,9 +94,11 @@ StepVisual_FillStyleSelect.cxx StepVisual_FillStyleSelect.hxx StepVisual_FontSelect.cxx StepVisual_FontSelect.hxx +StepVisual_HArray1OfAnnotationPlaneElement.hxx StepVisual_HArray1OfBoxCharacteristicSelect.hxx StepVisual_HArray1OfCurveStyleFontPattern.hxx StepVisual_HArray1OfDirectionCountSelect.hxx +StepVisual_HArray1OfDraughtingCalloutElement.hxx StepVisual_HArray1OfFillStyleSelect.hxx StepVisual_HArray1OfInvisibleItem.hxx StepVisual_HArray1OfLayeredItem.hxx @@ -194,3 +208,13 @@ StepVisual_TextStyleWithBoxCharacteristics.cxx StepVisual_TextStyleWithBoxCharacteristics.hxx StepVisual_ViewVolume.cxx StepVisual_ViewVolume.hxx +StepVisual_TessellatedAnnotationOccurrence.hxx +StepVisual_TessellatedAnnotationOccurrence.cxx +StepVisual_TessellatedItem.hxx +StepVisual_TessellatedItem.cxx +StepVisual_TessellatedGeometricSet.hxx +StepVisual_TessellatedGeometricSet.cxx +StepVisual_TessellatedCurveSet.hxx +StepVisual_TessellatedCurveSet.cxx +StepVisual_CoordinatesList.hxx +StepVisual_CoordinatesList.cxx diff --git a/src/StepVisual/StepVisual_AnnotationCurveOccurrence.cxx b/src/StepVisual/StepVisual_AnnotationCurveOccurrence.cxx new file mode 100644 index 0000000000..79428a82ad --- /dev/null +++ b/src/StepVisual/StepVisual_AnnotationCurveOccurrence.cxx @@ -0,0 +1,21 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include + +IMPLEMENT_STANDARD_RTTIEXT(StepVisual_AnnotationCurveOccurrence,StepVisual_StyledItem) + +StepVisual_AnnotationCurveOccurrence::StepVisual_AnnotationCurveOccurrence () {} diff --git a/src/StepVisual/StepVisual_AnnotationCurveOccurrence.hxx b/src/StepVisual/StepVisual_AnnotationCurveOccurrence.hxx new file mode 100644 index 0000000000..3223156076 --- /dev/null +++ b/src/StepVisual/StepVisual_AnnotationCurveOccurrence.hxx @@ -0,0 +1,36 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_AnnotationCurveOccurrence_HeaderFile +#define _StepVisual_AnnotationCurveOccurrence_HeaderFile + +#include +#include + +#include + +class StepVisual_AnnotationCurveOccurrence; +DEFINE_STANDARD_HANDLE(StepVisual_AnnotationCurveOccurrence, StepVisual_StyledItem) + +class StepVisual_AnnotationCurveOccurrence : public StepVisual_StyledItem +{ +public: + + //! Returns a AnnotationCurveOccurrence + Standard_EXPORT StepVisual_AnnotationCurveOccurrence(); + + DEFINE_STANDARD_RTTIEXT(StepVisual_AnnotationCurveOccurrence,StepVisual_StyledItem) +}; +#endif // _StepVisual_AnnotationCurveOccurrence_HeaderFile diff --git a/src/StepVisual/StepVisual_AnnotationOccurrence.cxx b/src/StepVisual/StepVisual_AnnotationOccurrence.cxx index 6ac10ae417..449feb997b 100644 --- a/src/StepVisual/StepVisual_AnnotationOccurrence.cxx +++ b/src/StepVisual/StepVisual_AnnotationOccurrence.cxx @@ -19,3 +19,5 @@ IMPLEMENT_STANDARD_RTTIEXT(StepVisual_AnnotationOccurrence,StepVisual_StyledItem StepVisual_AnnotationOccurrence::StepVisual_AnnotationOccurrence () {} + + diff --git a/src/StepVisual/StepVisual_AnnotationOccurrence.hxx b/src/StepVisual/StepVisual_AnnotationOccurrence.hxx index ce1b8a693b..6565d1818d 100644 --- a/src/StepVisual/StepVisual_AnnotationOccurrence.hxx +++ b/src/StepVisual/StepVisual_AnnotationOccurrence.hxx @@ -38,7 +38,6 @@ public: - DEFINE_STANDARD_RTTIEXT(StepVisual_AnnotationOccurrence,StepVisual_StyledItem) protected: diff --git a/src/StepVisual/StepVisual_AnnotationPlane.cxx b/src/StepVisual/StepVisual_AnnotationPlane.cxx new file mode 100644 index 0000000000..65e9245d66 --- /dev/null +++ b/src/StepVisual/StepVisual_AnnotationPlane.cxx @@ -0,0 +1,38 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include + +IMPLEMENT_STANDARD_RTTIEXT(StepVisual_AnnotationPlane,StepVisual_AnnotationOccurrence) + +//======================================================================= +//function : StepVisual_AnnotationPlane +//purpose : +//======================================================================= +StepVisual_AnnotationPlane::StepVisual_AnnotationPlane () {} + +//======================================================================= +//function : Init +//purpose : +//======================================================================= +void StepVisual_AnnotationPlane::Init (const Handle(TCollection_HAsciiString)& theName, + const Handle(StepVisual_HArray1OfPresentationStyleAssignment)& theStyles, + const Handle(StepRepr_RepresentationItem)& theItem, + const Handle(StepVisual_HArray1OfAnnotationPlaneElement)& theElements) +{ + StepVisual_AnnotationOccurrence::Init(theName, theStyles, theItem); + myElements = theElements; +} diff --git a/src/StepVisual/StepVisual_AnnotationPlane.hxx b/src/StepVisual/StepVisual_AnnotationPlane.hxx new file mode 100644 index 0000000000..b969509fd6 --- /dev/null +++ b/src/StepVisual/StepVisual_AnnotationPlane.hxx @@ -0,0 +1,76 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_AnnotationPlane_HeaderFile +#define _StepVisual_AnnotationPlane_HeaderFile + +#include +#include + +#include +#include + +class StepVisual_AnnotationPlane; +DEFINE_STANDARD_HANDLE(StepVisual_AnnotationPlane, StepVisual_AnnotationOccurrence) + +class StepVisual_AnnotationPlane : public StepVisual_AnnotationOccurrence +{ +public: + + //! Returns a AnnotationPlane + Standard_EXPORT StepVisual_AnnotationPlane(); + + Standard_EXPORT void Init (const Handle(TCollection_HAsciiString)& theName, + const Handle(StepVisual_HArray1OfPresentationStyleAssignment)& theStyles, + const Handle(StepRepr_RepresentationItem)& theItem, + const Handle(StepVisual_HArray1OfAnnotationPlaneElement)& theElements); + + //! Returns field Elements + inline Handle(StepVisual_HArray1OfAnnotationPlaneElement) Elements () const + { + return myElements; + } + + //! Set field Elements + inline void SetElements (const Handle(StepVisual_HArray1OfAnnotationPlaneElement) &theElements) + { + myElements = theElements; + } + + //! Returns number of Elements + inline Standard_Integer NbElements () const + { + return (myElements.IsNull() ? 0 : myElements->Length()); + } + + //! Returns Elements with the given number + inline StepVisual_AnnotationPlaneElement ElementsValue(const Standard_Integer theNum) const + { + return myElements->Value(theNum); + } + + //! Sets Elements with given number + inline void SetElementsValue(const Standard_Integer theNum, const StepVisual_AnnotationPlaneElement& theItem) + { + myElements->SetValue (theNum, theItem); + } + + DEFINE_STANDARD_RTTIEXT(StepVisual_AnnotationPlane,StepVisual_AnnotationOccurrence) + +private: + + Handle(StepVisual_HArray1OfAnnotationPlaneElement) myElements; +}; +#endif // _StepVisual_AnnotationPlane_HeaderFile diff --git a/src/StepVisual/StepVisual_AnnotationPlaneElement.cxx b/src/StepVisual/StepVisual_AnnotationPlaneElement.cxx new file mode 100644 index 0000000000..88bc13f6c4 --- /dev/null +++ b/src/StepVisual/StepVisual_AnnotationPlaneElement.cxx @@ -0,0 +1,45 @@ +// Created on: 2015-07-10 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include +#include +#include + +//======================================================================= +//function : StepVisual_AnnotationPlaneElement +//purpose : +//======================================================================= + +StepVisual_AnnotationPlaneElement::StepVisual_AnnotationPlaneElement () { } + +//======================================================================= +//function : CaseNum +//purpose : +//======================================================================= + +Standard_Integer StepVisual_AnnotationPlaneElement::CaseNum(const Handle(Standard_Transient)& ent) const +{ + if (ent.IsNull()) return 0; + if (ent->IsKind(STANDARD_TYPE(StepVisual_DraughtingCallout))) return 1; + if (ent->IsKind(STANDARD_TYPE(StepVisual_StyledItem))) return 2; + return 0; +} + +Handle(StepVisual_DraughtingCallout) StepVisual_AnnotationPlaneElement::DraughtingCallout() const +{ return GetCasted(StepVisual_DraughtingCallout,Value()); } + +Handle(StepVisual_StyledItem) StepVisual_AnnotationPlaneElement::StyledItem() const +{ return GetCasted(StepVisual_StyledItem,Value()); } diff --git a/src/StepVisual/StepVisual_AnnotationPlaneElement.hxx b/src/StepVisual/StepVisual_AnnotationPlaneElement.hxx new file mode 100644 index 0000000000..85c07874cb --- /dev/null +++ b/src/StepVisual/StepVisual_AnnotationPlaneElement.hxx @@ -0,0 +1,50 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_AnnotationPlaneElement_HeaderFile +#define _StepVisual_AnnotationPlaneElement_HeaderFile + +#include +#include +#include + +#include +#include +class Standard_Transient; +class StepVisual_DraughtingCallout; +class StepVisual_StyledItem; + +class StepVisual_AnnotationPlaneElement : public StepData_SelectType +{ +public: + + DEFINE_STANDARD_ALLOC + + //! Returns a AnnotationPlaneElement select type + Standard_EXPORT StepVisual_AnnotationPlaneElement(); + + //! Recognizes a IdAttributeSelect Kind Entity that is : + //! 1 -> DraughtingCallout + //! 2 -> StyledItem + //! 0 else + Standard_EXPORT Standard_Integer CaseNum (const Handle(Standard_Transient)& ent) const; + + //! returns Value as a DraughtingCallout (Null if another type) + Standard_EXPORT Handle(StepVisual_DraughtingCallout) DraughtingCallout() const; + + //! returns Value as a StyledItem (Null if another type) + Standard_EXPORT Handle(StepVisual_StyledItem) StyledItem() const; +}; +#endif // StepVisual_AnnotationPlaneElement diff --git a/src/StepVisual/StepVisual_Array1OfAnnotationPlaneElement.hxx b/src/StepVisual/StepVisual_Array1OfAnnotationPlaneElement.hxx new file mode 100644 index 0000000000..a45ad6c400 --- /dev/null +++ b/src/StepVisual/StepVisual_Array1OfAnnotationPlaneElement.hxx @@ -0,0 +1,23 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_Array1OfAnnotationPlaneElement_HeaderFile +#define _StepVisual_Array1OfAnnotationPlaneElement_HeaderFile + +#include +#include + +typedef NCollection_Array1 StepVisual_Array1OfAnnotationPlaneElement; +#endif // _StepVisual_Array1OfAnnotationPlaneElement_HeaderFile diff --git a/src/StepVisual/StepVisual_Array1OfDraughtingCalloutElement.hxx b/src/StepVisual/StepVisual_Array1OfDraughtingCalloutElement.hxx new file mode 100644 index 0000000000..8486478c7c --- /dev/null +++ b/src/StepVisual/StepVisual_Array1OfDraughtingCalloutElement.hxx @@ -0,0 +1,23 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_Array1OfDraughtingCalloutElement_HeaderFile +#define _StepVisual_Array1OfDraughtingCalloutElement_HeaderFile + +#include +#include + +typedef NCollection_Array1 StepVisual_Array1OfDraughtingCalloutElement; +#endif // _StepVisual_Array1OfDraughtingCalloutElement_HeaderFile diff --git a/src/StepVisual/StepVisual_CoordinatesList.cxx b/src/StepVisual/StepVisual_CoordinatesList.cxx new file mode 100644 index 0000000000..c339d8d3c6 --- /dev/null +++ b/src/StepVisual/StepVisual_CoordinatesList.cxx @@ -0,0 +1,31 @@ +// Copyright (c) 1999-2014 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include +IMPLEMENT_STANDARD_RTTIEXT(StepVisual_CoordinatesList,StepGeom_TessellatedItem) + +StepVisual_CoordinatesList::StepVisual_CoordinatesList () {} + +void StepVisual_CoordinatesList::Init(const Handle(TCollection_HAsciiString)& theName,const Handle(TColgp_HArray1OfXYZ)& thePoints) +{ + StepRepr_RepresentationItem::Init(theName); + myPoints = thePoints; +} + +Handle(TColgp_HArray1OfXYZ) StepVisual_CoordinatesList::Points() const +{ + return myPoints; +} diff --git a/src/StepVisual/StepVisual_CoordinatesList.hxx b/src/StepVisual/StepVisual_CoordinatesList.hxx new file mode 100644 index 0000000000..386eb132eb --- /dev/null +++ b/src/StepVisual/StepVisual_CoordinatesList.hxx @@ -0,0 +1,45 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_CoordinatesList_HeaderFile +#define _StepVisual_CoordinatesList_HeaderFile +#include +#include +#include +#include +#include +class Standard_Transient; + +DEFINE_STANDARD_HANDLE(StepVisual_CoordinatesList,StepVisual_TessellatedItem) +class StepVisual_CoordinatesList : public StepVisual_TessellatedItem +{ +public: + + DEFINE_STANDARD_ALLOC + + //! Returns a coordinate list + Standard_EXPORT StepVisual_CoordinatesList(); + + Standard_EXPORT void Init(const Handle(TCollection_HAsciiString)& theName, const Handle(TColgp_HArray1OfXYZ)& thePoints); + + Standard_EXPORT Handle(TColgp_HArray1OfXYZ) Points() const; + + DEFINE_STANDARD_RTTIEXT(StepVisual_CoordinatesList,StepVisual_TessellatedItem); + +private: + + Handle(TColgp_HArray1OfXYZ) myPoints; +}; +#endif // StepVisual_CoordinatesList diff --git a/src/StepVisual/StepVisual_DraughtingCallout.cxx b/src/StepVisual/StepVisual_DraughtingCallout.cxx new file mode 100644 index 0000000000..78af2e3d61 --- /dev/null +++ b/src/StepVisual/StepVisual_DraughtingCallout.cxx @@ -0,0 +1,36 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include + +IMPLEMENT_STANDARD_RTTIEXT(StepVisual_DraughtingCallout,StepGeom_GeometricRepresentationItem) + +//======================================================================= +//function : StepVisual_DraughtingCallout +//purpose : +//======================================================================= +StepVisual_DraughtingCallout::StepVisual_DraughtingCallout () {} + +//======================================================================= +//function : Init +//purpose : +//======================================================================= +void StepVisual_DraughtingCallout::Init (const Handle(TCollection_HAsciiString)& theName, + const Handle(StepVisual_HArray1OfDraughtingCalloutElement)& theContents) +{ + StepGeom_GeometricRepresentationItem::Init(theName); + myContents = theContents; +} diff --git a/src/StepVisual/StepVisual_DraughtingCallout.hxx b/src/StepVisual/StepVisual_DraughtingCallout.hxx new file mode 100644 index 0000000000..ef39ef48a2 --- /dev/null +++ b/src/StepVisual/StepVisual_DraughtingCallout.hxx @@ -0,0 +1,77 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_DraughtingCallout_HeaderFile +#define _StepVisual_DraughtingCallout_HeaderFile + +#include +#include + +#include +#include + + +class StepVisual_DraughtingCallout; +DEFINE_STANDARD_HANDLE(StepVisual_DraughtingCallout, StepGeom_GeometricRepresentationItem) + + +class StepVisual_DraughtingCallout : public StepGeom_GeometricRepresentationItem +{ +public: + + //! Returns a DraughtingCallout + Standard_EXPORT StepVisual_DraughtingCallout(); + + //! Init + Standard_EXPORT void Init (const Handle(TCollection_HAsciiString)& theName, + const Handle(StepVisual_HArray1OfDraughtingCalloutElement)& theContents); + + //! Returns field Contents + inline Handle(StepVisual_HArray1OfDraughtingCalloutElement) Contents () const + { + return myContents; + } + + //! Set field Contents + inline void SetContents (const Handle(StepVisual_HArray1OfDraughtingCalloutElement) &theContents) + { + myContents = theContents; + } + + //! Returns number of Contents + inline Standard_Integer NbContents () const + { + return (myContents.IsNull() ? 0 : myContents->Length()); + } + + //! Returns Contents with the given number + inline StepVisual_DraughtingCalloutElement ContentsValue(const Standard_Integer theNum) const + { + return myContents->Value(theNum); + } + + //! Sets Contents with given number + inline void SetContentsValue(const Standard_Integer theNum, const StepVisual_DraughtingCalloutElement& theItem) + { + myContents->SetValue (theNum, theItem); + } + + + DEFINE_STANDARD_RTTIEXT(StepVisual_DraughtingCallout,StepGeom_GeometricRepresentationItem) + +private: + Handle(StepVisual_HArray1OfDraughtingCalloutElement) myContents; +}; +#endif // _StepVisual_DraughtingCallout_HeaderFile diff --git a/src/StepVisual/StepVisual_DraughtingCalloutElement.cxx b/src/StepVisual/StepVisual_DraughtingCalloutElement.cxx new file mode 100644 index 0000000000..829b514e1f --- /dev/null +++ b/src/StepVisual/StepVisual_DraughtingCalloutElement.cxx @@ -0,0 +1,49 @@ +// Created on: 2015-07-10 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include +#include + +#include + +//======================================================================= +//function : StepVisual_DraughtingCalloutElement +//purpose : +//======================================================================= + +StepVisual_DraughtingCalloutElement::StepVisual_DraughtingCalloutElement () { } + +//======================================================================= +//function : CaseNum +//purpose : +//======================================================================= + +Standard_Integer StepVisual_DraughtingCalloutElement::CaseNum(const Handle(Standard_Transient)& ent) const +{ + if (ent.IsNull()) return 0; + if (ent->IsKind(STANDARD_TYPE(StepVisual_AnnotationCurveOccurrence))) return 1; + else if (ent->IsKind(STANDARD_TYPE(StepVisual_TessellatedAnnotationOccurrence))) return 2; + return 0; +} + +Handle(StepVisual_AnnotationCurveOccurrence) StepVisual_DraughtingCalloutElement::AnnotationCurveOccurrence() const +{ return GetCasted(StepVisual_AnnotationCurveOccurrence,Value()); } + + + +Handle(StepVisual_TessellatedAnnotationOccurrence) StepVisual_DraughtingCalloutElement::TessellatedAnnotationOccurrence() const +{ return GetCasted(StepVisual_TessellatedAnnotationOccurrence,Value()); } + diff --git a/src/StepVisual/StepVisual_DraughtingCalloutElement.hxx b/src/StepVisual/StepVisual_DraughtingCalloutElement.hxx new file mode 100644 index 0000000000..772c9ad050 --- /dev/null +++ b/src/StepVisual/StepVisual_DraughtingCalloutElement.hxx @@ -0,0 +1,49 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_DraughtingCalloutElement_HeaderFile +#define _StepVisual_DraughtingCalloutElement_HeaderFile + +#include +#include +#include + +#include +#include +class Standard_Transient; +class StepVisual_AnnotationCurveOccurrence; +class StepVisual_TessellatedAnnotationOccurrence; + +class StepVisual_DraughtingCalloutElement : public StepData_SelectType +{ +public: + + DEFINE_STANDARD_ALLOC + + //! Returns a DraughtingCalloutElement select type + Standard_EXPORT StepVisual_DraughtingCalloutElement(); + + //! Recognizes a IdAttributeSelect Kind Entity that is : + //! 1 -> AnnotationCurveOccurrence + //! 0 else + Standard_EXPORT Standard_Integer CaseNum (const Handle(Standard_Transient)& ent) const; + + //! returns Value as a AnnotationCurveOccurrence (Null if another type) + Standard_EXPORT Handle(StepVisual_AnnotationCurveOccurrence) AnnotationCurveOccurrence() const; + + //! returns Value as a AnnotationOccurrence for Tesselated Anotation Occurence + Standard_EXPORT Handle(StepVisual_TessellatedAnnotationOccurrence) TessellatedAnnotationOccurrence() const; +}; +#endif // StepVisual_DraughtingCalloutElement diff --git a/src/StepVisual/StepVisual_HArray1OfAnnotationPlaneElement.hxx b/src/StepVisual/StepVisual_HArray1OfAnnotationPlaneElement.hxx new file mode 100644 index 0000000000..543bff2d45 --- /dev/null +++ b/src/StepVisual/StepVisual_HArray1OfAnnotationPlaneElement.hxx @@ -0,0 +1,24 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_HArray1OfAnnotationPlaneElement_HeaderFile +#define _StepVisual_HArray1OfAnnotationPlaneElement_HeaderFile + +#include +#include +#include + +DEFINE_HARRAY1(StepVisual_HArray1OfAnnotationPlaneElement, StepVisual_Array1OfAnnotationPlaneElement) +#endif // _StepVisual_HArray1OfAnnotationPlaneElement_HeaderFile diff --git a/src/StepVisual/StepVisual_HArray1OfDraughtingCalloutElement.hxx b/src/StepVisual/StepVisual_HArray1OfDraughtingCalloutElement.hxx new file mode 100644 index 0000000000..f8c23f4e07 --- /dev/null +++ b/src/StepVisual/StepVisual_HArray1OfDraughtingCalloutElement.hxx @@ -0,0 +1,24 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_HArray1OfDraughtingCalloutElement_HeaderFile +#define _StepVisual_HArray1OfDraughtingCalloutElement_HeaderFile + +#include +#include +#include + +DEFINE_HARRAY1(StepVisual_HArray1OfDraughtingCalloutElement, StepVisual_Array1OfDraughtingCalloutElement) +#endif // _StepVisual_HArray1OfDraughtingCalloutElement_HeaderFile diff --git a/src/StepVisual/StepVisual_TessellatedAnnotationOccurrence.cxx b/src/StepVisual/StepVisual_TessellatedAnnotationOccurrence.cxx new file mode 100644 index 0000000000..0435ec692a --- /dev/null +++ b/src/StepVisual/StepVisual_TessellatedAnnotationOccurrence.cxx @@ -0,0 +1,21 @@ +// Created on: 2015-10-29 +// Created by: Irina KRYLOVA +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include + +IMPLEMENT_STANDARD_RTTIEXT(StepVisual_TessellatedAnnotationOccurrence,StepVisual_StyledItem); + +StepVisual_TessellatedAnnotationOccurrence::StepVisual_TessellatedAnnotationOccurrence () {} diff --git a/src/StepVisual/StepVisual_TessellatedAnnotationOccurrence.hxx b/src/StepVisual/StepVisual_TessellatedAnnotationOccurrence.hxx new file mode 100644 index 0000000000..1656db6b14 --- /dev/null +++ b/src/StepVisual/StepVisual_TessellatedAnnotationOccurrence.hxx @@ -0,0 +1,36 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_TessellatedAnnotationOccurrence_HeaderFile +#define _StepVisual_TessellatedAnnotationOccurrence_HeaderFile + +#include +#include + +#include + +class StepVisual_TessellatedAnnotationOccurrence; +DEFINE_STANDARD_HANDLE(StepVisual_TessellatedAnnotationOccurrence, StepVisual_StyledItem) + +class StepVisual_TessellatedAnnotationOccurrence : public StepVisual_StyledItem +{ +public: + + //! Returns a TesselatedAnnotationOccurence + Standard_EXPORT StepVisual_TessellatedAnnotationOccurrence(); + + DEFINE_STANDARD_RTTIEXT(StepVisual_TessellatedAnnotationOccurrence,StepVisual_StyledItem) +}; +#endif // _StepVisual_TesselatedAnnotationOccurrence_HeaderFile diff --git a/src/StepVisual/StepVisual_TessellatedCurveSet.cxx b/src/StepVisual/StepVisual_TessellatedCurveSet.cxx new file mode 100644 index 0000000000..f6d6e25b80 --- /dev/null +++ b/src/StepVisual/StepVisual_TessellatedCurveSet.cxx @@ -0,0 +1,42 @@ +// Copyright (c) 1999-2014 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include +#include + + +IMPLEMENT_STANDARD_RTTIEXT(StepVisual_TessellatedCurveSet,StepVisual_TessellatedItem) + +StepVisual_TessellatedCurveSet::StepVisual_TessellatedCurveSet () {} + +void StepVisual_TessellatedCurveSet::Init(const Handle(TCollection_HAsciiString)& theName, + const Handle(StepVisual_CoordinatesList)& theCoordList, + const NCollection_Handle& theCurves) +{ + StepRepr_RepresentationItem::Init(theName); + myCoordList = theCoordList; + myCurves = theCurves; +} + + +NCollection_Handle StepVisual_TessellatedCurveSet::Curves() const +{ + return myCurves; +} + +Handle(StepVisual_CoordinatesList) StepVisual_TessellatedCurveSet::CoordList() const +{ + return myCoordList; +} diff --git a/src/StepVisual/StepVisual_TessellatedCurveSet.hxx b/src/StepVisual/StepVisual_TessellatedCurveSet.hxx new file mode 100644 index 0000000000..a9b28b083e --- /dev/null +++ b/src/StepVisual/StepVisual_TessellatedCurveSet.hxx @@ -0,0 +1,60 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_TessellatedCurveSet_HeaderFile +#define _StepVisual_TessellatedCurveSet_HeaderFile +#include +#include +#include +#include +#include + +#include +#include +#include +#include +class Standard_Transient; + + +typedef NCollection_Vector StepVisual_VectorOfHSequenceOfInteger; + +DEFINE_STANDARD_HANDLE(StepVisual_TessellatedCurveSet, StepVisual_TessellatedItem); + + +class StepVisual_TessellatedCurveSet : public StepVisual_TessellatedItem +{ +public: + + DEFINE_STANDARD_ALLOC + + //! Returns a DraughtingCalloutElement select type + Standard_EXPORT StepVisual_TessellatedCurveSet(); + + Standard_EXPORT void Init(const Handle(TCollection_HAsciiString)& theName, const Handle(StepVisual_CoordinatesList)& theCoordList, + const NCollection_Handle& theCurves); + + Standard_EXPORT Handle(StepVisual_CoordinatesList) CoordList() const; + Standard_EXPORT NCollection_Handle Curves() const; + + +private: + + Handle(StepVisual_CoordinatesList) myCoordList; + NCollection_Handle myCurves; + +public : + DEFINE_STANDARD_RTTIEXT(StepVisual_TessellatedCurveSet,StepVisual_TessellatedItem); +}; +#endif // StepVisual_TessellatedCurveSet diff --git a/src/StepVisual/StepVisual_TessellatedGeometricSet.cxx b/src/StepVisual/StepVisual_TessellatedGeometricSet.cxx new file mode 100644 index 0000000000..48fc26fa2c --- /dev/null +++ b/src/StepVisual/StepVisual_TessellatedGeometricSet.cxx @@ -0,0 +1,33 @@ +// Copyright (c) 1999-2014 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include + + +IMPLEMENT_STANDARD_RTTIEXT(StepVisual_TessellatedGeometricSet,StepGeom_TessellatedItem) + + +StepVisual_TessellatedGeometricSet::StepVisual_TessellatedGeometricSet () {} + +void StepVisual_TessellatedGeometricSet::Init(const Handle(TCollection_HAsciiString)& theName, const NCollection_Handle& theItems) +{ + StepRepr_RepresentationItem::Init(theName); + myItems = theItems; +} + +NCollection_Handle StepVisual_TessellatedGeometricSet::Items() const +{ + return myItems; +} diff --git a/src/StepVisual/StepVisual_TessellatedGeometricSet.hxx b/src/StepVisual/StepVisual_TessellatedGeometricSet.hxx new file mode 100644 index 0000000000..e7b98f6ef7 --- /dev/null +++ b/src/StepVisual/StepVisual_TessellatedGeometricSet.hxx @@ -0,0 +1,54 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_TessellatedGeometricSet_HeaderFile +#define _StepVisual_TessellatedGeometricSet_HeaderFile +#include +#include +#include + +#include +#include +//#include +#include + +class Standard_Transient; + +typedef NCollection_Array1 StepVisual_Array1OfTessellaltedItem; +//typedef NCollection_Handle Handle(StepVisual_Array1OfTessellaltedItem); + +//DEFINE_HARRAY1(StepVisual_HArray1OfTessellaltedItem, StepVisual_Array1OfTessellaltedItem) +DEFINE_STANDARD_HANDLE(StepVisual_TessellatedGeometricSet, StepVisual_TessellatedItem) +class StepVisual_TessellatedGeometricSet : public StepVisual_TessellatedItem +{ +public: + + DEFINE_STANDARD_ALLOC + + //! Returns a DraughtingCalloutElement select type + Standard_EXPORT StepVisual_TessellatedGeometricSet(); + + Standard_EXPORT void Init(const Handle(TCollection_HAsciiString)& theName, const NCollection_Handle& theItems); + + Standard_EXPORT NCollection_Handle Items() const; + +private: + NCollection_Handle myItems; + +public: + + DEFINE_STANDARD_RTTIEXT(StepVisual_TessellatedGeometricSet,StepVisual_TessellatedItem) +}; +#endif // StepVisual_TessellatedGeometricSet diff --git a/src/StepVisual/StepVisual_TessellatedItem.cxx b/src/StepVisual/StepVisual_TessellatedItem.cxx new file mode 100644 index 0000000000..734b9f38da --- /dev/null +++ b/src/StepVisual/StepVisual_TessellatedItem.cxx @@ -0,0 +1,20 @@ +// Copyright (c) 1999-2014 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + + +#include +#include + +IMPLEMENT_STANDARD_RTTIEXT(StepVisual_TessellatedItem,StepGeom_GeometricRepresentationItem) + +StepVisual_TessellatedItem::StepVisual_TessellatedItem () {} diff --git a/src/StepVisual/StepVisual_TessellatedItem.hxx b/src/StepVisual/StepVisual_TessellatedItem.hxx new file mode 100644 index 0000000000..81fe88d6a3 --- /dev/null +++ b/src/StepVisual/StepVisual_TessellatedItem.hxx @@ -0,0 +1,37 @@ +// Created on: 2015-10-29 +// Created by: Galina Kulikova +// Copyright (c) 2015 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _StepVisual_TessellatedItem_HeaderFile +#define _StepVisual_TessellatedItem_HeaderFile +#include +#include +#include + +#include +class Standard_Transient; + +DEFINE_STANDARD_HANDLE(StepVisual_TessellatedItem, StepGeom_GeometricRepresentationItem) +class StepVisual_TessellatedItem : public StepGeom_GeometricRepresentationItem +{ +public: + + DEFINE_STANDARD_ALLOC + + //! Returns a DraughtingCalloutElement select type + Standard_EXPORT StepVisual_TessellatedItem(); + + DEFINE_STANDARD_RTTIEXT(StepVisual_TessellatedItem,StepGeom_GeometricRepresentationItem); +}; +#endif // StepVisual_TessellatedItem diff --git a/src/TKXDESTEP/EXTERNLIB b/src/TKXDESTEP/EXTERNLIB index a2f9e0622b..b14be71922 100755 --- a/src/TKXDESTEP/EXTERNLIB +++ b/src/TKXDESTEP/EXTERNLIB @@ -3,6 +3,7 @@ TKSTEPAttr TKernel TKMath TKXSBase +TKTopAlgo TKG2d TKCAF TKSTEPBase diff --git a/src/XCAFDimTolObjects/XCAFDimTolObjects_DatumObject.cxx b/src/XCAFDimTolObjects/XCAFDimTolObjects_DatumObject.cxx index 33ba5afcc2..652334046e 100644 --- a/src/XCAFDimTolObjects/XCAFDimTolObjects_DatumObject.cxx +++ b/src/XCAFDimTolObjects/XCAFDimTolObjects_DatumObject.cxx @@ -24,6 +24,9 @@ IMPLEMENT_STANDARD_RTTIEXT(XCAFDimTolObjects_DatumObject,Standard_Transient) XCAFDimTolObjects_DatumObject::XCAFDimTolObjects_DatumObject() { myIsDTarget = Standard_False; + myHasPlane = Standard_False; + myHasPnt = Standard_False; + myHasPntText = Standard_False; } //======================================================================= @@ -41,6 +44,12 @@ XCAFDimTolObjects_DatumObject::XCAFDimTolObjects_DatumObject(const Handle(XCAFDi myIsDTarget = theObj->myIsDTarget; myAxis = theObj->myAxis; myDTargetType = theObj->myDTargetType; + myPlane = theObj->myPlane; + myPnt= theObj->myPnt; + myPntText= theObj->myPntText; + myHasPlane = theObj->myHasPlane; + myHasPnt = theObj->myHasPnt; + myHasPntText = theObj->myHasPntText; } //======================================================================= diff --git a/src/XCAFDimTolObjects/XCAFDimTolObjects_DatumObject.hxx b/src/XCAFDimTolObjects/XCAFDimTolObjects_DatumObject.hxx index e3b161499a..96266d7eb0 100644 --- a/src/XCAFDimTolObjects/XCAFDimTolObjects_DatumObject.hxx +++ b/src/XCAFDimTolObjects/XCAFDimTolObjects_DatumObject.hxx @@ -91,6 +91,67 @@ public: Standard_EXPORT void SetDatumTargetNumber (const Standard_Integer theNumber); + Standard_EXPORT void SetPlane (const gp_Ax2& thePlane) + { + myPlane = thePlane; + myHasPlane = Standard_True; + } + + Standard_EXPORT const gp_Ax2& GetPlane() const { return myPlane; } + + Standard_EXPORT void SetPoint (const gp_Pnt& thePnt) + { + myPnt = thePnt; + myHasPnt = Standard_True; + } + + Standard_EXPORT const gp_Pnt& GetPoint() const + { + return myPnt; + } + + + Standard_EXPORT void SetPointTextAttach (const gp_Pnt& thePntText) + { + myPntText = thePntText; + myHasPntText = Standard_True; + } + + Standard_EXPORT const gp_Pnt& GetPointTextAttach() const + { + return myPntText; + } + + Standard_Boolean HasPlane() const { return myHasPlane; } + + Standard_Boolean HasPoint() const { return myHasPnt; } + + Standard_EXPORT Standard_Boolean HasPointText() const + { + return myHasPntText; + } + + //! Set graphical presentation for object + Standard_EXPORT void SetPresentation(const TopoDS_Shape& thePresentation, + const Handle(TCollection_HAsciiString)& thePresentationName) + { + myPresentation = thePresentation; + myPresentationName = thePresentationName; + } + + //! Returns graphical presentation of the object + Standard_EXPORT TopoDS_Shape GetPresentation() const + { + return myPresentation; + } + + //! Returns graphical presentation of the object + Standard_EXPORT Handle(TCollection_HAsciiString) GetPresentationName() const + { + return myPresentationName; + } + + DEFINE_STANDARD_RTTIEXT(XCAFDimTolObjects_DatumObject,Standard_Transient) @@ -108,7 +169,14 @@ private: Standard_Real myLength; Standard_Real myWidth; Standard_Integer myDatumTargetNumber; - + gp_Ax2 myPlane; + gp_Pnt myPnt; + gp_Pnt myPntText; + Standard_Boolean myHasPlane; + Standard_Boolean myHasPnt; + Standard_Boolean myHasPntText; + TopoDS_Shape myPresentation; + Handle(TCollection_HAsciiString) myPresentationName; }; #endif // _XCAFDimTolObjects_DatumObject_HeaderFile diff --git a/src/XCAFDimTolObjects/XCAFDimTolObjects_DimensionObject.cxx b/src/XCAFDimTolObjects/XCAFDimTolObjects_DimensionObject.cxx index 1ff4f502b9..8a053ba738 100644 --- a/src/XCAFDimTolObjects/XCAFDimTolObjects_DimensionObject.cxx +++ b/src/XCAFDimTolObjects/XCAFDimTolObjects_DimensionObject.cxx @@ -26,6 +26,8 @@ IMPLEMENT_STANDARD_RTTIEXT(XCAFDimTolObjects_DimensionObject,Standard_Transient) XCAFDimTolObjects_DimensionObject::XCAFDimTolObjects_DimensionObject() { + myHasPlane = Standard_False; + myHasPntText = Standard_False; } //======================================================================= @@ -47,6 +49,10 @@ XCAFDimTolObjects_DimensionObject::XCAFDimTolObjects_DimensionObject(const Handl myPath = theObj->myPath; myDir = theObj->myDir; myPnts = theObj->myPnts; + myPntText= theObj->myPntText; + myHasPlane = theObj->myHasPlane; + myPlane = theObj->myPlane; + myHasPntText = theObj->myHasPntText; } //======================================================================= diff --git a/src/XCAFDimTolObjects/XCAFDimTolObjects_DimensionObject.hxx b/src/XCAFDimTolObjects/XCAFDimTolObjects_DimensionObject.hxx index 9cbb866e62..802724eb5c 100644 --- a/src/XCAFDimTolObjects/XCAFDimTolObjects_DimensionObject.hxx +++ b/src/XCAFDimTolObjects/XCAFDimTolObjects_DimensionObject.hxx @@ -32,10 +32,12 @@ #include #include #include +#include #include #include #include #include +#include class XCAFDimTolObjects_DimensionObject; DEFINE_STANDARD_HANDLE(XCAFDimTolObjects_DimensionObject, Standard_Transient) @@ -116,6 +118,52 @@ public: Standard_EXPORT void SetPoints (const Handle(TColgp_HArray1OfPnt)& thePnts); + Standard_EXPORT void SetPointTextAttach (const gp_Pnt& thePntText) + { + myPntText = thePntText; + myHasPntText = Standard_True; + } + + Standard_EXPORT const gp_Pnt& GetPointTextAttach() const { return myPntText; } + + Standard_EXPORT Standard_Boolean HasTextPoint() const + { + return myHasPntText; + } + + Standard_EXPORT void SetPlane (const gp_Ax2& thePlane) + { + myPlane = thePlane; + myHasPlane = Standard_True; + } + + Standard_EXPORT const gp_Ax2& GetPlane() const { return myPlane; } + + Standard_EXPORT Standard_Boolean HasPlane() const { return myHasPlane; } + + Standard_EXPORT Standard_Boolean HasPoints() const { return (!myPnts.IsNull() && myPnts->Length() > 0); } + + + + //! Set graphical presentation for object + Standard_EXPORT void SetPresentation(const TopoDS_Shape& thePresentation, + const Handle(TCollection_HAsciiString)& thePresentationName) + { + myPresentation = thePresentation; + myPresentationName = thePresentationName; + } + + //! Returns graphical presentation of the object + Standard_EXPORT TopoDS_Shape GetPresentation() const + { + return myPresentation; + } + + //! Returns graphical presentation of the object + Standard_EXPORT Handle(TCollection_HAsciiString) GetPresentationName() const + { + return myPresentationName; + } DEFINE_STANDARD_RTTIEXT(XCAFDimTolObjects_DimensionObject,Standard_Transient) @@ -133,6 +181,12 @@ private: TopoDS_Edge myPath; gp_Dir myDir; Handle(TColgp_HArray1OfPnt) myPnts; + gp_Ax2 myPlane; + Standard_Boolean myHasPlane; + Standard_Boolean myHasPntText; + gp_Pnt myPntText; + TopoDS_Shape myPresentation; + Handle(TCollection_HAsciiString) myPresentationName; }; diff --git a/src/XCAFDimTolObjects/XCAFDimTolObjects_GeomToleranceObject.cxx b/src/XCAFDimTolObjects/XCAFDimTolObjects_GeomToleranceObject.cxx index 58aae26e2b..f1e5c77dd0 100644 --- a/src/XCAFDimTolObjects/XCAFDimTolObjects_GeomToleranceObject.cxx +++ b/src/XCAFDimTolObjects/XCAFDimTolObjects_GeomToleranceObject.cxx @@ -23,6 +23,9 @@ IMPLEMENT_STANDARD_RTTIEXT(XCAFDimTolObjects_GeomToleranceObject,Standard_Transi XCAFDimTolObjects_GeomToleranceObject::XCAFDimTolObjects_GeomToleranceObject() { myHasAxis = Standard_False; + myHasPlane = Standard_False; + myHasPnt = Standard_False; + myHasPntText = Standard_False; } //======================================================================= @@ -40,8 +43,14 @@ XCAFDimTolObjects_GeomToleranceObject::XCAFDimTolObjects_GeomToleranceObject(con myValueOfZoneModif = theObj->myValueOfZoneModif; myModifiers = theObj->myModifiers; myMaxValueModif = theObj->myMaxValueModif; - myAxis = theObj->GetAxis(); - myHasAxis = Standard_False; + myAxis = theObj->myAxis; + myHasAxis = theObj->myHasAxis; + myPlane = theObj->myPlane; + myPnt= theObj->myPnt; + myPntText= theObj->myPntText; + myHasPlane = theObj->myHasPlane; + myHasPnt = theObj->myHasPnt; + myHasPntText = theObj->myHasPntText; } //======================================================================= @@ -243,4 +252,4 @@ gp_Ax2 XCAFDimTolObjects_GeomToleranceObject::GetAxis() const Standard_Boolean XCAFDimTolObjects_GeomToleranceObject::HasAxis () const { return myHasAxis; -} \ No newline at end of file +} diff --git a/src/XCAFDimTolObjects/XCAFDimTolObjects_GeomToleranceObject.hxx b/src/XCAFDimTolObjects/XCAFDimTolObjects_GeomToleranceObject.hxx index c141b1f992..5fdf62084a 100644 --- a/src/XCAFDimTolObjects/XCAFDimTolObjects_GeomToleranceObject.hxx +++ b/src/XCAFDimTolObjects/XCAFDimTolObjects_GeomToleranceObject.hxx @@ -30,6 +30,8 @@ #include #include #include +#include +#include class XCAFDimTolObjects_GeomToleranceObject; DEFINE_STANDARD_HANDLE(XCAFDimTolObjects_GeomToleranceObject, Standard_Transient) @@ -84,6 +86,62 @@ public: Standard_EXPORT Standard_Boolean HasAxis () const; + void SetPlane (const gp_Ax2& thePlane) + { + myPlane = thePlane; + myHasPlane = Standard_True; + } + + const gp_Ax2& GetPlane() const { return myPlane; } + + void SetPoint (const gp_Pnt& thePnt) + { + myPnt = thePnt; + myHasPnt = Standard_True; + } + + const gp_Pnt& GetPoint() const { return myPnt; } + + void SetPointTextAttach (const gp_Pnt& thePntText) + { + myPntText = thePntText; + myHasPntText = Standard_True; + } + + const gp_Pnt& GetPointTextAttach() const + { + return myPntText; + } + Standard_Boolean HasPlane() const { return myHasPlane; } + + Standard_Boolean HasPoint() const { return myHasPnt; } + + Standard_Boolean HasPointText() const + { + return myHasPntText; + } + + + //! Set graphical presentation for object + Standard_EXPORT void SetPresentation(const TopoDS_Shape& thePresentation, + const Handle(TCollection_HAsciiString)& thePresentationName) + { + myPresentation = thePresentation; + myPresentationName = thePresentationName; + } + + //! Returns graphical presentation of the object + Standard_EXPORT TopoDS_Shape GetPresentation() const + { + return myPresentation; + } + + //! Returns graphical presentation of the object + Standard_EXPORT Handle(TCollection_HAsciiString) GetPresentationName() const + { + return myPresentationName; + } + DEFINE_STANDARD_RTTIEXT(XCAFDimTolObjects_GeomToleranceObject,Standard_Transient) private: @@ -98,6 +156,15 @@ private: Standard_Real myMaxValueModif; gp_Ax2 myAxis; Standard_Boolean myHasAxis; + gp_Ax2 myPlane; + gp_Pnt myPnt; + gp_Pnt myPntText;; + Standard_Boolean myHasPlane; + Standard_Boolean myHasPnt; + Standard_Boolean myHasPntText; + TopoDS_Shape myPresentation; + Handle(TCollection_HAsciiString) myPresentationName; + }; diff --git a/src/XCAFDoc/XCAFDoc_Datum.cxx b/src/XCAFDoc/XCAFDoc_Datum.cxx index 774e284d05..8cc394c969 100644 --- a/src/XCAFDoc/XCAFDoc_Datum.cxx +++ b/src/XCAFDoc/XCAFDoc_Datum.cxx @@ -27,7 +27,8 @@ #include #include #include - +#include +#include #include @@ -48,6 +49,12 @@ enum ChildLab ChildLab_DTargetWidth, ChildLab_DTargetNumber, ChildLab_DatumTarget, + ChildLab_PlaneLoc, + ChildLab_PlaneN, + ChildLab_PlaneRef, + ChildLab_Pnt, + ChildLab_PntText, + ChildLab_Presentation }; //======================================================================= @@ -281,6 +288,73 @@ void XCAFDoc_Datum::SetObject(const Handle(XCAFDimTolObjects_DatumObject)& theOb aNum->Set(theObject->GetDatumTargetNumber()); Label().FindChild(ChildLab_DTargetNumber).AddAttribute(aNum); } + + if (theObject->HasPlane()) + { + Handle(TDataStd_RealArray) aLoc = new TDataStd_RealArray(); + Handle(TDataStd_RealArray) aN = new TDataStd_RealArray(); + Handle(TDataStd_RealArray) aR = new TDataStd_RealArray(); + gp_Ax2 anAx = theObject->GetPlane(); + + Handle(TColStd_HArray1OfReal) aLocArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aLocArr->SetValue(i, anAx.Location().Coord(i)); + aLoc->ChangeArray(aLocArr); + + Handle(TColStd_HArray1OfReal) aNArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aNArr->SetValue(i, anAx.Direction().Coord(i)); + aN->ChangeArray(aNArr); + + Handle(TColStd_HArray1OfReal) aRArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aRArr->SetValue(i, anAx.XDirection().Coord(i)); + aR->ChangeArray(aRArr); + + Label().FindChild(ChildLab_PlaneLoc).AddAttribute(aLoc); + Label().FindChild(ChildLab_PlaneN).AddAttribute(aN); + Label().FindChild(ChildLab_PlaneRef).AddAttribute(aR); + } + + if (theObject->HasPoint()) + { + Handle(TDataStd_RealArray) aLoc = new TDataStd_RealArray(); + gp_Pnt aPnt = theObject->GetPoint(); + + Handle(TColStd_HArray1OfReal) aLocArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aLocArr->SetValue(i, aPnt.Coord(i)); + aLoc->ChangeArray(aLocArr); + + Label().FindChild(ChildLab_Pnt).AddAttribute(aLoc); + } + + if (theObject->HasPointText()) + { + Handle(TDataStd_RealArray) aLoc = new TDataStd_RealArray(); + gp_Pnt aPntText = theObject->GetPointTextAttach(); + + Handle(TColStd_HArray1OfReal) aLocArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aLocArr->SetValue(i, aPntText.Coord(i)); + aLoc->ChangeArray(aLocArr); + + Label().FindChild(ChildLab_PntText).AddAttribute(aLoc); + } + TopoDS_Shape aPresentation = theObject->GetPresentation(); + if( !aPresentation.IsNull()) + { + TDF_Label aLPres = Label().FindChild( ChildLab_Presentation); + TNaming_Builder tnBuild(aLPres); + tnBuild.Generated(aPresentation); + Handle(TCollection_HAsciiString) aName = theObject->GetPresentationName(); + if( !aName.IsNull() ) + { + TCollection_ExtendedString str ( aName->String() ); + TDataStd_Name::Set ( aLPres, str ); + } + } + } //======================================================================= @@ -325,6 +399,32 @@ Handle(XCAFDimTolObjects_DatumObject) XCAFDoc_Datum::GetObject() const anObj->SetPosition(aPosition->Get()); } + Handle(TDataStd_RealArray) aLoc, aN, aR; + if(Label().FindChild(ChildLab_PlaneLoc).FindAttribute(TDataStd_RealArray::GetID(), aLoc) && aLoc->Length() == 3 && + Label().FindChild(ChildLab_PlaneN).FindAttribute(TDataStd_RealArray::GetID(), aN) && aN->Length() == 3 && + Label().FindChild(ChildLab_PlaneRef).FindAttribute(TDataStd_RealArray::GetID(), aR) && aR->Length() == 3 ) + { + gp_Pnt aL(aLoc->Value(aLoc->Lower()), aLoc->Value(aLoc->Lower()+1), aLoc->Value(aLoc->Lower()+2)); + gp_Dir aD(aN->Value(aN->Lower()), aN->Value(aN->Lower()+1), aN->Value(aN->Lower()+2)); + gp_Dir aDR(aR->Value(aR->Lower()), aR->Value(aR->Lower()+1), aR->Value(aR->Lower()+2)); + gp_Ax2 anAx(aL, aD, aDR); + anObj->SetPlane(anAx); + } + + Handle(TDataStd_RealArray) aPnt; + if(Label().FindChild(ChildLab_Pnt).FindAttribute(TDataStd_RealArray::GetID(), aPnt) && aPnt->Length() == 3 ) + { + gp_Pnt aP(aLoc->Value(aPnt->Lower()), aPnt->Value(aPnt->Lower()+1), aPnt->Value(aPnt->Lower()+2)); + anObj->SetPoint(aP); + } + + Handle(TDataStd_RealArray) aPntText; + if(Label().FindChild(ChildLab_PntText).FindAttribute(TDataStd_RealArray::GetID(), aPntText) && aPntText->Length() == 3 ) + { + gp_Pnt aP (aPntText->Value(aPntText->Lower()), aPntText->Value(aPntText->Lower()+1), aPntText->Value(aPntText->Lower()+2)); + anObj->SetPointTextAttach(aP); + } + Handle(TDataStd_Integer) aIsDTarget; if(Label().FindChild(ChildLab_IsDTarget).FindAttribute(TDataStd_Integer::GetID(), aIsDTarget)) { @@ -351,9 +451,6 @@ Handle(XCAFDimTolObjects_DatumObject) XCAFDoc_Datum::GetObject() const } else { - Handle(TDataStd_RealArray) aLoc; - Handle(TDataStd_RealArray) aN; - Handle(TDataStd_RealArray) aR; if(Label().FindChild(ChildLab_AxisLoc).FindAttribute(TDataStd_RealArray::GetID(), aLoc) && aLoc->Length() == 3 && Label().FindChild(ChildLab_AxisN).FindAttribute(TDataStd_RealArray::GetID(), aN) && aN->Length() == 3 && Label().FindChild(ChildLab_AxisRef).FindAttribute(TDataStd_RealArray::GetID(), aR) && aR->Length() == 3 ) @@ -394,6 +491,27 @@ Handle(XCAFDimTolObjects_DatumObject) XCAFDoc_Datum::GetObject() const } } + Handle(TNaming_NamedShape) aNS; + TDF_Label aLPres = Label().FindChild( ChildLab_Presentation); + if ( aLPres.FindAttribute(TNaming_NamedShape::GetID(), aNS) ) + { + + TopoDS_Shape aPresentation = TNaming_Tool::GetShape(aNS); + if( !aPresentation.IsNull()) + { + Handle(TDataStd_Name) aNameAtrr; + Handle(TCollection_HAsciiString) aPresentName; + if (aLPres.FindAttribute(TDataStd_Name::GetID(),aNameAtrr)) + { + const TCollection_ExtendedString& aName = aNameAtrr->Get(); + + if( !aName.IsEmpty()) + aPresentName = new TCollection_HAsciiString(aName); + } + + anObj->SetPresentation(aPresentation, aPresentName); + } + } return anObj; } diff --git a/src/XCAFDoc/XCAFDoc_Datum.hxx b/src/XCAFDoc/XCAFDoc_Datum.hxx index 7356e0160c..11805395e4 100644 --- a/src/XCAFDoc/XCAFDoc_Datum.hxx +++ b/src/XCAFDoc/XCAFDoc_Datum.hxx @@ -84,6 +84,7 @@ private: Handle(TCollection_HAsciiString) myIdentification; + }; diff --git a/src/XCAFDoc/XCAFDoc_DimTolTool.cxx b/src/XCAFDoc/XCAFDoc_DimTolTool.cxx index 8267f03d76..fe1a05e151 100644 --- a/src/XCAFDoc/XCAFDoc_DimTolTool.cxx +++ b/src/XCAFDoc/XCAFDoc_DimTolTool.cxx @@ -11,7 +11,7 @@ // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. - +#include #include #include #include @@ -34,6 +34,7 @@ #include #include + IMPLEMENT_STANDARD_RTTIEXT(XCAFDoc_DimTolTool,TDF_Attribute) //======================================================================= @@ -886,6 +887,7 @@ Standard_Boolean XCAFDoc_DimTolTool::GetTolerOfDatumLabels(const TDF_Label& theD } + //======================================================================= //function : ID //purpose : diff --git a/src/XCAFDoc/XCAFDoc_DimTolTool.hxx b/src/XCAFDoc/XCAFDoc_DimTolTool.hxx index 9e79142445..3081691e7b 100644 --- a/src/XCAFDoc/XCAFDoc_DimTolTool.hxx +++ b/src/XCAFDoc/XCAFDoc_DimTolTool.hxx @@ -24,6 +24,8 @@ #include #include #include +#include + class XCAFDoc_ShapeTool; class TDF_Label; class Standard_GUID; @@ -185,7 +187,7 @@ public: //! Returns Datum label defined for label ShapeL Standard_EXPORT Standard_Boolean GetRefDatumLabel (const TDF_Label& theShapeL, TDF_LabelSequence& theDatum) const; - + Standard_EXPORT const Standard_GUID& ID() const Standard_OVERRIDE; Standard_EXPORT void Restore (const Handle(TDF_Attribute)& with) Standard_OVERRIDE; diff --git a/src/XCAFDoc/XCAFDoc_Dimension.cxx b/src/XCAFDoc/XCAFDoc_Dimension.cxx index 162e14286d..6dc547c9d6 100644 --- a/src/XCAFDoc/XCAFDoc_Dimension.cxx +++ b/src/XCAFDoc/XCAFDoc_Dimension.cxx @@ -28,6 +28,8 @@ #include #include #include +#include +#include IMPLEMENT_STANDARD_RTTIEXT(XCAFDoc_Dimension,TDF_Attribute) @@ -41,7 +43,13 @@ enum ChildLab ChildLab_Modifiers, ChildLab_Path, ChildLab_Dir, - ChildLab_Pnts + ChildLab_Pnts, + ChildLab_PlaneLoc, + ChildLab_PlaneN, + ChildLab_PlaneRef, + ChildLab_PntText, + ChildLab_Presentation + }; //======================================================================= @@ -171,18 +179,75 @@ void XCAFDoc_Dimension::SetObject (const Handle(XCAFDimTolObjects_DimensionObjec Handle(TColgp_HArray1OfPnt) aP = theObject->GetPoints(); if(!aP.IsNull() && aP->Length() > 0) { - anArrR = new TColStd_HArray1OfReal(1,6); + anArrR = new TColStd_HArray1OfReal(1,aP->Length() * 3); Handle(TDataStd_RealArray) aPnts; anArrR->SetValue(1,aP->Value(1).X()); anArrR->SetValue(2,aP->Value(1).Y()); anArrR->SetValue(3,aP->Value(1).Z()); - anArrR->SetValue(4,aP->Value(2).X()); - anArrR->SetValue(5,aP->Value(2).Y()); - anArrR->SetValue(6,aP->Value(2).Z()); + if (aP->Length() == 2) { + anArrR->SetValue(4,aP->Value(2).X()); + anArrR->SetValue(5,aP->Value(2).Y()); + anArrR->SetValue(6,aP->Value(2).Z()); + } aPnts = new TDataStd_RealArray(); Label().FindChild(ChildLab_Pnts).AddAttribute(aPnts); aPnts->ChangeArray(anArrR); } + + if (theObject->HasPlane()) + { + Handle(TDataStd_RealArray) aLoc = new TDataStd_RealArray(); + Handle(TDataStd_RealArray) aN = new TDataStd_RealArray(); + Handle(TDataStd_RealArray) aRAtt = new TDataStd_RealArray(); + gp_Ax2 anAx = theObject->GetPlane(); + + Handle(TColStd_HArray1OfReal) aLocArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aLocArr->SetValue(i, anAx.Location().Coord(i)); + aLoc->ChangeArray(aLocArr); + + Handle(TColStd_HArray1OfReal) aNArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aNArr->SetValue(i, anAx.Direction().Coord(i)); + aN->ChangeArray(aNArr); + + Handle(TColStd_HArray1OfReal) aRArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aRArr->SetValue(i, anAx.XDirection().Coord(i)); + aRAtt->ChangeArray(aRArr); + + Label().FindChild(ChildLab_PlaneLoc).AddAttribute(aLoc); + Label().FindChild(ChildLab_PlaneN).AddAttribute(aN); + Label().FindChild(ChildLab_PlaneRef).AddAttribute(aRAtt); + } + + if (theObject->HasTextPoint()) + { + Handle(TDataStd_RealArray) aLoc = new TDataStd_RealArray(); + gp_Pnt aPntText = theObject->GetPointTextAttach(); + + Handle(TColStd_HArray1OfReal) aLocArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aLocArr->SetValue(i, aPntText.Coord(i)); + aLoc->ChangeArray(aLocArr); + + Label().FindChild(ChildLab_PntText).AddAttribute(aLoc); + } + + TopoDS_Shape aPresentation = theObject->GetPresentation(); + if( !aPresentation.IsNull()) + { + TDF_Label aLPres = Label().FindChild( ChildLab_Presentation); + TNaming_Builder tnBuild(aLPres); + tnBuild.Generated(aPresentation); + Handle(TCollection_HAsciiString) aName = theObject->GetPresentationName(); + if( !aName.IsNull() ) + { + TCollection_ExtendedString str ( aName->String() ); + TDataStd_Name::Set ( aLPres, str ); + } + } + } //======================================================================= @@ -254,14 +319,60 @@ Handle(XCAFDimTolObjects_DimensionObject) XCAFDoc_Dimension::GetObject() const Handle(TDataStd_RealArray) aPnts; if(Label().FindChild(ChildLab_Pnts).FindAttribute(TDataStd_RealArray::GetID(), aPnts) - && !aPnts->Array().IsNull() && aPnts->Array()->Length() > 0) + && !aPnts->Array().IsNull() && aPnts->Array()->Length() > 2) { - Handle(TColgp_HArray1OfPnt) aP = new TColgp_HArray1OfPnt(1,2); - aP->SetValue(1, gp_Pnt(aPnts->Array()->Value(1), aPnts->Array()->Value(2), aPnts->Array()->Value(3))); - aP->SetValue(2, gp_Pnt(aPnts->Array()->Value(4), aPnts->Array()->Value(5), aPnts->Array()->Value(6))); + Handle(TColgp_HArray1OfPnt) aP = new TColgp_HArray1OfPnt(1,aPnts->Array()->Length()/3); + gp_Pnt aP1(aPnts->Array()->Value(1), aPnts->Array()->Value(2), aPnts->Array()->Value(3)); + aP->SetValue(1, aP1); + if (aPnts->Array()->Length() == 6) + { + gp_Pnt aP2(aPnts->Array()->Value(4), aPnts->Array()->Value(5), aPnts->Array()->Value(6)); + aP->SetValue(2, aP2); + } anObj->SetPoints(aP); } + Handle(TDataStd_RealArray) aLoc, aN, aR; + if(Label().FindChild(ChildLab_PlaneLoc).FindAttribute(TDataStd_RealArray::GetID(), aLoc) && aLoc->Length() == 3 && + Label().FindChild(ChildLab_PlaneN).FindAttribute(TDataStd_RealArray::GetID(), aN) && aN->Length() == 3 && + Label().FindChild(ChildLab_PlaneRef).FindAttribute(TDataStd_RealArray::GetID(), aR) && aR->Length() == 3 ) + { + gp_Pnt aL(aLoc->Value(aLoc->Lower()), aLoc->Value(aLoc->Lower()+1), aLoc->Value(aLoc->Lower()+2)); + gp_Dir aD(aN->Value(aN->Lower()), aN->Value(aN->Lower()+1), aN->Value(aN->Lower()+2)); + gp_Dir aDR(aR->Value(aR->Lower()), aR->Value(aR->Lower()+1), aR->Value(aR->Lower()+2)); + gp_Ax2 anAx(aL, aD, aDR); + anObj->SetPlane(anAx); + } + + Handle(TDataStd_RealArray) aPntText; + if(Label().FindChild(ChildLab_PntText).FindAttribute(TDataStd_RealArray::GetID(), aPntText) && aPntText->Length() == 3 ) + { + gp_Pnt aP(aPntText->Value(aPntText->Lower()), aPntText->Value(aPntText->Lower()+1), aPntText->Value(aPntText->Lower()+2)); + anObj->SetPointTextAttach(aP); + } + + Handle(TNaming_NamedShape) aNS; + TDF_Label aLPres = Label().FindChild( ChildLab_Presentation); + if ( aLPres.FindAttribute(TNaming_NamedShape::GetID(), aNS) ) + { + + TopoDS_Shape aPresentation = TNaming_Tool::GetShape(aNS); + if( !aPresentation.IsNull()) + { + + Handle(TDataStd_Name) aNameAtrr; + Handle(TCollection_HAsciiString) aPresentName; + if (aLPres.FindAttribute(TDataStd_Name::GetID(),aNameAtrr)) + { + const TCollection_ExtendedString& aName = aNameAtrr->Get(); + + if( !aName.IsEmpty()) + aPresentName = new TCollection_HAsciiString(aName); + } + + anObj->SetPresentation(aPresentation, aPresentName); + } + } return anObj; } diff --git a/src/XCAFDoc/XCAFDoc_GeomTolerance.cxx b/src/XCAFDoc/XCAFDoc_GeomTolerance.cxx index 99cddcc97d..c5ed6315c7 100644 --- a/src/XCAFDoc/XCAFDoc_GeomTolerance.cxx +++ b/src/XCAFDoc/XCAFDoc_GeomTolerance.cxx @@ -22,6 +22,10 @@ #include #include #include +#include +#include +#include +#include IMPLEMENT_STANDARD_RTTIEXT(XCAFDoc_GeomTolerance,TDF_Attribute) @@ -37,7 +41,13 @@ enum ChildLab ChildLab_aMaxValueModif, ChildLab_AxisLoc, ChildLab_AxisN, - ChildLab_AxisRef + ChildLab_AxisRef, + ChildLab_PlaneLoc, + ChildLab_PlaneN, + ChildLab_PlaneRef, + ChildLab_Pnt, + ChildLab_PntText, + ChildLab_Presentation }; //======================================================================= @@ -175,6 +185,74 @@ void XCAFDoc_GeomTolerance::SetObject (const Handle(XCAFDimTolObjects_GeomTolera Label().FindChild(ChildLab_AxisN).AddAttribute(aN); Label().FindChild(ChildLab_AxisRef).AddAttribute(aR); } + + if (theObject->HasPlane()) + { + Handle(TDataStd_RealArray) aLoc = new TDataStd_RealArray(); + Handle(TDataStd_RealArray) aN = new TDataStd_RealArray(); + Handle(TDataStd_RealArray) aR = new TDataStd_RealArray(); + gp_Ax2 anAx = theObject->GetPlane(); + + Handle(TColStd_HArray1OfReal) aLocArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aLocArr->SetValue(i, anAx.Location().Coord(i)); + aLoc->ChangeArray(aLocArr); + + Handle(TColStd_HArray1OfReal) aNArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aNArr->SetValue(i, anAx.Direction().Coord(i)); + aN->ChangeArray(aNArr); + + Handle(TColStd_HArray1OfReal) aRArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aRArr->SetValue(i, anAx.XDirection().Coord(i)); + aR->ChangeArray(aRArr); + + Label().FindChild(ChildLab_PlaneLoc).AddAttribute(aLoc); + Label().FindChild(ChildLab_PlaneN).AddAttribute(aN); + Label().FindChild(ChildLab_PlaneRef).AddAttribute(aR); + } + + if (theObject->HasPoint()) + { + Handle(TDataStd_RealArray) aLoc = new TDataStd_RealArray(); + gp_Pnt aPnt = theObject->GetPoint(); + + Handle(TColStd_HArray1OfReal) aLocArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aLocArr->SetValue(i, aPnt.Coord(i)); + aLoc->ChangeArray(aLocArr); + + Label().FindChild(ChildLab_Pnt).AddAttribute(aLoc); + } + + if (theObject->HasPointText()) + { + Handle(TDataStd_RealArray) aLoc = new TDataStd_RealArray(); + gp_Pnt aPntText = theObject->GetPointTextAttach(); + + Handle(TColStd_HArray1OfReal) aLocArr = new TColStd_HArray1OfReal(1, 3); + for (Standard_Integer i = 1; i <= 3; i++) + aLocArr->SetValue(i, aPntText.Coord(i)); + aLoc->ChangeArray(aLocArr); + + Label().FindChild(ChildLab_PntText).AddAttribute(aLoc); + } + + TopoDS_Shape aPresentation = theObject->GetPresentation(); + if( !aPresentation.IsNull()) + { + TDF_Label aLPres = Label().FindChild( ChildLab_Presentation); + TNaming_Builder tnBuild(aLPres); + tnBuild.Generated(aPresentation); + Handle(TCollection_HAsciiString) aName = theObject->GetPresentationName(); + if( !aName.IsNull() ) + { + TCollection_ExtendedString str ( aName->String() ); + TDataStd_Name::Set ( aLPres, str ); + } + } + } //======================================================================= @@ -251,6 +329,54 @@ Handle(XCAFDimTolObjects_GeomToleranceObject) XCAFDoc_GeomTolerance::GetObject() gp_Ax2 anAx(aL, aD, aDR); anObj->SetAxis(anAx); } + + if(Label().FindChild(ChildLab_PlaneLoc).FindAttribute(TDataStd_RealArray::GetID(), aLoc) && aLoc->Length() == 3 && + Label().FindChild(ChildLab_PlaneN).FindAttribute(TDataStd_RealArray::GetID(), aN) && aN->Length() == 3 && + Label().FindChild(ChildLab_PlaneRef).FindAttribute(TDataStd_RealArray::GetID(), aR) && aR->Length() == 3 ) + { + gp_Pnt aL(aLoc->Value(aLoc->Lower()), aLoc->Value(aLoc->Lower()+1), aLoc->Value(aLoc->Lower()+2)); + gp_Dir aD(aN->Value(aN->Lower()), aN->Value(aN->Lower()+1), aN->Value(aN->Lower()+2)); + gp_Dir aDR(aR->Value(aR->Lower()), aR->Value(aR->Lower()+1), aR->Value(aR->Lower()+2)); + gp_Ax2 anAx(aL, aD, aDR); + anObj->SetPlane(anAx); + } + + Handle(TDataStd_RealArray) aPnt; + if(Label().FindChild(ChildLab_PlaneLoc).FindAttribute(TDataStd_RealArray::GetID(), aPnt) && aPnt->Length() == 3 ) + { + gp_Pnt aP(aLoc->Value(aPnt->Lower()), aPnt->Value(aPnt->Lower()+1), aPnt->Value(aPnt->Lower()+2)); + anObj->SetPoint(aP); + } + + Handle(TDataStd_RealArray) aPntText; + if(Label().FindChild(ChildLab_PntText).FindAttribute(TDataStd_RealArray::GetID(), aPntText) && aPntText->Length() == 3 ) + { + gp_Pnt aP(aPntText->Value(aPntText->Lower()), aPntText->Value(aPntText->Lower()+1), aPntText->Value(aPntText->Lower()+2)); + anObj->SetPointTextAttach(aP); + } + + Handle(TNaming_NamedShape) aNS; + TDF_Label aLPres = Label().FindChild( ChildLab_Presentation); + if ( aLPres.FindAttribute(TNaming_NamedShape::GetID(), aNS) ) + { + + TopoDS_Shape aPresentation = TNaming_Tool::GetShape(aNS); + if( !aPresentation.IsNull()) + { + Handle(TDataStd_Name) aNameAtrr; + Handle(TCollection_HAsciiString) aPresentName; + if (aLPres.FindAttribute(TDataStd_Name::GetID(),aNameAtrr)) + { + const TCollection_ExtendedString& aName = aNameAtrr->Get(); + + if( !aName.IsEmpty()) + aPresentName = new TCollection_HAsciiString(aName); + } + + anObj->SetPresentation(aPresentation, aPresentName); + } + } + return anObj; }