/////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2002-2025, 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 Open Design Alliance software pursuant to a license // agreement with Open Design Alliance. // Open Design Alliance Copyright (C) 2002-2025 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 _DB_ROTATED_DIMENSION_ #define _DB_ROTATED_DIMENSION_ #include "TD_PackPush.h" #include "DbDimension.h" #include "DwgDeclareMembers.h" /** \details This class represents Rotated Dimension entities in an OdDbDatabase instance. \remarks A Rotated Dimension entity dimensions the distance between between any two points in space as projected onto a line at the specfied rotation angle in the plane of the dimension. */ class DBDIM_EXPORT OdDbRotatedDimension : public OdDbDimension { public: DWGMAP_DECLARE_MEMBERS(OdDbRotatedDimension); OdDbRotatedDimension(); /* OdDbRotatedDimension( double rotation, const OdGePoint3d& xLine1Point, const OdGePoint3d& xLine2Point, const OdGePoint3d& dimLinePoint, const OdChar* dimText = 0, OdDbObjectId dimStyle = OdDbObjectId::kNull); */ /** \details Returns the WCS start point of the first extension line of this Dimension entity (DXF 13). \remarks This point and the centerPoint define one side of the angle being dimensioned. */ OdGePoint3d xLine1Point() const; /** \details Sets the WCS start point of the first extension line of this Dimension entity (DXF 13). \param xLine1Point [in] Start point. \remarks This point and the centerPoint define one side of the angle being dimensioned. */ void setXLine1Point( const OdGePoint3d& xLine1Point); /** \details Returns the WCS start point of the second extension line of this Dimension entity (DXF 14). \remarks This point and the centerPoint define one side of the angle being dimensioned. */ OdGePoint3d xLine2Point() const; /** \details Sets the WCS start point of the second extension line of this Dimension entity (DXF 14). \param xLine2Point [in] Start point. \remarks This point and the centerPoint define one side of the angle being dimensioned. */ void setXLine2Point( const OdGePoint3d& xLine2Point); /** \details Returns the WCS point defining the location of dimension line for this Dimension entity (DXF 10). */ OdGePoint3d dimLinePoint() const; /** \details Sets the WCS point defining the location of dimension line for this Dimension entity (DXF 10). \param dimLinePoint [in] Dimension line point. */ void setDimLinePoint( const OdGePoint3d& dimLinePoint); /** \details Returns the obliquing angle for this Dimension entity (DXF 52). \remarks All angles are expressed in radians. */ double oblique() const; /** \details Sets the obliquing angle for this Dimension entity (DXF 52). \param oblique [in] Obliquing angle. \remarks All angles are expressed in radians. */ void setOblique( double oblique); /** \details Returns the rotation angle for this Dimension entity (DXF 50). \remarks The rotation angle is measured from the OCS X-axis to the dimension line of this Dimension entity. \remarks All angles are expressed in radians. */ double rotation() const; /** \details Sets the rotation angle for this Dimension entity (DXF 50). \param rotation [in] Rotation angle. \remarks The rotation angle is measured from the OCS X-axis to the dimension line of this Dimension entity. \remarks All angles are expressed in radians. */ void setRotation(double rotation); /** \details Returns the jog symbol status of this Dimension entity. \returns Returns true if the jog symbol is on. */ bool jogSymbolOn() const; /** \details Sets the jog symbol status for this Dimension entity. \param value [in] Input jog symbol status. */ void setJogSymbolOn(bool value); /** \details Returns the jog symbol position of this Dimension entity. \returns Returns the jog symbol position as object of OdGePoint3d class. */ OdGePoint3d jogSymbolPosition() const; /** \details Sets the jog symbol position for this Dimension entity. \param pt [in] Input jog symbol position. */ void setJogSymbolPosition(const OdGePoint3d& pt); /** \details Returns the jog symbol height of this Dimension entity. \returns Returns the jog symbol height as a double value. */ double jogSymbolHeight(); /** \details Sets the jog symbol height for this Dimension entity. \param value [in] Input jog symbol height. */ void setJogSymbolHeight(double value); virtual OdResult dxfInFields_R12( OdDbDxfFiler* pFiler); virtual void dxfOutFields_R12( OdDbDxfFiler* pFiler) const; virtual OdResult dwgInFields( OdDbDwgFiler* pFiler); virtual void dwgOutFields( OdDbDwgFiler* pFiler) const; virtual OdResult dxfInFields( OdDbDxfFiler* pFiler); virtual void dxfOutFields( OdDbDxfFiler* pFiler) const; virtual OdResult subGetClassID( void* pClsid) const; }; /** \details This template class is a specialization of the OdSmartPtr class for OdDbRotatedDimension object pointers. */ typedef OdSmartPtr OdDbRotatedDimensionPtr; #include "TD_PackPop.h" #endif