/////////////////////////////////////////////////////////////////////////////// // 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 __OD_GS_VIEWPORT_PROPERTIES__ #define __OD_GS_VIEWPORT_PROPERTIES__ #include "TD_PackPush.h" #include "Gs/GsProperties.h" #include "Gi/GiViewportTraitsData.h" #include "Gs/GsBackgroundProperties.h" #include "Gs/GsVisualStyleProperties.h" #include "Gs/GsRenderSettingsProperties.h" // Viewports is not entities or nodes (this is objects with one attributes set per scene) // OdGsViewportProperties hierarhy: // OdGsViewportProperties // OdGsBackgroundProperties // OdGsVisualStyleProperties // OdGsRenderEnvironmentProperties // OdGsRenderSettingsProperties /** */ class GS_TOOLKIT_EXPORT OdGsViewportProperties : public OdGsProperties { OdGiViewportTraitsData* m_pViewportTraits; // Internal handlers OdGsBackgroundPropertiesPtr m_pBackground; OdGsVisualStylePropertiesPtr m_pVisualStyle; OdGsRenderEnvironmentPropertiesPtr m_pRenderEnvironment; OdGsRenderSettingsPropertiesPtr m_pRenderSettings; public: ODRX_DECLARE_MEMBERS(OdGsViewportProperties); /** \details Default constructor for the OdGsViewportProperties class. Sets viewport traits to NULL. */ OdGsViewportProperties(); /** \details Destructor for the OdGsViewportProperties class. Clears viewport traits. */ ~OdGsViewportProperties(); /** \details Retrieves pointer to viewport traits data object. */ OdGiViewportTraitsData* viewportTraitsData() const { return m_pViewportTraits; } /** \details Checks whether viewport traits are modified. \returns true if viewport traits are modified, false otherwise. */ bool isTraitsModified(); /** \details Clears viewport traits (background, visual style, render environment and render settings) if they are not NULL. */ void clearTraits(); // OdGsProperties virtual overrides /** \details Retrieves type of properties for this object with is 'kViewport'. */ virtual PropertiesType propertiesType() const { return kViewport; } /** \details Retrieves smart pointer to properties specified by the passed type. \param type [in] Property type. \remarks 'type' can be one of the the following: * kViewport - smart pointer to this object is returned * kBackground - method returns OdGsBackgroundPropertiesPtr smart pointer to associated background properties. * kVisualStyle - method returns OdGsVisualStylePropertiesPtr smart pointer to associated visual style properties. * kRenderEnvironment - method returns OdGsRenderEnvironmentPropertiesPtr smart pointer to associated render environment properties. * kRenderSettings - method returns OdGsRenderSettingsPropertiesPtr smart pointer to associated sender settings properties. In all other case method returns generic OdGsPropertiesPtr smart pointer. */ virtual OdSmartPtr propertiesForType(PropertiesType type) const; // Update attributes virtual void update(const OdGiDrawable* pUnderlyingDrawable, OdGsViewImpl* view, OdUInt32 incFlags = kAll); // Display attributed data virtual void display(OdGsBaseVectorizer& view, OdGsPropertiesDirectRenderOutput *pdro = NULL, OdUInt32 incFlags = kAll); }; /** \details This template class is a specialization of the OdSmartPtr class for OdGsViewportProperties object pointers. */ typedef OdSmartPtr OdGsViewportPropertiesPtr; #include "TD_PackPop.h" #endif // __OD_GS_VIEWPORT_PROPERTIES__