Unigine.World Class
This class provides functionality for the world script. It contains methods required for loading the world with all its nodes, managing a spatial tree and handling nodes collisions and intersections.
Loading of nodes on demand is managed via the AsyncQueue Class.
See also#
- AsyncQueue Class to manage loading nodes and other resources on demand.
- The Intersections article demonstrating how to use intersection-related functions
World Class
Enums
MOVING_IMMOVABLE_NODES_MODE#
Properties
bool UnpackNodeReferences#
bool AutoReloadNodeReferences#
float UpdateGridSize#
float Distance#
float Budget#
bool IsLoaded#
string ScriptName#
string Path#
bool ScriptExecute#
string PhysicsSettings#
string SoundSettings#
string RenderSettings#
string LoadWorldRequestPath#
bool IsLoadWorldRequested#
World.MOVING_IMMOVABLE_NODES_MODE MovingImmovableNodeMode#
- At run-time for procedural generation of levels. This may cause some freezing but won't affect performance much. Upon completion of the generation process you should enable warnings again.
- On world initialization, this will change world loading time but won't affect overall performance.
bool AsyncLoadNodeReferences#
Event<Node> EventNodeRemoved#
Usage Example
// implement the NodeRemoved event handler
void noderemoved_event_handler(Node node)
{
Log.Message("\Handling NodeRemoved event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections noderemoved_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventNodeRemoved.Connect(noderemoved_event_connections, noderemoved_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventNodeRemoved.Connect(noderemoved_event_connections, (Node node) => {
Log.Message("Handling NodeRemoved event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
noderemoved_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the NodeRemoved event with a handler function
World.EventNodeRemoved.Connect(noderemoved_event_handler);
// remove subscription to the NodeRemoved event later by the handler function
World.EventNodeRemoved.Disconnect(noderemoved_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection noderemoved_event_connection;
// subscribe to the NodeRemoved event with a lambda handler function and keeping the connection
noderemoved_event_connection = World.EventNodeRemoved.Connect((Node node) => {
Log.Message("Handling NodeRemoved event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
noderemoved_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
noderemoved_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
noderemoved_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring NodeRemoved events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventNodeRemoved.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventNodeRemoved.Enabled = true;
Event<Node> EventNodeAdded#
Usage Example
// implement the NodeAdded event handler
void nodeadded_event_handler(Node node)
{
Log.Message("\Handling NodeAdded event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections nodeadded_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventNodeAdded.Connect(nodeadded_event_connections, nodeadded_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventNodeAdded.Connect(nodeadded_event_connections, (Node node) => {
Log.Message("Handling NodeAdded event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
nodeadded_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the NodeAdded event with a handler function
World.EventNodeAdded.Connect(nodeadded_event_handler);
// remove subscription to the NodeAdded event later by the handler function
World.EventNodeAdded.Disconnect(nodeadded_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection nodeadded_event_connection;
// subscribe to the NodeAdded event with a lambda handler function and keeping the connection
nodeadded_event_connection = World.EventNodeAdded.Connect((Node node) => {
Log.Message("Handling NodeAdded event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
nodeadded_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
nodeadded_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
nodeadded_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring NodeAdded events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventNodeAdded.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventNodeAdded.Enabled = true;
Event EventPostWorldShutdown#
Usage Example
// implement the PostWorldShutdown event handler
void postworldshutdown_event_handler()
{
Log.Message("\Handling PostWorldShutdown event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections postworldshutdown_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPostWorldShutdown.Connect(postworldshutdown_event_connections, postworldshutdown_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPostWorldShutdown.Connect(postworldshutdown_event_connections, () => {
Log.Message("Handling PostWorldShutdown event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
postworldshutdown_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PostWorldShutdown event with a handler function
World.EventPostWorldShutdown.Connect(postworldshutdown_event_handler);
// remove subscription to the PostWorldShutdown event later by the handler function
World.EventPostWorldShutdown.Disconnect(postworldshutdown_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection postworldshutdown_event_connection;
// subscribe to the PostWorldShutdown event with a lambda handler function and keeping the connection
postworldshutdown_event_connection = World.EventPostWorldShutdown.Connect(() => {
Log.Message("Handling PostWorldShutdown event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
postworldshutdown_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
postworldshutdown_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
postworldshutdown_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PostWorldShutdown events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPostWorldShutdown.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPostWorldShutdown.Enabled = true;
Event EventPreWorldShutdown#
Usage Example
// implement the PreWorldShutdown event handler
void preworldshutdown_event_handler()
{
Log.Message("\Handling PreWorldShutdown event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections preworldshutdown_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPreWorldShutdown.Connect(preworldshutdown_event_connections, preworldshutdown_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPreWorldShutdown.Connect(preworldshutdown_event_connections, () => {
Log.Message("Handling PreWorldShutdown event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
preworldshutdown_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PreWorldShutdown event with a handler function
World.EventPreWorldShutdown.Connect(preworldshutdown_event_handler);
// remove subscription to the PreWorldShutdown event later by the handler function
World.EventPreWorldShutdown.Disconnect(preworldshutdown_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection preworldshutdown_event_connection;
// subscribe to the PreWorldShutdown event with a lambda handler function and keeping the connection
preworldshutdown_event_connection = World.EventPreWorldShutdown.Connect(() => {
Log.Message("Handling PreWorldShutdown event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
preworldshutdown_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
preworldshutdown_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
preworldshutdown_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PreWorldShutdown events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPreWorldShutdown.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPreWorldShutdown.Enabled = true;
Event EventPostWorldInit#
Usage Example
// implement the PostWorldInit event handler
void postworldinit_event_handler()
{
Log.Message("\Handling PostWorldInit event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections postworldinit_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPostWorldInit.Connect(postworldinit_event_connections, postworldinit_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPostWorldInit.Connect(postworldinit_event_connections, () => {
Log.Message("Handling PostWorldInit event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
postworldinit_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PostWorldInit event with a handler function
World.EventPostWorldInit.Connect(postworldinit_event_handler);
// remove subscription to the PostWorldInit event later by the handler function
World.EventPostWorldInit.Disconnect(postworldinit_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection postworldinit_event_connection;
// subscribe to the PostWorldInit event with a lambda handler function and keeping the connection
postworldinit_event_connection = World.EventPostWorldInit.Connect(() => {
Log.Message("Handling PostWorldInit event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
postworldinit_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
postworldinit_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
postworldinit_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PostWorldInit events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPostWorldInit.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPostWorldInit.Enabled = true;
Event EventPreWorldInit#
Usage Example
// implement the PreWorldInit event handler
void preworldinit_event_handler()
{
Log.Message("\Handling PreWorldInit event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections preworldinit_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPreWorldInit.Connect(preworldinit_event_connections, preworldinit_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPreWorldInit.Connect(preworldinit_event_connections, () => {
Log.Message("Handling PreWorldInit event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
preworldinit_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PreWorldInit event with a handler function
World.EventPreWorldInit.Connect(preworldinit_event_handler);
// remove subscription to the PreWorldInit event later by the handler function
World.EventPreWorldInit.Disconnect(preworldinit_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection preworldinit_event_connection;
// subscribe to the PreWorldInit event with a lambda handler function and keeping the connection
preworldinit_event_connection = World.EventPreWorldInit.Connect(() => {
Log.Message("Handling PreWorldInit event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
preworldinit_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
preworldinit_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
preworldinit_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PreWorldInit events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPreWorldInit.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPreWorldInit.Enabled = true;
Event<string, Node> EventPostNodeSave#
Usage Example
// implement the PostNodeSave event handler
void postnodesave_event_handler(string world_file_path, Node node)
{
Log.Message("\Handling PostNodeSave event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections postnodesave_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPostNodeSave.Connect(postnodesave_event_connections, postnodesave_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPostNodeSave.Connect(postnodesave_event_connections, (string world_file_path, Node node) => {
Log.Message("Handling PostNodeSave event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
postnodesave_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PostNodeSave event with a handler function
World.EventPostNodeSave.Connect(postnodesave_event_handler);
// remove subscription to the PostNodeSave event later by the handler function
World.EventPostNodeSave.Disconnect(postnodesave_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection postnodesave_event_connection;
// subscribe to the PostNodeSave event with a lambda handler function and keeping the connection
postnodesave_event_connection = World.EventPostNodeSave.Connect((string world_file_path, Node node) => {
Log.Message("Handling PostNodeSave event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
postnodesave_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
postnodesave_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
postnodesave_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PostNodeSave events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPostNodeSave.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPostNodeSave.Enabled = true;
Event<string, Node> EventPreNodeSave#
Usage Example
// implement the PreNodeSave event handler
void prenodesave_event_handler(string world_file_path, Node node)
{
Log.Message("\Handling PreNodeSave event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections prenodesave_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPreNodeSave.Connect(prenodesave_event_connections, prenodesave_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPreNodeSave.Connect(prenodesave_event_connections, (string world_file_path, Node node) => {
Log.Message("Handling PreNodeSave event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
prenodesave_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PreNodeSave event with a handler function
World.EventPreNodeSave.Connect(prenodesave_event_handler);
// remove subscription to the PreNodeSave event later by the handler function
World.EventPreNodeSave.Disconnect(prenodesave_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection prenodesave_event_connection;
// subscribe to the PreNodeSave event with a lambda handler function and keeping the connection
prenodesave_event_connection = World.EventPreNodeSave.Connect((string world_file_path, Node node) => {
Log.Message("Handling PreNodeSave event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
prenodesave_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
prenodesave_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
prenodesave_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PreNodeSave events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPreNodeSave.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPreNodeSave.Enabled = true;
Event<string> EventPostWorldClear#
Usage Example
// implement the PostWorldClear event handler
void postworldclear_event_handler(string world_file_path)
{
Log.Message("\Handling PostWorldClear event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections postworldclear_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPostWorldClear.Connect(postworldclear_event_connections, postworldclear_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPostWorldClear.Connect(postworldclear_event_connections, (string world_file_path) => {
Log.Message("Handling PostWorldClear event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
postworldclear_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PostWorldClear event with a handler function
World.EventPostWorldClear.Connect(postworldclear_event_handler);
// remove subscription to the PostWorldClear event later by the handler function
World.EventPostWorldClear.Disconnect(postworldclear_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection postworldclear_event_connection;
// subscribe to the PostWorldClear event with a lambda handler function and keeping the connection
postworldclear_event_connection = World.EventPostWorldClear.Connect((string world_file_path) => {
Log.Message("Handling PostWorldClear event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
postworldclear_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
postworldclear_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
postworldclear_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PostWorldClear events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPostWorldClear.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPostWorldClear.Enabled = true;
Event<string> EventPreWorldClear#
Usage Example
// implement the PreWorldClear event handler
void preworldclear_event_handler(string world_file_path)
{
Log.Message("\Handling PreWorldClear event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections preworldclear_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPreWorldClear.Connect(preworldclear_event_connections, preworldclear_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPreWorldClear.Connect(preworldclear_event_connections, (string world_file_path) => {
Log.Message("Handling PreWorldClear event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
preworldclear_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PreWorldClear event with a handler function
World.EventPreWorldClear.Connect(preworldclear_event_handler);
// remove subscription to the PreWorldClear event later by the handler function
World.EventPreWorldClear.Disconnect(preworldclear_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection preworldclear_event_connection;
// subscribe to the PreWorldClear event with a lambda handler function and keeping the connection
preworldclear_event_connection = World.EventPreWorldClear.Connect((string world_file_path) => {
Log.Message("Handling PreWorldClear event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
preworldclear_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
preworldclear_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
preworldclear_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PreWorldClear events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPreWorldClear.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPreWorldClear.Enabled = true;
Event<string> EventPostWorldSave#
Usage Example
// implement the PostWorldSave event handler
void postworldsave_event_handler(string world_file_path)
{
Log.Message("\Handling PostWorldSave event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections postworldsave_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPostWorldSave.Connect(postworldsave_event_connections, postworldsave_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPostWorldSave.Connect(postworldsave_event_connections, (string world_file_path) => {
Log.Message("Handling PostWorldSave event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
postworldsave_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PostWorldSave event with a handler function
World.EventPostWorldSave.Connect(postworldsave_event_handler);
// remove subscription to the PostWorldSave event later by the handler function
World.EventPostWorldSave.Disconnect(postworldsave_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection postworldsave_event_connection;
// subscribe to the PostWorldSave event with a lambda handler function and keeping the connection
postworldsave_event_connection = World.EventPostWorldSave.Connect((string world_file_path) => {
Log.Message("Handling PostWorldSave event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
postworldsave_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
postworldsave_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
postworldsave_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PostWorldSave events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPostWorldSave.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPostWorldSave.Enabled = true;
Event<string> EventPreWorldSave#
Usage Example
// implement the PreWorldSave event handler
void preworldsave_event_handler(string world_file_path)
{
Log.Message("\Handling PreWorldSave event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections preworldsave_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPreWorldSave.Connect(preworldsave_event_connections, preworldsave_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPreWorldSave.Connect(preworldsave_event_connections, (string world_file_path) => {
Log.Message("Handling PreWorldSave event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
preworldsave_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PreWorldSave event with a handler function
World.EventPreWorldSave.Connect(preworldsave_event_handler);
// remove subscription to the PreWorldSave event later by the handler function
World.EventPreWorldSave.Disconnect(preworldsave_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection preworldsave_event_connection;
// subscribe to the PreWorldSave event with a lambda handler function and keeping the connection
preworldsave_event_connection = World.EventPreWorldSave.Connect((string world_file_path) => {
Log.Message("Handling PreWorldSave event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
preworldsave_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
preworldsave_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
preworldsave_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PreWorldSave events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPreWorldSave.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPreWorldSave.Enabled = true;
Event<string> EventPostWorldLoad#
Usage Example
// implement the PostWorldLoad event handler
void postworldload_event_handler(string world_file_path)
{
Log.Message("\Handling PostWorldLoad event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections postworldload_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPostWorldLoad.Connect(postworldload_event_connections, postworldload_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPostWorldLoad.Connect(postworldload_event_connections, (string world_file_path) => {
Log.Message("Handling PostWorldLoad event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
postworldload_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PostWorldLoad event with a handler function
World.EventPostWorldLoad.Connect(postworldload_event_handler);
// remove subscription to the PostWorldLoad event later by the handler function
World.EventPostWorldLoad.Disconnect(postworldload_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection postworldload_event_connection;
// subscribe to the PostWorldLoad event with a lambda handler function and keeping the connection
postworldload_event_connection = World.EventPostWorldLoad.Connect((string world_file_path) => {
Log.Message("Handling PostWorldLoad event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
postworldload_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
postworldload_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
postworldload_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PostWorldLoad events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPostWorldLoad.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPostWorldLoad.Enabled = true;
Event<string> EventPreWorldLoad#
Usage Example
// implement the PreWorldLoad event handler
void preworldload_event_handler(string world_file_path)
{
Log.Message("\Handling PreWorldLoad event\n");
}
//////////////////////////////////////////////////////////////////////////////
// 1. Multiple subscriptions can be linked to an EventConnections instance
// class that you can use later to remove all these subscriptions at once
//////////////////////////////////////////////////////////////////////////////
// create an instance of the EventConnections class
EventConnections preworldload_event_connections = new EventConnections();
// link to this instance when subscribing to an event (subscription to various events can be linked)
World.EventPreWorldLoad.Connect(preworldload_event_connections, preworldload_event_handler);
// other subscriptions are also linked to this EventConnections instance
// (e.g. you can subscribe using lambdas)
World.EventPreWorldLoad.Connect(preworldload_event_connections, (string world_file_path) => {
Log.Message("Handling PreWorldLoad event lambda\n");
}
);
// later all of these linked subscriptions can be removed with a single line
preworldload_event_connections.DisconnectAll();
//////////////////////////////////////////////////////////////////////////////
// 2. You can subscribe and unsubscribe via the handler function directly
//////////////////////////////////////////////////////////////////////////////
// subscribe to the PreWorldLoad event with a handler function
World.EventPreWorldLoad.Connect(preworldload_event_handler);
// remove subscription to the PreWorldLoad event later by the handler function
World.EventPreWorldLoad.Disconnect(preworldload_event_handler);
//////////////////////////////////////////////////////////////////////////////
// 3. Subscribe to an event and unsubscribe later via an EventConnection instance
//////////////////////////////////////////////////////////////////////////////
// define a connection to be used to unsubscribe later
EventConnection preworldload_event_connection;
// subscribe to the PreWorldLoad event with a lambda handler function and keeping the connection
preworldload_event_connection = World.EventPreWorldLoad.Connect((string world_file_path) => {
Log.Message("Handling PreWorldLoad event lambda\n");
}
);
// ...
// you can temporarily disable a particular event connection
preworldload_event_connection.Enabled = false;
// ... perform certain actions
// and enable it back when necessary
preworldload_event_connection.Enabled = true;
// ...
// remove the subscription later using the saved connection
preworldload_event_connection.Disconnect();
//////////////////////////////////////////////////////////////////////////////
// 4. Ignoring PreWorldLoad events when necessary
//////////////////////////////////////////////////////////////////////////////
// you can temporarily disable the event to perform certain actions without triggering it
World.EventPreWorldLoad.Enabled = false;
// ... actions to be performed
// and enable it back when necessary
World.EventPreWorldLoad.Enabled = true;
Members
bool GetCollision ( WorldBoundBox bb, Object[] OUT_objects ) #
Searches for all collider objects within a given bounding box.Arguments
- WorldBoundBox bb - Bounding box.
- Object[]
OUT_objects - Array with collider objects' smart pointers.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
1 if collider objects are found; otherwise, 0.bool GetCollision ( WorldBoundSphere bs, Object[] OUT_objects ) #
Searches for all collider objects within a given bounding sphere.Arguments
- WorldBoundSphere bs - Bounding sphere.
- Object[]
OUT_objects - Array with collider objects' smart pointers.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
1 if collider objects are found; otherwise, 0.bool GetCollision ( WorldBoundFrustum bf, Object[] OUT_objects ) #
Searches for all collider objects within a given bounding frustum.Arguments
- WorldBoundFrustum bf - Bounding frustum.
- Object[]
OUT_objects - Array with collider objects' smart pointers.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
1 if collider objects are found; otherwise, 0.bool GetCollision ( vec3 p0, vec3 p1, Object[] OUT_objects ) #
Performs tracing from the p0 point to the p1 point to find all collider objects intersected by the line. This function detects intersection with surfaces (polygons) of mesh and terrain objects.
Collisions with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Collision flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - The start point coordinates.
- vec3 p1 - The end point coordinates.
- Object[]
OUT_objects - Array with collider objects' smart pointers.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
1 if collider objects are found; otherwise, 0.void SetData ( string name, string data ) #
Sets user data associated with the world with the specified key. In the *.world file, the data is set in the data tag with the specified key.Arguments
- string name - String containing a key identifying user data to be stored in the *.world file.
The "editor_data" key is reserved for the UnigineEditor.
- string data - New user data.
string GetData ( string name ) #
Returns user string data associated with the world by the specified key. This string is written directly into the data tag of the *.world file with the specified key.Arguments
- string name - String containing a key identifying user data stored in the *.world file.
The "editor_data" key is reserved for the UnigineEditor.
Return value
User string data.bool HasData ( string name ) #
Checks whether user string data associated with the world by the specified key is stored in the data tag of the *.world file.Arguments
- string name - String containing a key identifying user data stored in the *.world file.
The "editor_data" key is reserved for the UnigineEditor.
Return value
true if user string data associated with the world by the specified key is stored in the data tag of the *.world file; otherwise, false.void RemoveData ( string name ) #
Removes user string data associated with the world by the specified key. This string is stored in the data tag of the *.world file with the specified key.Arguments
- string name - String containing a key identifying user data stored in the *.world file.
The "editor_data" key is reserved for the UnigineEditor.
Object GetIntersection ( vec3 p0, vec3 p1, int mask ) #
Performs tracing from the p0 point to the p1 point to find the first object intersected by the line. This function detects intersection with surfaces (polygons) of meshes. An intersection can be found only if an object has a matching intersection mask.
Intersections with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Intersection flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - Line start point coordinates.
- vec3 p1 - Line end point coordinates.
- int mask - Intersection mask. If 0 is passed, the function will return NULL.
Return value
Intersected object.Object GetIntersection ( vec3 p0, vec3 p1, int mask, Node[] exclude ) #
Performs tracing from the p0 point to the p1 point to find the first object intersected by the line (except for the ones passed in the exclude list). This function detects intersection with surfaces (polygons) of meshes. An intersection can be found only if an object has a matching intersection mask.
Intersections with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Intersection flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - Line start point coordinates.
- vec3 p1 - Line end point coordinates.
- int mask - Intersection mask. If 0 is passed, the function will return NULL.
- Node[] exclude - List of nodes to be ignored when searching for intersection by the traced line.
Return value
The first intersected object found at the line (except for the ones passed in the exclude list); nullptr if there was no intersection.Object GetIntersection ( vec3 p0, vec3 p1, int mask, WorldIntersection intersection ) #
Performs tracing from the p0 point to the p1 point to find the first object intersecting the line. This function detects intersection with surfaces (polygons) of meshes. An intersection can be found only if an object is matching the intersection mask.
Intersections with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Intersection flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - Coordinates of the line start point.
- vec3 p1 - Coordinates of the line end point.
- int mask - Intersection mask. If 0 is passed, the function will return NULL.
- WorldIntersection intersection - WorldIntersection object to be filled.
Return value
First intersected object.Object GetIntersection ( vec3 p0, vec3 p1, int mask, WorldIntersectionNormal intersection ) #
Performs tracing from the p0 point to the p1 point to find the first object intersecting the line. This function detects intersection with surfaces (polygons) of meshes. An intersection can be found only if an object is matching the intersection mask.
Intersections with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Intersection flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - Coordinates of the line start point.
- vec3 p1 - Coordinates of the line end point.
- int mask - Intersection mask. If 0 is passed, the function will return NULL.
- WorldIntersectionNormal intersection - WorldIntersectionNormal object to be filled.
Return value
First intersected object.Object GetIntersection ( vec3 p0, vec3 p1, int mask, WorldIntersectionTexCoord intersection ) #
Performs tracing from the p0 point to the p1 point to find the first object intersecting the line. This function detects intersection with surfaces (polygons) of meshes. An intersection can be found only if an object is matching the intersection mask.
Intersections with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Intersection flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - Coordinates of the line start point.
- vec3 p1 - Coordinates of the line end point.
- int mask - Intersection mask. If 0 is passed, the function will return NULL.
- WorldIntersectionTexCoord intersection - WorldIntersectionTexCoord object to be filled.
Return value
First intersected object.Object GetIntersection ( vec3 p0, vec3 p1, int mask, Node[] exclude, WorldIntersection intersection ) #
Performs tracing from the p0 point to the p1 point to find the first object intersecting the line. This function detects intersection with surfaces (polygons) of meshes. An intersection can be found only if an object is matching the intersection mask.
Intersections with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Intersection flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - Coordinates of the line start point.
- vec3 p1 - Coordinates of the line end point.
- int mask - Intersection mask. If 0 is passed, the function will return NULL.
- Node[] exclude - The list of nodes to be excluded.
- WorldIntersection intersection - WorldIntersection object to be filled.
Return value
First intersected object.Object GetIntersection ( vec3 p0, vec3 p1, int mask, Node[] exclude, WorldIntersectionNormal intersection ) #
Performs tracing from the p0 point to the p1 point to find the first object intersecting the line. This function detects intersection with surfaces (polygons) of meshes. An intersection can be found only if an object is matching the intersection mask.
Intersections with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Intersection flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - Coordinates of the line start point.
- vec3 p1 - Coordinates of the line end point.
- int mask - Intersection mask. If 0 is passed, the function will return NULL.
- Node[] exclude - The list of nodes to be excluded.
- WorldIntersectionNormal intersection - WorldIntersectionNormal object to be filled.
Return value
First intersected object.Object GetIntersection ( vec3 p0, vec3 p1, int mask, Node[] exclude, WorldIntersectionTexCoord intersection ) #
Performs tracing from the p0 point to the p1 point to find the first object intersected by the line. This function detects intersection with surfaces (polygons) of meshes. An intersection can be found only if an object is matching the intersection mask.
Intersections with the surface can be found only if the following conditions are fulfilled:
- The surface is enabled.
- Per-surface Intersection flag is enabled.
- The surface has a material assigned.
Arguments
- vec3 p0 - Coordinates of the line start point.
- vec3 p1 - Coordinates of the line end point.
- int mask - Intersection mask. If 0 is passed, the function will return NULL.
- Node[] exclude - The list of nodes to be excluded.
- WorldIntersectionTexCoord intersection - WorldIntersectionTexCoord object to be filled.
Return value
First intersected object.bool GetIntersection ( vec3 p0, vec3 p1, Object[] OUT_objects, bool check_surface_flags = true ) #
Performs tracing from the p0 point to the p1 point to find objects intersected by the line. This function detects intersection with objects' bounds.
Arguments
- vec3 p0 - Coordinates of the line start point.
- vec3 p1 - Coordinates of the line end point.
- Object[]
OUT_objects - Array of intersected objects.This output buffer is to be filled by the Engine as a result of executing the method.
- bool check_surface_flags - true if surfaceIntersection flags are to be taken into account when checking for intersections with objects; otherwise, false. When set to true objects with surface Intersection flags disabled (default setting) will be ignored as non-intersectable.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundBox bb, Object[] OUT_objects ) #
Searches for intersections with objects that are found in a given bounding box.
Arguments
- WorldBoundBox bb - Bounding box where intersection search will be performed.
- Object[]
OUT_objects - Array of intersected objects.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundBox bb, Node[] OUT_nodes ) #
Searches for intersections with nodes that are found in a given bounding box.
Arguments
- WorldBoundBox bb - Bounding box where intersection search will be performed.
- Node[]
OUT_nodes - Array of intersected nodes.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundBox bb, Node.TYPE type, Node[] OUT_nodes ) #
Searches for intersections with specified type of nodes that are found in a given bounding box.
Arguments
- WorldBoundBox bb - Bounding box where intersection search will be performed.
- Node.TYPE type - Node type filter. Only the nodes of the specified type will be checked.
- Node[]
OUT_nodes - Array of intersected nodes.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundSphere bs, Object[] OUT_objects ) #
Searches for intersections with objects that are found in a given bounding sphere.
Arguments
- WorldBoundSphere bs - Bounding sphere where intersection search will be performed.
- Object[]
OUT_objects - Array of intersected objects.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundSphere bs, Node[] OUT_nodes ) #
Searches for intersections with nodes that are found in a given bounding sphere.
Arguments
- WorldBoundSphere bs - Bounding sphere where intersection search will be performed.
- Node[]
OUT_nodes - Array of intersected nodes.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundSphere bs, Node.TYPE type, Node[] OUT_nodes ) #
Searches for intersections with nodes of the specified type that are found in a given bounding sphere.
Arguments
- WorldBoundSphere bs - Bounding sphere where intersection search will be performed.
- Node.TYPE type - Node type filter. Only the nodes of the specified type will be checked.
- Node[]
OUT_nodes - Array of intersected nodes.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundFrustum bf, Object[] OUT_objects ) #
Searches for intersections with Objects that are found in a given bounding frustum. This method catches all objects independent of their visibility (i.e., if an object is disabled, any of its LODs are disabled, or it is out of the visibility distance range, but is located within the bounding frustum, the intersection shall be detected). To check for intersections while taking into account the visibility aspect, use getVisibleIntersection(). Check the usage example applying this method.
Arguments
- WorldBoundFrustum bf - Bounding frustum where intersection search will be performed.
- Object[]
OUT_objects - Array of intersected objects.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundFrustum bf, Node.TYPE type, Node[] OUT_nodes ) #
Searches for intersections with nodes of the specified type that are found in a given bounding frustum. This method catches all nodes of the specified type independent of their visibility (i.e., if an object is disabled, any of its LODs are disabled, or it is out of the visibility distance range, but is located within the bounding frustum, the intersection shall be detected). To check for intersections while taking into account the visibility aspect, use getVisibleIntersection().
Arguments
- WorldBoundFrustum bf - Bounding frustum where intersection search will be performed.
- Node.TYPE type - Node type filter. Only the nodes of the specified type will be checked.
- Node[]
OUT_nodes - Array of intersected nodes.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetIntersection ( WorldBoundFrustum bf, Node[] OUT_nodes ) #
Searches for intersections with nodes of the specified type that are found in a given bounding frustum. This method catches all nodes independent of their visibility (i.e., if an object is disabled, any of its LODs are disabled, or it is out of the visibility distance range, but is located within the bounding frustum, the intersection shall be detected). To check for intersections while taking into account the visibility aspect, use getVisibleIntersection().
Arguments
- WorldBoundFrustum bf - Bounding frustum where intersection search will be performed.
- Node[]
OUT_nodes - Array of intersected nodes.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if intersections are found; otherwise, false.bool GetVisibleIntersection ( vec3 camera, WorldBoundFrustum bf, Object[] OUT_objects, float max_distance ) #
Searches for intersections with objects inside a given bounding frustum that are visible to the specified camera position, i.e. either of its LODs is within the visibility distance distance. Unlike the getIntersection()method, this one takes the "visibility" concept into account (hidden objects or the ones that are too far away won't be found). Check this usage example for more details.Arguments
- vec3 camera - Position of the camera from which the visibility distance to objects is checked.
- WorldBoundFrustum bf - Bounding frustum inside which intersection search is performed.
- Object[]
OUT_objects - Array of intersected objects.This output buffer is to be filled by the Engine as a result of executing the method.
- float max_distance - Maximum visibility distance for objects, in units. If the distance from the specified camera position to an object exceeds this limit, the intersection is not registered even if the node is within the specified bounding frustum.
Return value
true if at least one intersection is found; otherwise, false.bool GetVisibleIntersection ( vec3 camera, WorldBoundFrustum bf, Node.TYPE type, Node[] OUT_nodes, float max_distance ) #
Searches for intersections with nodes inside a given bounding frustum that are visible to the specified camera position, i.e. either of its LODs is within the visibility distance distance. Unlike the getIntersection()method, this one takes the "visibility" concept into account (hidden nodes or the ones that are too far away won't be found). Check this usage example for more details.
Arguments
- vec3 camera - Position of the camera from which the visibility distance to nodes is checked.
- WorldBoundFrustum bf - Bounding frustum inside which intersection search is performed.
- Node.TYPE type - Node type (one of the NODE_* variables); set it to -1 if you won't use this filter.
- Node[]
OUT_nodes - Array of intersected nodes.This output buffer is to be filled by the Engine as a result of executing the method.
- float max_distance - Maximum visibility distance for nodes, in units. If the distance from the specified camera position to a node exceeds this limit, the intersection is not registered even if the node is within the specified bounding frustum.
Return value
true if at least one intersection is found; otherwise, false.bool LoadWorld ( string path ) #
Loads a world from the specified file path and replaces the current world with it. The world is not loaded immediately — loading starts at the beginning of the next frame, while the current world is unloaded at the end of the current frame.Arguments
- string path - Path to the file describing the world.
Return value
true if the world is loaded successfully; otherwise, false.bool LoadWorld ( string path, bool partial_path ) #
Loads a world from the specified file path and replaces the current world with it. The world is not loaded immediately — loading starts at the beginning of the next frame, while the current world is unloaded at the end of the current frame.Arguments
- string path - Path to the file describing the world.
- bool partial_path - true if the path to the world file is partial; or false if it is a full path.
Return value
true if the world is loaded successfully; otherwise, false.bool LoadWorldForce ( string path ) #
Loads a world from the specified file path and replaces the current world with it. The world is loaded immediately, breaking the Execution Sequence, therefore should be used either before Engine::update() or after Engine::swap(). If called in Engine::update(), the Execution Sequence will be as follows: update() before calling loadWorldForce(), loadWorldForce(), shutdown(), continuation of update() from the place of interruption, postUpdate(), swap(), init(), etc. This function is recommended for the Editor-related use.Arguments
- string path - Path to the file describing the world.
Return value
true if the world is loaded successfully; otherwise, false.bool LoadWorldForce ( string path, bool partial_path ) #
Loads a world from the specified file path and replaces the current world with it. The world is loaded immediately, breaking the Execution Sequence, therefore should be used either before Engine::update() or after Engine::swap(). If called in Engine::update(), the Execution Sequence will be as follows: update() before calling loadWorldForce(), loadWorldForce(), shutdown(), continuation of update() from the place of interruption, postUpdate(), swap(), init(), etc. This function is recommended for the Editor-related use.Arguments
- string path - Path to the file describing the world.
- bool partial_path - true if the path to the world file is partial; or false if it is a full path.
Return value
true if the world is loaded successfully; otherwise, false.bool SaveWorld ( ) #
Saves the World.Return value
true, if the world has been saved successfully; otherwise false.bool SaveWorld ( string path ) #
Saves the world to the specified location.Arguments
- string path - Path to where the world is going to be saved.
Return value
true, if the world has been saved successfully; otherwise false.bool ReloadWorld ( ) #
Reloads the World.Return value
true, if the world has been reloaded successfully; otherwise false.bool QuitWorld ( ) #
Closes the World.Return value
true, if the world has been quit successfully; otherwise false.bool AddWorld ( string name ) #
Loads a world from a file and adds it to the current World.Arguments
- string name - Name of the file describing the world.
Return value
1 if the world is loaded and added successfully; otherwise, 0.bool IsNode ( int id ) #
Checks if a node with a given ID exists in the World.Arguments
- int id - Node ID.
Return value
true if the node with the given ID exists; otherwise, false.void GetNodes ( Node[] OUT_nodes, bool expand_node_reference = true, bool expand_world_clutter = true ) #
Collects all instances of all nodes (either loaded from the *.world file or created dynamically at run time), including cache, Node Reference internals, World Clutters contents (if the corresponding flags are set) and puts them to the specified output list.Arguments
- Node[]
OUT_nodes - Array with node smart pointers.This output buffer is to be filled by the Engine as a result of executing the method.
- bool expand_node_reference - true to get nodes contained in NodeReferences; otherwise, false.
- bool expand_world_clutter - true to get nodes contained in WorldClutters; otherwise, false.
Node LoadNode ( string file_path, bool cache = 1 ) #
Loads a node (or a hierarchy of nodes) from a .node / .fbx file. If the node is loaded successfully, it is managed by the current world (its Lifetime is World).Cached nodes remain in the memory. If you don't intend to load more node references from a certain *.node asset, set the cache argument to 0 or you can delete cached nodes from the list of world nodes afterwards by using the destroyCacheNode() method.
Arguments
- string file_path - Path to the *.node file.
- bool cache - true to use caching of nodes, false not to use.
Return value
Loaded node; NULL if the node cannot be loaded.bool LoadNodes ( string file_path, Node[] OUT_nodes ) #
Loads nodes from a file.Arguments
- string file_path - Path to the *.node file.
- Node[]
OUT_nodes - Array of nodes' smart pointers to which the loaded nodes are appended.This output buffer is to be filled by the Engine as a result of executing the method.
Return value
true if the nodes are loaded successfully; otherwise, false.bool SaveNode ( string file_path, Node node, bool binary = 0 ) #
Saves a given node to a file with due regard for its local transformation.Arguments
- string file_path - Path to the *.node file.
- Node node - Pointer to the node to save.
- bool binary - If set to true, the node is saved to the binary *.xml. This file cannot be read, but using it speeds up the saving of the node and requires less disk space.
Return value
true if the node is saved successfully; otherwise, false.bool SaveNodes ( string file_path, Node[] nodes, bool binary = 0 ) #
Saves nodes to a file.Arguments
- string file_path - Path to the *.node file.
- Node[] nodes - Array of nodes' smart pointers to be saved.
- bool binary - If set to true, the node is saved to the binary *.xml. This file cannot be read, but using it speeds up the saving of the node and requires less disk space.
Return value
true if the nodes are saved successfully; otherwise, false.void UpdateSpatial ( ) #
Updates the node BSP (binary space partitioning) tree.
The engine calls this method automatically each frame after the world script update() code is executed. As a new node becomes a part of the BSP tree only after this method is called, all engine subsystems (renderer, physics, sound, pathfinding, collisions, intersections, etc.) can process this node only in the next frame. If you need the subsystem to process the node in the very first frame, you can call the updateSpatial() method manually. The engine will call this method automatically after the update() code is executed anyways.
Node GetNodeByID ( int node_id ) #
Returns a node by its identifier if it exists.Arguments
- int node_id - Node ID.
Return value
Node, if it exists in the world; otherwise, null.Node GetNodeByName ( string name ) #
Returns a node by its name if it exists. If the world contains multiple nodes having the same name, only the first one found shall be returned. To get all nodes having the same name, use the getNodesByName() method.Arguments
- string name - Node name.
Return value
Node, if it exists in the world; otherwise, null.void GetNodesByName ( string name, Node[] OUT_nodes ) #
Generates a list of nodes in the world with a given name and puts it to nodes.Arguments
- string name - Node name.
- Node[]
OUT_nodes - List of nodes with the given name (if any); otherwise, null.This output buffer is to be filled by the Engine as a result of executing the method.
Node GetNodeByType ( int type ) #
Returns the first node of the specified type in the World. Hidden and system nodes are ignored.Arguments
- int type - Node type identifier, one of the NODE_* values.
Return value
First node of the specified type, if it exists in the world; otherwise, null.void GetNodesByType ( int type, Node[] OUT_nodes ) #
Generates a list of nodes of the specified type in the world and puts it to nodes. Hidden and system nodes are ignored.Arguments
- int type - Node type identifier, one of the NODE_* values.
- Node[]
OUT_nodes - List of nodes of the given type (if any); otherwise, null.This output buffer is to be filled by the Engine as a result of executing the method.
bool IsNode ( string name ) #
Checks if a node with a given name exists in the World.Arguments
- string name - Node name.
Return value
true if a node with the specified name exists in the world; otherwise, false.void ClearBindings ( ) #
Clears internal buffers with pointers and instances. This function is used for proper cloning of objects with hierarchies, for example, bodies and joints. Should be called before cloning.void GetRootNodes ( Node[] OUT_nodes ) #
Gets all root nodes in the world hierarchy and puts them to nodes. Doesn't include cached nodes.Arguments
- Node[]
OUT_nodes - Array, to which all root nodes of the world hierarchy are to be put.This output buffer is to be filled by the Engine as a result of executing the method.
int GetRootNodeIndex ( Node node ) #
Returns the index for the specified root node, that belongs to the world hierarchy.Arguments
- Node node - Root node, for which an index is to be obtained.
Return value
Index of the specified root node if it exists; otherwise, -1.void SetRootNodeIndex ( Node node, int index ) #
Sets a new index for the specified root node, that belongs to the world hierarchy.Arguments
- Node node - Root node, for which a new index is to be set.
- int index - New index to be set for the specified root node.
void SetNodeIdSeed ( uint seed ) #
Sets a seed value for random generation of a node ID. This method is used for deterministic generation.Arguments
- uint seed - A seed value.
void SetNodeIdRange ( int from, int to ) #
Sets a range for random generation of a node ID. This method can be used, for example, to generate IDs for nodes divided in several groups: within a group, IDs will be generated in a separate range.Arguments
- int from - Beginning of the range.
- int to - End of the range.
void FindNodes ( FindNodeCallback find_node_callback ) #
Arguments
- FindNodeCallback find_node_callback
bool RemoveNodeFile ( string file_path ) #
Clears cached nodes for the given *.node file and removes all related Node References from the scene.When trying to access cached nodes, keep in mind the following:
- if the node was loaded by the name — the node gets stored in the cache by its name;
- if the node was loaded from the parent Node Reference — the node is stored in the cache by its GUID.
Node node = World.LoadNode(file_name);
// change something in the node...
World.SaveNode(file_name, node);
// clear cache by the name and reload all node references associated with this source
World.RemoveNodeFile(file_name);
// clear cache by the GUID (if this node is inside another Node Reference) and reload all node references associated with this source
World.RemoveNodeFile("guid://" + FileSystem.GetGUID("file_name").GetString());
Arguments
- string file_path - Path to the *.node file.
Return value
true if nodes for the given *.node file were successfully removed from cache with related Node References removed from the scene; otherwise, false.bool RemoveNodeFile ( UGUID file_guid ) #
Clears cached nodes for the given *.node file and removes all related Node References from the scene.When trying to access cached nodes, keep in mind the following:
- if the node was loaded by the name — the node gets stored in the cache by its name;
- if the node was loaded from the parent Node Reference — the node is stored in the cache by its GUID.
Node node = World.LoadNode(file_name);
// change something in the node...
World.SaveNode(file_name, node);
// clear cache by the name and reload all node references associated with this source
World.RemoveNodeFile(file_name);
// clear cache by the GUID (if this node is inside another Node Reference) and reload all node references associated with this source
World.RemoveNodeFile("guid://" + FileSystem.GetGUID("file_name").GetString());
Arguments
- UGUID file_guid - GUID of the *.node file.
Return value
true if nodes for the given *.node file were successfully removed from cache with related Node References removed from the scene; otherwise, false.bool ReloadNodeFile ( string file_path ) #
Clears cached nodes for the given *.node file and reloads all related Node References in the scene.When trying to access cached nodes, keep in mind the following:
- if the node was loaded by the name — the node gets stored in the cache by its name;
- if the node was loaded from the parent Node Reference — the node is stored in the cache by its GUID.
Node node = World.LoadNode(file_name);
// change something in the node...
World.SaveNode(file_name, node);
// clear cache by the name and reload all node references associated with this source
World.ReloadNodeFile(file_name);
// clear cache by the GUID (if this node is inside another Node Reference) and reload all node references associated with this source
World.ReloadNodeFile("guid://" + FileSystem.GetGUID("file_name").GetString());
Arguments
- string file_path - Path to the *.node file.
Return value
true if nodes for the given *.node file were successfully removed from cache and reloaded from the source file; otherwise, false.bool ReloadNodeFile ( UGUID file_guid ) #
Clears cached nodes for the given *.node file and reloads all related Node References in the scene.When trying to access cached nodes, keep in mind the following:
- if the node was loaded by the name — the node gets stored in the cache by its name;
- if the node was loaded from the parent Node Reference — the node is stored in the cache by its GUID.
Node node = World.LoadNode(file_name);
// change something in the node...
World.SaveNode(file_name, node);
// clear cache by the name and reload all node references associated with this source
World.ReloadNodeFile(file_name);
// clear cache by the GUID (if this node is inside another Node Reference) and reload all node references associated with this source
World.ReloadNodeFile("guid://" + FileSystem.GetGUID("file_name").GetString());
Arguments
- UGUID file_guid - GUID of the *.node file.
Return value
true if nodes for the given *.node file were successfully removed from cache and reloaded from the source file; otherwise, false.bool DestroyCacheNode ( string file_path ) #
Clears cached nodes of the given node file.When trying to access cached nodes, keep in mind the following:
- if the node was loaded by the name — the node gets stored in the cache by its name;
- if the node was loaded from the parent Node Reference — the node is stored in the cache by its GUID.
Node node = World.LoadNode(file_name);
// change something in the node...
World.SaveNode(file_name, node);
// clear cache by the name
World.DestroyCacheNode(file_name);
// clear cache by the GUID (if this node is inside another node reference)
World.DestroyCacheNode("guid://" + FileSystem.GetGUID("file_name").GetString());
// reload the node
node.DeleteForce();
node = World.LoadNode(file_name);
Arguments
- string file_path - Path to the *.node file.
Return value
true if nodes for the given *.node file were successfully removed from cache; otherwise, false.bool DestroyCacheNode ( UGUID file_guid ) #
Clears cached nodes of the given node file.When trying to access cached nodes, keep in mind the following:
- if the node was loaded by the name — the node gets stored in the cache by its name;
- if the node was loaded from the parent Node Reference — the node is stored in the cache by its GUID.
Node node = World.LoadNode(file_name);
// change something in the node...
World.SaveNode(file_name, node);
// clear cache by the name
World.DestroyCacheNode(file_name);
// clear cache by the GUID (if this node is inside another node reference)
World.DestroyCacheNode("guid://" + FileSystem.GetGUID("file_name").GetString());
// reload the node
node.DeleteForce();
node = World.LoadNode(file_name);
Arguments
- UGUID file_guid - GUID of the *.node file.