/////////////////////////////////////////////////////////////////////////////// // 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 _ODAUTOPLANTTORUSIMPL_INCLUDED #define _ODAUTOPLANTTORUSIMPL_INCLUDED #include "DgGraphicsElement.h" class OdDgAutoplantTorus; class OdDgAutoplantTorusImpl { public: OdDgAutoplantTorusImpl(); virtual ~OdDgAutoplantTorusImpl(); virtual OdResult dgnInFields(OdDgFiler* pFiler); virtual void dgnOutFields(OdDgFiler* pFiler) const; virtual void scaleData(double dScale); virtual bool subWorldDraw(OdGiWorldDraw* pWd, const OdDgAutoplantTorus* pElm) const; virtual void subViewportDraw(OdGiViewportDraw *pVd, const OdDgAutoplantTorus* pElm) const; OdResult subGetGeomExtents(OdGeExtents3d& extents, const OdDgAutoplantTorus* pElm) const; OdResult subGetGeomExtents(const OdDgElementId& idView, OdGeExtents3d& extents, const OdDgAutoplantTorus* pElm) const; virtual OdResult subExplode(OdRxObjectPtrArray& entitySet, const OdDgAutoplantTorus* pElm) const; virtual OdResult transformBy(const OdGeMatrix3d& xfm); virtual const OdDgGraphicsElement* getCachedElement(const OdDgAutoplantTorus* pElm) const; virtual void updateCachedElement(const OdDgAutoplantTorus* pElm); virtual OdGePoint3d getOrigin() const; virtual void setOrigin(const OdGePoint3d& ptOrigin); virtual OdGeVector3d getDirection() const; virtual void setDirection(const OdGeVector3d& vrDirection); virtual OdGeVector3d getRefVector() const; virtual void setRefVector(const OdGeVector3d& vrRef); virtual double getMajorRadius() const; virtual void setMajorRadius(double dRadius); virtual double getMinorStartRadius() const; virtual void setMinorStartRadius(double dRadius); virtual double getMinorEndRadius() const; virtual void setMinorEndRadius(double dRadius); virtual double getStartAngle() const; virtual void setStartAngle(double dAngle); virtual double getSweepAngle() const; virtual void setSweepAngle(double dAngle); virtual OdUInt64 getFlags() const; virtual void setFlags(OdUInt64 uFlags); virtual double getStartData() const; virtual void setStartData(double dStartData); protected: virtual bool drawTorusIsolines(OdGiWorldDraw* pWd) const; virtual bool drawTorusMesh(OdGiWorldDraw* pWd, const OdDgAutoplantTorus* pElm) const; private: double m_dStartData; OdGePoint3d m_ptOrigin; OdGeVector3d m_vrDirection; OdGeVector3d m_vrRef; double m_dMajorRadius; double m_dStartAngle; double m_dSweepAngle; double m_dMinorStartRadius; double m_dMinorEndRadius; OdUInt64 m_uFlags; OdDgGraphicsElementPtr m_pCacheElement; }; #endif