/////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2002-2016, Open Design Alliance (the "Alliance"). // All rights reserved. // // This software and its documentation and related materials are owned by // the Alliance. The software may only be incorporated into application // programs owned by members of the Alliance, subject to a signed // Membership Agreement and Supplemental Software License Agreement with the // Alliance. The structure and organization of this software are the valuable // trade secrets of the Alliance and its suppliers. The software is also // protected by copyright law and international treaty provisions. Application // programs incorporating this software must include the following statement // with their copyright notices: // // This application incorporates Teigha(R) software pursuant to a license // agreement with Open Design Alliance. // Teigha(R) Copyright (C) 2002-2016 by Open Design Alliance. // All rights reserved. // // By use of this software, its documentation or related materials, you // acknowledge and accept the above terms. /////////////////////////////////////////////////////////////////////////////// #ifndef _OD_DB_DIAMETRIC_DIMENSION_ #define _OD_DB_DIAMETRIC_DIMENSION_ #include "TD_PackPush.h" #include "DbDimension.h" /** \details This class represents Diametric Dimension entities in an OdDbDatabase instance. \remarks Diametric Dimension entities require two points defining the diameter of the curve being dimensioned. In additional, an optional leaderLength may be used to specify how far the dimension line extends beyond the curve before the dogleg to the annotation text. \sa TD_Db */ class TOOLKIT_EXPORT OdDbDiametricDimension : public OdDbDimension { public: ODDB_DECLARE_MEMBERS(OdDbDiametricDimension); OdDbDiametricDimension(); /** \details Sets the length from the chordPoint to the dogleg for this Dimension entity (DXF 40). \param leaderLength [in] Leader length. */ void setLeaderLength( double leaderLength); /** \details Returns the length from the chordPoint to the dogleg for this Dimension entity (DXF 40). */ double leaderLength() const; /** \details Returns the WCS chord point for this Dimension entity (DXF 15). \remarks The chord point is the point at which the dimension line for this Dimension entity intersects the curve being dimensioned, and would extend beyond it if the annotation text is outside the curve. It is the point on the diameter opposite farChordPoint. */ OdGePoint3d chordPoint() const; /** \details Sets the WCS chord point for this Dimension entity (DXF 15). \param chordPoint [in] Chord point. \remarks The chord point is the point at which the dimension line for this Dimension entity intersects the curve being dimensioned, and would extend beyond it if the annotation text is outside the curve. It is the point on the diameter opposite farChordPoint. */ void setChordPoint( const OdGePoint3d& chordPoint); /** \details Returns the WCS far chord point for this Dimension entity (DXF 10). \remarks The far chord point is the point on the diameter opposite chordPoint. */ OdGePoint3d farChordPoint() const; /** \details Sets the WCS far chord point for this Dimension entity (DXF 10). \param farChordPoint [in] Far chord point. \remarks The far chord point is the point on the diameter opposite chordPoint. */ void setFarChordPoint( const OdGePoint3d& farChordPoint); bool extArcOn() const; double extArcStartAngle() const; void setExtArcStartAngle(double newAngle); double extArcEndAngle() const; void setExtArcEndAngle(double newAngle); virtual OdResult dwgInFields( OdDbDwgFiler* pFiler); virtual void dwgOutFields( OdDbDwgFiler* pFiler) const; virtual OdResult dxfInFields( OdDbDxfFiler* pFiler); virtual void dxfOutFields( OdDbDxfFiler* pFiler) const; virtual OdResult dxfInFields_R12( OdDbDxfFiler* pFiler); virtual void dxfOutFields_R12( OdDbDxfFiler* pFiler) const; virtual OdResult subGetClassID( void* pClsid) const; }; /** \details This template class is a specialization of the OdSmartPtr class for OdDbDiametricDimension object pointers. */ typedef OdSmartPtr OdDbDiametricDimensionPtr; #include "TD_PackPop.h" #endif