/////////////////////////////////////////////////////////////////////////////// // 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 _ODAUTOPLANTCYLINDERIMPL_INCLUDED #define _ODAUTOPLANTCYLINDERIMPL_INCLUDED #include "DgCone.h" #include "DgEllipse.h" class OdDgAutoplantCylinder; class OdDgAutoplantCylinderImpl { public: OdDgAutoplantCylinderImpl(); virtual ~OdDgAutoplantCylinderImpl(); virtual OdResult dgnInFields(OdDgFiler* pFiler); virtual void dgnOutFields(OdDgFiler* pFiler) const; virtual void scaleData(double dScale); virtual bool subWorldDraw(OdGiWorldDraw* pWd, const OdDgAutoplantCylinder* pElm) const; virtual void subViewportDraw(OdGiViewportDraw *pVd, const OdDgAutoplantCylinder* pElm) const; OdResult subGetGeomExtents(OdGeExtents3d& extents, const OdDgAutoplantCylinder* pElm) const; OdResult subGetGeomExtents(const OdDgElementId& idView, OdGeExtents3d& extents, const OdDgAutoplantCylinder* pElm) const; virtual OdResult subExplode(OdRxObjectPtrArray& entitySet, const OdDgAutoplantCylinder* pElm) const; virtual OdResult transformBy(const OdGeMatrix3d& xfm); virtual const OdDgCone* getConeElement(const OdDgAutoplantCylinder* pElm) const; virtual void updateConeElement(const OdDgAutoplantCylinder* pElm); virtual OdGePoint3d getCenter1() const; virtual void setCenter1(const OdGePoint3d& ptCenter); virtual OdGePoint3d getCenter2() const; virtual void setCenter2(const OdGePoint3d& ptCenter); virtual double getRadius() const; virtual void setRadius(double dRadius); virtual bool getDrawStartCapFlag() const; virtual void setDrawStartCapFlag(bool bSet); virtual bool getDrawEndCapFlag() const; virtual void setDrawEndCapFlag(bool bSet); virtual OdUInt64 getFlags() const; virtual void setFlags(OdUInt64 uFlags); virtual double getStartData() const; virtual void setStartData(double dStartData); private: double m_dStartData; OdGePoint3d m_ptCenter1; OdGePoint3d m_ptCenter2; double m_dRadius; OdUInt64 m_uFlags; OdDgConePtr m_pConeElement; OdDgEllipse3dPtr m_pCapElement; }; #endif