/////////////////////////////////////////////////////////////////////////////// // 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 OdConstrainedArcImpl_INCLUDED #define OdConstrainedArcImpl_INCLUDED #include "OdConstrainedCircleImpl.h" #include "TD_PackPush.h" /** \details This class represents custom implementation of the constrained circular arc node in the owning constraint group. Library: Source code provided. */ class DBCONSTRAINTS_EXPORT OdConstrainedArcImpl: public OdConstrainedCircleImpl { public: /** \details Constructor creates an instance of this class. */ OdConstrainedArcImpl(); /** \details Initializes this constrained circular arc object. */ virtual OdResult init(OdDbObjectId depId) ODRX_OVERRIDE; /** \details Returns the start point of this constrained circular arc. */ OdGePoint3d startPoint() const; /** \details Returns the end point of this constrained circular arc. */ OdGePoint3d endPoint() const; /** \details Returns the middle point of this constrained circular arc. */ OdGePoint3d midPoint() const; /** \details Checks whether the constrained circular arc is bounded and returns True when the it is bounded, or False otherwise. */ virtual bool isBounded() const; /** \details Reads the .dwg file data of this object. \param pFiler [in] Filer object from which data are read. \remarks Returns the filer status. */ virtual OdResult dwgInFields(OdDbDwgFiler* pFiler); /** \details Writes the .dwg file data of this object. \param pFiler [in] Pointer to the filer to which data are written. */ virtual void dwgOutFields(OdDbDwgFiler* pFiler) const; /** \details Reads the .dxf file data of this object. \param pFiler [in] Filer object from which data are read. \remarks Returns the filer status. */ virtual OdResult dxfInFields(OdDbDxfFiler* pFiler); /** \details Writes the .dxf file data of this object. \param pFiler [in] Pointer to the filer to which data are written. */ virtual void dxfOutFields(OdDbDxfFiler* pFiler) const; /** \details Sets the center point for this constrained circular arc. */ virtual OdResult setCenterPoint(const OdGePoint3d& center); /** \details Sets the radius for this constrained circular arc. */ virtual OdResult setRadius(const double val); /** \details Sets the start point for this constrained circular arc. */ OdResult setStartPoint(const OdGePoint3d& val); /** \details Sets the end point for this constrained circular arc. */ OdResult setEndPoint(const OdGePoint3d& val); /** \details Sets data from a given geometry dependency using transformation matrix. */ virtual OdResult setDataFromGeomDependency(const OdDbObjectId geomDependencyId, const OdGeMatrix3d& matrFromWrd); /** \details Updates the database object. */ virtual OdResult updateDbObject(OdDbObject *pObj, OdDbAssocGeomDependency* pDep, const OdGeMatrix3d& matrToWrd); /** \details Compares two constrained points on equality. */ virtual bool operator==(const OdConstrainedGeometryImpl& geom) const; /** \details Compares two constrained points on unequality. */ virtual bool operator!=(const OdConstrainedGeometryImpl& geom) const; /** \details Gets the three-dimesional point for the specified implicit point through argument. */ virtual OdResult point(const OdConstrainedImplicitPointImpl* pImplicitPoint, OdGePoint3d& res) const; /** \details Sets the specified implicit point using a three-dimesional point passed through argument. */ virtual OdResult setPoint(const OdConstrainedImplicitPointImpl* pImplicitPoint, const OdGePoint3d& val); /** \details Gets the three-dimesional original point for the specified implicit point through argument. */ virtual OdResult getOriginalPoint(const OdConstrainedImplicitPointImpl* pImplicitPoint, OdGePoint3d& res) const; /** \details Gets the three-dimensional circular arc as Ge-object. */ virtual const OdGeCircArc3d getOdGeCircArc3d() const; /** \details Gets the original three-dimensional circular arc as Ge-object. */ virtual const OdGeCircArc3d getOriginalOdGeCircArc3d() const; /** \details Returns an array of full subent paths. */ virtual OdResult getFullSubentPaths(OdDbFullSubentPathArray& subentPaths) const; /** \details Sets the start point, end point, center and radius for this constrained circular arc. */ OdResult set(const OdGePoint3d centerPt, const double rad, const OdGePoint3d startPt, const OdGePoint3d endPt); virtual void audit(OdConstraintGroupNode* pNode, OdAuditInfo* pAuditInfo) ODRX_OVERRIDE; /** \\details Restores original geometry. */ virtual void restoreOriginalGeometry(); /** \details Sets the start point, end point, center and radius for this constrained circular arc. */ OdResult set(const OdGePoint3d centerPt, const double rad, const double startAngle, const double endAngle); protected: /*!DOM*/ OdGePoint3d m_startOrig; /*!DOM*/ OdGePoint3d m_endOrig; /*!DOM*/ OdGePoint3d m_start; /*!DOM*/ OdGePoint3d m_end; }; #include "TD_PackPop.h" #endif