data:image/s3,"s3://crabby-images/ec6d8/ec6d856c1c1edd902e6834820f67cad638c6efe5" alt="AB4D logo" |
SceneNode Class |
SceneNode class represents a basic component of a 3D scene that is composed of various SceneNodes organized in a hierarchical structure.
Inheritance Hierarchy Namespace: Ab3d.DirectXAssembly: Ab3d.DXEngine (in Ab3d.DXEngine.dll) Version: 7.1.9105.2048 (1.0.0.0)
Syntaxpublic class SceneNode : SharedDXSceneResource
The SceneNode type exposes the following members.
Constructors | Name | Description |
---|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | SceneNode |
Initializes a new instance of the SceneNode class.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | SceneNode(String) |
Initializes a new instance of the SceneNode class.
|
Top
Properties | Name | Description |
---|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | Bounds |
Bounds (bounding box) of this object in local coordinates (transformed by transformation on this SceneNode but not with parent's transformations).
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | ChildNodes |
Gets a readonly collection of child SceneNodes
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | ChildNodesCount |
Gets a number of child SceneNodes count
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | DirtyFlags |
Gets the current dirty flags
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | IsActuallyVisible |
Gets a Boolean that specifies if this SceneNode and its Children are actually visible taking parents visibility into account - this.IsVisible is true and also the parent is visible.
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | IsChildNodesListLocked |
Gets a boolean that specifies if ChildNodes for this SceneNode can be changed.
This property is set to true with calling LockChildNodes method. After locking the child nodes, they cannot be unlocked any more.
Note that this property is different from IsLocked property - that one prevent any change to SceneNode and can be unlocked.
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | IsHitTestVisible |
Gets or sets a Boolean that specifies if this SceneNode and 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).
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | IsLocked |
Gets or sets a boolean that specified is this SceneNode can be changed or not. If true than this SceneNode cannot be changed any more.
This also prevents checking DirtyFlags and calling Update method (calling NotifySceneNodeChange has no effect).
SceneNode can be made locked with calling Lock method. It can be un-locked with calling UnLock method.
Note that we can also lock only child nodes with calling LockChildNodes method.
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | IsVisible |
Gets or sets a Boolean that specified is this SceneNode and its child SceneNodes are visible.
This property may be true, but if parent's SceneNode is not visible, then this SceneNode will not be actually visible (this can be get from IsActuallyVisible).
When IsVisible is set to false, the DirectX resources created with this SceneNode are not disposed (are still available).
But when rendering the RenderablePrimitive objects that are created from this SceneNode are skipped when the scene is rendered.
This makes hiding and showing ob SceneNodes very fast because only the visibility of the RenderablePrimitive is changed.
If you want to release DirectX resources when hiding the SceneNode, remove it from its parent SceneNode and call Dispose instead of setting IsVisible to false.
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | ParentDXScene |
Gets the parent DXScene.
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | ParentNode |
Gets or sets the parent SceneNode
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | Tag |
Tag can contain any arbitrary data.
|
data:image/s3,"s3://crabby-images/a927d/a927d9d1a961d1cacbe02ed4ec4c64bdf9bf57d7" alt="Public property Public property" | Transform |
Gets or sets the Transformation.
|
Top
Methods | Name | Description |
---|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | AddChild |
Adds the specified SceneNode to the ChildNodes collection of this SceneNode
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | AddChildren |
Adds child SceneNodes to the ChildNodes collection of this SceneNode
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | CleanAllDirtyFlags |
Clean dirty flags on this and child nodes.
This is called after a frame was rendered.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | ClearChildNodes |
Removes all SceneNodes from the ChildNodes collection
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | FindNode |
Searches the ChildNodes recursively and returns the SceneNode with the specified name if found; else returns null.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | ForEachChildNodeT |
ForEachChildNode calls the childNodeFoundAction for each SceneNode of type T that is find in the hierarchy of the child SceneNodes starting at this SceneNode's ChildNodes.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | GetAllDescendantNodes |
Returns an enumerable of this SceneNode and all SceneNode that are children of this SceneNode and its children - gets all SceneNode in the hierarchy tree below this SceneNode as flat IEnumerable.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | GetChildNode |
Returns a child SceneNode object with the specified index.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | GetDetailsText |
Returns string that tells details about this SceneNode
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" data:image/s3,"s3://crabby-images/2b0d4/2b0d4d7176f844dc3239c286ca13a007050e05db" alt="Static member Static member" | GetSceneNodesBounds |
Returns the Bounds of the scene nodes that are children of the rootSceneNode. The sceneNodesFilter Func can be used to choose which scene nodes to use.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | GetTotalTransformMatrix |
Returns a SharpDX.Matrix that represents the transformation from the Root SceneNode to this SceneNode.
The includeThisTransform parameter specifies if transformation from this SceneNode is also included in the returned matrix.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | InsertChild |
Inserts the specified SceneNode to the ChildNodes collection to the specified index
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | Lock |
Locks the SceneNode which make it unchangable.
Note that Lock can be called only when the DirtyFlags are Unchanged - there are no changes made on this SceneNode.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | LockChildNodes |
LockChildNodes method locks ChildNodes and prevents changing them. After locking SceneNodes they cannot be unlocked again.
This is used mostly by SceneNodes that does not contain any ChildNodes - for example for MeshObjectNode.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | NotifyAllChildSceneNodesChange |
Add the changeType to all child SceneNodes.
This does not change this SceneNode's dirty flags.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" 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/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | NotifySceneNodeChange |
Add the SceneNodeDirtyFlags to this SceneNode's DirtyFlags flags.
This methods also calls NotifyChange on parent DXScene.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | RemoveChild |
Removes the specified SceneNode from the ChildNodes collection
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | RemoveChildAt |
Removes the SceneNode at the specified index from the ChildNodes collection
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | ReplaceChild(Int32, SceneNode) |
Replaces the SceneNode at the specified index with the newChildNode
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | ReplaceChild(SceneNode, SceneNode) |
Replaces the currentChildNode with the newChildNode
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | ToString |
Returns a String that represents this instance.
(Overrides ObjectToString) |
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | UnLock |
Unlocks the SceneNode.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | Update |
Update method is called on each update phase (before render phase)
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | UpdateBounds |
Updates the bounds of this SceneNode if the dirty flags indicates that the bounds could be changed of if the forceUpdate parameter is set to true
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | UpdateWorldBoundingBox |
Updates the worldBounds field based on the current worldMatrix and Bounds.
|
data:image/s3,"s3://crabby-images/09345/0934553d2b7fada669d1718da70c5df0ee44caa2" alt="Public method Public method" | UpdateWorldMatrix |
UpdateWorldMatrix checks if dirty flags indicate that the final world matrix for this SceneNode needs to be recalculated.
|
Top
Events | Name | Description |
---|
data:image/s3,"s3://crabby-images/b1450/b14509cc3744380ec8f681df7444053bd185eb1a" alt="Public event Public event" | ChildNodesChanged |
Occurs when list of ChildNode is changed.
|
data:image/s3,"s3://crabby-images/b1450/b14509cc3744380ec8f681df7444053bd185eb1a" alt="Public event Public event" | ParentNodeChanged |
Occurs when ParentNode 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 (ParentNode is set to null).
This event does not occur when this SceneNode is disposed.
|
data:image/s3,"s3://crabby-images/b1450/b14509cc3744380ec8f681df7444053bd185eb1a" alt="Public event Public event" | ResourcesInitialized |
ResourcesInitialized event is fried after the OnInitializeResources was called and the DirectX resources were created.
|
Top
Fields | Name | Description |
---|
data:image/s3,"s3://crabby-images/54275/542751c06595bcfaa1976f54d9fae1c1a73a9ccc" alt="Public field Public field" | IsWorldMatrixIdentity |
True if final world matrix (WorldMatrix) is identity.
This field can be checked to skip multipliyng with WorldMatrix.
|
data:image/s3,"s3://crabby-images/54275/542751c06595bcfaa1976f54d9fae1c1a73a9ccc" alt="Public field Public field" | WorldBounds |
Bounds with BoundingBox in world coordinates (transformed by parents transformations and transformation on this SceneNode).
|
data:image/s3,"s3://crabby-images/54275/542751c06595bcfaa1976f54d9fae1c1a73a9ccc" alt="Public field Public field" | WorldMatrix |
When IsWorldMatrixIdentity is false this field defines the final world matrix that is calculated from the parent's world matrix and this node's transformation matrix.
When IsWorldMatrixIdentity is true this field has an invalid value (is not set to Identity matrix for performance reasons).
|
Top
Extension Methods | Name | Description |
---|
data:image/s3,"s3://crabby-images/d8b78/d8b782f977637fe96c45c9bed604fcae99e522b9" alt="Public Extension Method Public Extension Method" | GetGeometryModel3D |
Returns a WPF's GeometryModel3D that was used to create the specified sceneNode.
If the sceneNode does not define a GeometryModel3D object, then null is returned.
(Defined by Extensions) |
data:image/s3,"s3://crabby-images/d8b78/d8b782f977637fe96c45c9bed604fcae99e522b9" alt="Public Extension Method Public Extension Method" | GetModel3D |
Returns a WPF's Model3D that was used to create the specified sceneNode.
If the sceneNode does not define a Model3D object, then null is returned.
(Defined by Extensions) |
data:image/s3,"s3://crabby-images/d8b78/d8b782f977637fe96c45c9bed604fcae99e522b9" alt="Public Extension Method Public Extension Method" | GetModelVisual3D |
Returns a WPF's ModelVisual3D that was used to create the specified sceneNode or any parent SceneNode (in case searchParentSceneNodes is true).
If a SceneNode that defines a ModelVisual3D is not found, then null is returned.
(Defined by Extensions) |
data:image/s3,"s3://crabby-images/d8b78/d8b782f977637fe96c45c9bed604fcae99e522b9" alt="Public Extension Method Public Extension Method" | GetVisual3D |
Returns a WPF's Visual3D that was used to create the specified sceneNode or any parent SceneNode (in case searchParentSceneNodes is true).
If a SceneNode that defines a Visual3D is not found, then null is returned.
(Defined by Extensions) |
Top
See Also