-
Notifications
You must be signed in to change notification settings - Fork 70
Scene and EC Model
Scene consists of 0 to N Entities.
Entity consists of 0 to N Components.
Component (entity-component, EC) consists of 0 to N Attributes.
Components can be added to any Entity in the scene. The components define the functionality/behavior of the Entity.
A Component consists of Attributes. Each attribute has a name and a type. Once this structure is defined it can automatically be synchronized over the network, whatever the structure may be, without doing any networking code / message definitions to the components implementation. For more on the network synchronization refer to the realXtend Tundra protocol.
The components listed on this page are not a full list of available components in Tundra, but a list that will be relevant in brainstorming the XML3D integration. For a full list of component refer to the Tundra doxygen documentation.
The Tundra component system is extendable, so anyone can define a component and add it to the system. Usually outside of the Tundra core SDK this happens by loading C++ plugins during runtime that declare/register the component structure to both the server and client.
Name
- Adds a non-unique name for an entity. This can be used to query scene for Entities. Description and group can be used by application logic to create groups and define metadata (lighter alternative to using DynamicComponent)
- Main attributes: name (String), description (String) and group (String).
DynamicComponent
- Special component of which structure is not statically defined, but can be defined during runtime. This is useful on script logic to store custom data for the application and have it persist in the scene state.
- Main attributes: defined during runtime, all 17 attribute types are available.
Placeable
- Adds this Entity to the rendering scene graph by creating a scene node to it.
- Main attributes: transform (Transform: pos, rot and scale vectors) and visibility (Bool).
Mesh
- Defines the visual 3D mesh resources and surface materials to be loaded.
- Attaches itself to the parent Entity's Placeable component's scene node.
- In addition to the mesh resource defines list of materials that tell the rendering about mesh surface properties (ambient, diffuse, emissive, specular colors + textures + potential shaders).
- Main attributes: meshRef (AssetReference), meshMaterial (AssetReferenceList).
Camera
- Adds a camera/viewport to the 3D rendering. Usually this component is created locally on the client by (script) application logic.
- Attaches itself to the parent Entity's Placeable components scene node.
- Main attributes: FOV, near- and farclip (Real).
Light
- Adds a light source to the 3D scene.
- Attaches itself to the parent Entity's Placeable components scene node.
- Main attributes: Diffuse and specular color (Color), type (Number/Enum: Spot, Point and Directional), range (Number), brightness (Number), attenuation(s) (Number).
ParticleSystem
- Adds a particle system/effect to the 3D scene. The particle system will be loaded from the specified asset reference.
- Attaches itself to the parent Entity's Placeable components scene node.
- Main attributes: particleRef (AssetReference: points to a supported particle asset) and visibility (Bool).
Billboard
- Adds a "2D" sprite type billboard to the 3D scene. Surface material defined similarly as the Mesh component does, references to a material file.
- Is part of the 3D scene but always faces the active camera.
- Attaches itself to the parent Entity's Placeable components scene node.
- Main attributes: materialRef (AssetReference), position (Float3: relative offset from Placeable), size and visibility (Bool).
Sky
- Adds a skybox to the scene. There are multiple sky component from skybox to more comple dome with volumetric cloud rendering etc.
- Main attributes: materialRef (AssetReference) or a list of textures for the cube map and sky box size.
Water
- Adds water to the scene. There are multiple water components from water plane to complex real-time water rendering.
- Main attributes: water position/height and size.
WebBrowser
- Creates a web browser (with 3D input etc.) render to the mesh surface (replacing the original material in that submesh).
- Main attributes: url (String), resolution (Float2), accept3DInput (Bool) etc.
Script
- Defines a script resource that should be loaded and executed.
- Main attributes: scriptRef (AssetReference), runMode (Int/Enum: Server, Client or Both), runOnLoad (Bool: if should be execute after load completes. If false application logic can execute the script.)
RigidBody
- Adds a rigid body object to the physics simulation world for collision & dynamics response. On the native Tundra client/server, the physics simulation world will always be created along with the scene if the PhysicsModule plugin is loaded. Web client does not currently simulate physics.
- If the rigid body is dynamic (mass > 0), the position & rotation in the entity's Placeable component will be updated after each simulation step
- The collision shape of the rigid body can either be a primitive like box, sphere, capsule, cylinder, or derived from rendering mesh data (trianglemesh or convex hull). The size attribute and the scale from the Placeable's transform are combined to find the final size for the collision shape.
- Main attributes: mass (Real), friction (Real), restitution (Real), linearVelocity (Float3), angularVelocity (Float3), shapeType (enum Int), size (Float3), collisionMeshRef (AssetReference)
For a more comprehensive list, see https://github.com/realXtend/tundra/wiki/Reserved-EC-IDs
This is the mapping of attribute type id to the type name of the available attribute types in Tundra.
- 1 : String
- 2 : Int
- 3 : Real
- 4 : Color
- 5 : Float2
- 6 : Float3
- 7 : Float4
- 8 : Bool
- 9 : UInt
- 10 : Quat
- 11 : AssetReference (1)
- 12 : AssetReferenceList
- 13 : EntityReference (1)
- 14 : QVariant (2)
- 15 : QVariantList
- 16 : Transform (pos, rot and scale vectors)
- 17 : QPoint (pretty much deprecated, use Float2)
(1) Essentially a string but has different semantics and there for a separate type to avoid confusion from app developers etc.
(2) QVariant is a Qt class that has various types. Over the wire these are always just converted to a string. This is not a relevant type to support from a generic design standpoint.