/////////////////////////////////////////////////////////////////////////////// // 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 OdDbAssocPointBasedPersSubentIdPE_INCLUDED_ #define OdDbAssocPointBasedPersSubentIdPE_INCLUDED_ /*!DOM*/ #include "OdDbAssocPersSubentIdPE.h" #include "TD_PackPush.h" /** \details This class provides the base protocol extension class that declares the protocol for working with point persistent subentity identifier. Library: Source code provided. */ class DBCONSTRAINTS_EXPORT OdDbAssocPointBasedPersSubentIdPE : public OdDbAssocPersSubentIdPE { protected: /** \details Checks whether the type equals to a given type specified by the class description instance. */ bool isTypeEqual(const OdDbEntity* pEntity, const OdRxClass* pTypeDesc) const; /** \details Fills the start vertex subentity identifiers. */ virtual void fillStartVertexSubentId(const OdDbEntity* pEntity, const OdDbSubentId& edgeSubentId, OdDbSubentId& startVertexSubentId); /** \details Fills the end vertex subentity identifiers. */ virtual void fillEndVertexSubentId(const OdDbEntity* pEntity, const OdDbSubentId& edgeSubentId, OdDbSubentId& startVertexSubentId); /** \details Gets other vertex subentity identifiers. */ virtual void getOtherVertexSubentIds(const OdDbEntity* pEntity, const OdDbSubentId& edgeSubentId, OdArray& otherVertexSubentIds); public: ODRX_DECLARE_MEMBERS(OdDbAssocPointBasedPersSubentIdPE); /** \details Declares the vertex type. */ enum VertexSubentIdx { kNotDefine = 0, // Undefined kStart = -1, // Start kEnd = -3, // End kCenter = -5, // Center kMiddle = -6, // Middle kMiddlePLinePrefix = 10000000, kCenterPLinePrefix = 1000000, }; /** \details Creates new persistent subentity identifier. */ virtual OdDbAssocPersSubentIdPtr createNewPersSubent(OdDbEntity* pEntity, const class OdDbCompoundObjectId& compId, const OdDbSubentId& subentId); /** \details Returns the transient subent ID of the dependent-on entity corresponding to the internally held associated subentity. */ virtual OdResult getTransientSubentIds(const OdDbEntity* pEntity, const OdDbAssocPersSubentId* pPerSubentId, OdArray& subents) const; /** \details Gets all subentity identifiers for a given subentity type. */ virtual OdResult getAllSubentities(const OdDbEntity* pEntity, OdDb::SubentType subentType, OdArray& allSubentIds); /** \details Gets the vertex subentity identifier corresponding to the given edge subentity identifier. This protocol provides the query of relations between the edge and vertex subentities. */ virtual OdResult getEdgeVertexSubentities(const OdDbEntity* pEntity, const OdDbSubentId& edgeSubentId, OdDbSubentId& startVertexSubentId, OdDbSubentId& endVertexSubentId, OdArray& otherVertexSubentIds); /** \details Gets the coordinates of a vertex subentity corresponding to the associated subentity ID. */ virtual OdResult getVertexSubentityGeometry(const OdDbEntity* pEntity, const OdDbSubentId& vertexSubentId, OdGePoint3d& vertexPosition); /** \details Sets the coordinates of a vertex subentity corresponding to the associated subentity ID. */ virtual OdResult setVertexSubentityGeometry(OdDbEntity* pEntity, const OdDbSubentId& vertexSubentId, const OdGePoint3d& newVertexPosition); /** \details Modifiers the geometry of a subentity. */ virtual OdResult setSubentityGeometry(OdDbEntity* pEntity, const OdDbSubentId& subentId, const OdDbEntity* pNewSubentityGeometry); private: /** \details Checks whether subentity identifier. */ bool checkSubentId(const OdDbSubentId& subentId) const; }; #include "TD_PackPop.h" #endif