Class TIfcCartesianTransformationOperator3D

Unit

Declaration

type TIfcCartesianTransformationOperator3D = class(TIfcCartesianTransformationOperator)

Description

Geometric transformation in three-dimensional space.

Spec: https://standards.buildingsmart.org/IFC/RELEASE/IFC4_3/HTML/lexical/IfcCartesianTransformationOperator3D.htm

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2136).

Hierarchy

Show Additional Members:

Overview

Methods

Protected function WantsGlobalId: Boolean; virtual;
Protected class function IfcClassName: String; virtual;
Public function BuildNode(const Mapping: TCastleIfcMapping; const ParentProduct: TIfcProduct; const LitAppearance, UnlitAppearance: TAppearanceNode): TAbstractChildNode; virtual;
Protected function Scl: Single;
Protected function Scl2: Single; virtual;
Protected function Scl3: Single; virtual;
Protected function Axis1Vector: TVector3;
Protected function Axis2Vector: TVector3;
Protected function Axis3Vector: TVector3; virtual;
Public procedure GetTransform(out Translation: TVector3; out Rotation: TVector4; out AScale: TVector3); virtual;
Protected function Axis3Vector: TVector3; override;

Properties

Published property GlobalId: String read FGlobalId write FGlobalId;
Published property LayerAssignment: TIfcPresentationLayerAssignment read FLayerAssignment write FLayerAssignment;
Published property StyledByItem: TIfcStyledItem read FStyledByItem write FStyledByItem;
Published property Axis1: TIfcDirection read FAxis1 write FAxis1;
Published property Axis2: TIfcDirection read FAxis2 write FAxis2;
Published property LocalOrigin: TIfcCartesianPoint read FLocalOrigin write FLocalOrigin;
Published property Scale: TIfcReal read FScale write FScale;
Published property Axis3: TIfcDirection read FAxis3 write FAxis3;

Description

Methods

Protected function WantsGlobalId: Boolean; virtual;

If True, instances of this class will have GlobalId auto-assigned at saving, and they will be saved as part of the "data" list in IFC JSON files.

Strictly following the spec, this should be only defined for TIfcRoot, because only IfcRoot has GlobalId. In reality, we need GlobalId at TIfcPersistent to load some files, and we sometimes need WantsGlobalId = True to save some files.

Source: scene/load/ifc/castleifc_ifc_types.inc (line 52).

Protected class function IfcClassName: String; virtual;

Name for the IFC standard, used in IFC files. By default, this is just ClassName with prefix 'T' removed.

Source: scene/load/ifc/castleifc_ifc_types.inc (line 56).

Public function BuildNode(const Mapping: TCastleIfcMapping; const ParentProduct: TIfcProduct; const LitAppearance, UnlitAppearance: TAppearanceNode): TAbstractChildNode; virtual;

Build a node to display this using Castle Game Engine. Returns Nil if not possible / not implemented.

Parameters
ParentProduct
Parent TIfcProduct, to be used with TCastleIfcMapping.ConnectShapeAndProduct call.

It can be Nil (and TCastleIfcMapping.ConnectShapeAndProduct is already prepared to handle it too) if no particular TIfcProduct is parent of this, which (right now) only happens for some internal usage in UpdateCrossSection for throw-away shape instances.

LitAppearance
Appearance that should be used for all shapes created here, if they are supposed to be lit (made of polygons). May be given as Nil.
UnlitAppearance
Appearance that should be used for all shapes created here, if they are supposed to be unlit (made of lines, points). May be given as Nil.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 368).

Protected function Scl: Single;

The derived scale of the transformation, equal to scale if that is non-zero (it is zero if not specified in file), or 1.0 otherwise.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2097).

Protected function Scl2: Single; virtual;

The derived scale of the transformation along the axis 2 (normally the y axis).

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2100).

Protected function Scl3: Single; virtual;

The derived scale of the transformation along the axis 3 (normally the z axis).

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2103).

Protected function Axis1Vector: TVector3;

This item has no description.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2105).

Protected function Axis2Vector: TVector3;

This item has no description.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2106).

Protected function Axis3Vector: TVector3; virtual;

This item has no description.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2107).

Public procedure GetTransform(out Translation: TVector3; out Rotation: TVector4; out AScale: TVector3); virtual;

This item has no description.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2109).

Protected function Axis3Vector: TVector3; override;

This item has no description.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2140).

Properties

Published property GlobalId: String read FGlobalId write FGlobalId;

Globally unique identifier for the object instance.

Note: Not declared as TGUID, because TGUID cannot be published, but also we don't really need it: for our purposes, this identifier is just an arbitrary string.

Note: IFC 4.3 specification puts this only at IfcRoot, not at every IFC class. But testcase https://github.com/buildingsmart-community/Community-Sample-Test-Files/blob/main/IFC%204.0.2.1%20(IFC%204)/ISO%20Spec%20archive/wall-with-opening-and-window.json (from IFC 4.0) shows this can be present at any IFC class, in particular TIfcGeometricRepresentationContext.

In fact, TIfcGeometricRepresentationContext needs to have GlobalId to be successfully saved (avoid recursively trying to serialize it) in some cases. We indicate such classes with WantsGlobalId.

IFC JSON documentation says this, which seems to (unfortunately it is not unambiguous enough...) allow this at any IFC class: "Whereas the globalId attribute is only available to those elements that are descendent of the IfcRoot entity in the EXPRESS schema, we encourage a broader use of this globalId, to enable referencing between objects in a JSON file when useful.".

Source: scene/load/ifc/castleifc_ifc_types.inc (line 79).

Published property LayerAssignment: TIfcPresentationLayerAssignment read FLayerAssignment write FLayerAssignment;

Assignment of the representation item to a single or multiple layer(s). Nil if none.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 374).

Published property StyledByItem: TIfcStyledItem read FStyledByItem write FStyledByItem;

Reference to the IfcStyledItem that provides presentation information to the representation, e.g. a curve style, including colour and thickness to a geometric curve. Nil if none.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 380).

Published property Axis1: TIfcDirection read FAxis1 write FAxis1;

The direction used to determine U[1], the derived X axis direction.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2113).

Published property Axis2: TIfcDirection read FAxis2 write FAxis2;

The direction used to determine U[2], the derived Y axis direction.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2116).

Published property LocalOrigin: TIfcCartesianPoint read FLocalOrigin write FLocalOrigin;

The required translation, specified as a cartesian point. The actual translation included in the transformation is from the geometric origin to the local origin.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2121).

Published property Scale: TIfcReal read FScale write FScale;

The scaling value specified for the transformation.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2124).

Published property Axis3: TIfcDirection read FAxis3 write FAxis3;

The direction used to determine U[3], the derived Z axis direction.

Source: scene/load/ifc/castleifc_ifc_standard_types.inc (line 2143).


Generated by PasDoc 0.17.0.snapshot.