/////////////////////////////////////////////////////////////////////////////// // 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. /////////////////////////////////////////////////////////////////////////////// // This file is generated automatically. #ifndef _IFC4X3_RC1_IFCDOORSTANDARDCASE_AUTO_IMPL_H #define _IFC4X3_RC1_IFCDOORSTANDARDCASE_AUTO_IMPL_H #include "IfcDoorAutoImpl.h" #include "TD_PackPush.h" /** \details The namespace contains schema-dependent classes, definitions and sub routines for work with IFC4X3_RC1 express schema definitions. */ namespace OdIfc4x3_rc1 { /** \details The standard door, IfcDoorStandardCase, defines a door with certain constraints for the provision of operation types, opening directions, frame and lining parameters, and with certain constraints for the geometric representation. The IfcDoorStandardCase handles all cases of doors, that: * are inserted into an opening, represented by IfcOpeningElement, using the IfcRelFillsElement relationship; * have a local placement relative to this opening, and with the y-axis of the placement pointing into the opening direction; * have a profile geometry, represented by IfcShapeRepresentation.RepresentationIdentifier="Profile" as a closed curve to which the door parameters apply; * have a reference to an IfcDoorType to define the opening direction and the operation type (swinging, sliding, folding, etc.) of the door. The attribute OperationType is provided and it's value is not UNDEFINED, and the attribute ParameterTakesPrecedence is "TRUE"; * have an IfcDoorLiningProperties and IfcDoorPanelProperties instances included in the set of HasPropertySets at IfcDoorType. - Geometric Representations - The geometric representation of IfcDoorStandardCase is defined using the following multiple shape representations for its definition: * Profile: a three-dimensional closed curve within a particular shape representation. The profile is used to apply the parameter of the parametric door representation. The profile around the edges of the opening is used to apply the door lining and door panel shape parameter. * MappedRepresentation: A SweptSolid, SurfaceModel, Brep or a CSG representation additionally defining the 3D shape of the standard door in addition to the parametric representation by applying the IfcDoorLiningProperties and an the IfcDoorPanelProperties to the 'Profile' representation. - Profile 3D Geometry - The Profile 3D Geometry concept applies to this entity. The door profile is represented by a three-dimensional closed curve within a particular shape representation. The profile is used to apply the parameter of the parametric door representation. The following attribute values for the IfcShapeRepresentation holding this geometric representation are used: * RepresentationIdentifier : 'Profile' * RepresentationType : 'Curve3D' or 'GeometricCurveSet', in case of 'GeometricCurveSet' only a single closed curve is contained in the set of IfcShapeRepresentation.Items. The following additional constraints apply to the 'Profile' representation type: * Curve: being an IfcPolyline defining a rectangle. * Position: The curve lies in the xz plane of the object placement coordinate (the y coordinate values of the IfcCartesianPoint's is 0.). Example of a door profile: */ class IFC4X3_RC1_EXPORT IfcDoorStandardCase : public IfcDoor { //DOM-IGNORE-BEGIN OD_EXP_DECLARE_MEMBERS(OdIfc4x3_rc1::IfcDoorStandardCase); //DOM-IGNORE-END public: /** \details Returns a type of a class instance. \returns Pointer to the OdDAI::Entity type that determines an entity definition within a schema. */ virtual OdDAI::Entity* getInstanceType() const override; /** \details Early-bound version of instances comparison. \param pOther [in] Other application instance. \param ordering [out] Receives the ordering (comparison) status. \returns true if comparison was performed, false if method has no implementation, so late-bound version could be applied. \remarks If the method returns true, the ordering parameter can receive one of the following statuses: Name Value Description _kLessThan_ -1 This object < Other Object. _kEqual_ 0 This object = Other Object. _kGreaterThan_ 1 This object > Other Object. _kNotOrderable_ 2 This class is not orderable.
*/ virtual bool comparedToEarlyImpl(const OdDAI::ApplicationInstance *pOther, OdRx::Ordering &ordering) const override; /** \details Checks whether the specified instance is the object derived from or belongs to this class. \param entityType [in] Entity to check. \returns true if the specified instance is the object derived from or belongs to this class, false otherwise. */ virtual bool isKindOf(OdIfc::OdIfcEntityType entityType) const override; /** \details Returns the type of this entity. \returns A value of the OdIfc::OdIfcEntityType type that represents type of this entity. */ virtual OdIfc::OdIfcEntityType type() const override; }; /** \details A data type that represents a smart pointer to a IfcDoorStandardCase object. */ typedef OdSmartPtr IfcDoorStandardCasePtr; } // namespace #include "TD_PackPop.h" #endif // _IFC4X3_RC1_IFCDOORSTANDARDCASE_AUTO_IMPL_H