data:image/s3,"s3://crabby-images/d68fc/d68fc152f82aca48a52d5ceb7d13aa5a75512434" alt="Ab4d.SharpEngine logo" |
SceneNode Class |
SceneNode is a base abstract class that defines the common properties for all SceneNode objects.
SceneNodes objects define the 3D objects that are hierarchically organized by using
GroupNode object and define the 3D objects in the scene.
Inheritance Hierarchy Namespace: Ab4d.SharpEngine.SceneNodesAssembly: Ab4d.SharpEngine (in Ab4d.SharpEngine.dll) Version: 2.0.8956+4c7684e186ca1be74e7a284fbe739d9a1b843d3c
Syntaxpublic abstract class SceneNode : InitializedSceneComponent,
IDisposable
The SceneNode type exposes the following members.
Constructors
Properties | Name | Description |
---|
data:image/s3,"s3://crabby-images/19cd1/19cd14ffb2c91a1d6e84841b101310f623784a50" alt="Public property Public property" | DirtyFlags |
Gets the current dirty flags
|
data:image/s3,"s3://crabby-images/19cd1/19cd14ffb2c91a1d6e84841b101310f623784a50" alt="Public property Public property" | IsHitTestVisible |
Gets or sets a Boolean that specifies if this SceneNode (and in case of GroupNode all its child SceneNodes) are visible to hit testing.
When false, then the object cannot be hit and the testing ray passes through this SceneNode and through its child SceneNodes.
Default value is true.
|
data:image/s3,"s3://crabby-images/1fbf7/1fbf799a6ddc7c477f8c7ad7cbfa4f37a8ad2924" alt="Protected property Protected property" | IsParentVisible |
True if parent is visible
|
data:image/s3,"s3://crabby-images/19cd1/19cd14ffb2c91a1d6e84841b101310f623784a50" alt="Public property Public property" | IsVisible |
True if this SceneNode is actually visible (taking this and parent's Visibility into account).
|
data:image/s3,"s3://crabby-images/19cd1/19cd14ffb2c91a1d6e84841b101310f623784a50" alt="Public property Public property" | IsWorldMatrixIdentity |
True if this SceneNode has no transformed and also its parents have no transformation.
|
data:image/s3,"s3://crabby-images/19cd1/19cd14ffb2c91a1d6e84841b101310f623784a50" alt="Public property Public property" | Parent |
Gets the parent GroupNode of this SceneNode.
|
data:image/s3,"s3://crabby-images/19cd1/19cd14ffb2c91a1d6e84841b101310f623784a50" alt="Public property Public property" | PreviousDirtyFlags |
Gets DirtyFlags value before the last Update method call.
The Update method the DirtyFlags value is reset to Unchanged.
This property is set in the CleanDirtyFlags method and preserves the DirtyFlags value before the last Update call.
|
data:image/s3,"s3://crabby-images/19cd1/19cd14ffb2c91a1d6e84841b101310f623784a50" alt="Public property Public property" | Transform |
Gets or sets a transformation to this SceneNode.
|
data:image/s3,"s3://crabby-images/19cd1/19cd14ffb2c91a1d6e84841b101310f623784a50" alt="Public property Public property" | Visibility |
Gets or sets a SceneNodeVisibility of this SceneNode.
If this SceneNode is a GroupNode, then setting this property to Hidden will also hide all the child SceneNodes.
To see if this SceneNode is actually visible (taking this and parent's Visibility into account) see the value of the IsVisible property.
Default value is Visible.
|
Top
Methods | Name | Description |
---|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfMaterialIsDisposed |
CheckIfMaterialIsDisposed
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfMeshIsDisposed |
CheckIfMeshIsDisposed
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfNonZeroPositive(Single, String) |
CheckIfNonZeroPositive
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfNonZeroPositive(Vector2, String) |
CheckIfNonZeroPositive
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfNonZeroPositive(Vector3, String) |
CheckIfNonZeroPositive
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfNotSmallerThan(Int32, Int32, String) |
CheckIfNotSmallerThan
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfNotSmallerThan(Single, Single, String) |
CheckIfNotSmallerThan
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfPositiveOrZero(Single, String) |
CheckIfPositiveOrZero
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfPositiveOrZero(Vector2, String) |
CheckIfPositiveOrZero
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" data:image/s3,"s3://crabby-images/954dc/954dc06d9653ac7cb3995829e2d537c187a76876" alt="Static member Static member" | CheckIfPositiveOrZero(Vector3, String) |
CheckIfPositiveOrZero
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | CleanDirtyFlags |
Clean dirty flags on this and child nodes.
This should be called only after the frame was rendered.
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | ClearMeshDirtyFlag |
Clears the MeshDirty flag
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | CollectRenderingItems |
CollectRenderingItems
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | Dispose |
Dispose method disposes resources that are created by this SceneNode
(for example Mesh in PyramidModelNode or LineMaterial when LineNode is created with setting LineColor).
It does not dispose the resources that are created by the user and then set to properties in this SceneNode
(for example when a StandardMaterial is assigned to the Material property or Mesh is assigned to the MeshModelNode).
To also dispose the meshes and materials use the specialized dispose methods:
DisposeWithMaterial(Boolean),
DisposeWithMeshAndMaterial(Boolean, Boolean),
DisposeWithMaterial,
DisposeAllChildren(Boolean, Boolean, Boolean, Boolean),
DisposeWithAllChildren(Boolean, Boolean, Boolean, Boolean),
DisposeChildren(Int32, Int32, Boolean, Boolean, Boolean, Boolean).
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | Dispose(Boolean) |
Dispose
(Overrides ComponentBaseDispose(Boolean)) |
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | DisposeRenderingItems |
DisposeRenderingItems
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | GetInvertedWorldMatrix |
GetInvertedWorldMatrix method gets the inverted WorldMatrix into the matrix out parameter and returns true if matrix can be inverted; otherwise false is returned.
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | GetLocalBoundingBox |
Gets the BoundingBox of this SceneNode in local coordinates.
The BoundingBox is transformed by transformation on this SceneNode but not by parent's transformations.
This method always returns the value of localBoundingBox.
Derived classes can provide additional logic when updateIfDirty is true
(for example ModelNode can call UpdateMesh method when mesh is dirty;
GroupNode can update mesh on child SceneNodes, etc.).
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | GetOverviewText |
GetOverviewText adds string that writes details about this SceneNode into the specified StringBuilder.
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | NotifyAllParentSceneNodesChange |
Add the changeType to all parent SceneNodes.
This does not change this SceneNode's dirty flags.
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | NotifyChange |
Add the SceneNodeDirtyFlags to this SceneNode's DirtyFlags flags.
This methods also calls NotifyChange on parent DXScene.
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | OnIsVisibleChanged |
OnIsVisibleChanged is called when the value of IsVisible property is changed.
Overridden implementations should update the IsVisible property of the RenderingItem objects that were already added to RenderingLayers.
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | OnParentChanged |
OnParentChanged
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | OnTransformChanged |
OnTransformChanged is called when Transform or Parent's Transform is changed.
This method updates the WorldMatrix and sets WorldMatrixChanged dirty flags.
The method can be overridden to provide custom transformation handling.
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | OnUpdate |
OnUpdate
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | OnWorldMatrixChanged |
OnWorldMatrixChanged
|
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | ToString |
Returns a String that represents this instance.
(Overrides ObjectToString) |
data:image/s3,"s3://crabby-images/21394/21394337db2031cd49852d9f506dec7619157b48" alt="Public method Public method" | Update |
Update method is called before every rendering and updates the graphics buffers and states objects based on the current value of properties in this SceneNode.
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | UpdateIsVisible |
UpdateIsVisible
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | UpdateLocalBoundingBox |
UpdateLocalBoundingBox
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | UpdateWorldBoundingBox |
UpdateWorldBoundingBox
|
data:image/s3,"s3://crabby-images/3e6b4/3e6b4bad37cdafe2cdb13e7bbdc36ba7b911a664" alt="Protected method Protected method" | UpdateWorldMatrix |
UpdateWorldMatrix
|
Top
Events | Name | Description |
---|
data:image/s3,"s3://crabby-images/d0f85/d0f85e0a9b5ab3f65d9f8c9184232b17ef57da79" alt="Public event Public event" | ParentChanged |
Occurs when Parent is changed.
Occurs also when this SceneNode is added to the SceneNodes tree for the first time or when it is removed from the SceneNodes tree (Parent is set to null).
This event does not occur when this SceneNode is disposed.
|
Top
Fields | Name | Description |
---|
data:image/s3,"s3://crabby-images/5f2af/5f2af0cbc617a7a9ddba50d7aefc0c324beff3b4" alt="Protected field Protected field" | localBoundingBox |
BoundingBox in local coordinates that can be get or set by derived classes.
The BoundingBox is transformed by transformation on this SceneNode but not by parent's transformations.
Its value can be get by calling GetLocalBoundingBox(Boolean) method.
|
data:image/s3,"s3://crabby-images/5f2af/5f2af0cbc617a7a9ddba50d7aefc0c324beff3b4" alt="Protected field Protected field" | stateFlags |
stateFlags is used to store multiple Boolean values in one int based enum.
This value should not be set directly but only through a property.
|
data:image/s3,"s3://crabby-images/74161/741612345b839292b0d8271381cbaa0d1692dee9" alt="Public field Public field" | Tag |
Gets or sets an arbitrary object value that can be used to store custom information about this SceneNode.
|
data:image/s3,"s3://crabby-images/74161/741612345b839292b0d8271381cbaa0d1692dee9" alt="Public field Public field" | WorldBoundingBox |
BoundingBox in world coordinates (transformed by parents transformations and transformation on this SceneNode).
This value is calculated by the engine and should not be changed by the user. It is a field and not a property for performance reasons.
|
data:image/s3,"s3://crabby-images/74161/741612345b839292b0d8271381cbaa0d1692dee9" alt="Public field Public field" | WorldMatrix |
WorldMatrix defines the final world matrix for this SceneNode that is calculated from the parent's world matrix and this node's transformation matrix.
This value is calculated by the engine and should not be changed by the user.
|
Top
See Also