Scripting
This scripting guide shows how to implement and use a Script Component in the game engine, detailing the available functions in Lua.
Editor
How to implement a Script Component?
- Create a new project (in an empty folder) and save the current scene 
- Create an Entity and add to it a Script Component 
- Open the script from where you saved it, and the following should appear 
 1function on_ready()
 2    -- Add initialization code here
 3end
 4
 5function on_update(dt)
 6    -- Add update code here
 7end
 8
 9function on_exit()
10    -- Add cleanup code here
11end
The variables created as public with the following nomenclature, will appear on the inspector inside the Script Component, on Runtime mode:
1--[[export]] age = 10
Note
For now, if a variable is public, any change made from the inspector won’t apply to it.
Lua
Logging functions
The engine provides functions to register messages on the console with diferent levels of severity
- log(message) 
1log("This is an informative message")
- log_warning(message) 
1log("This is a warning message")
- log_error(message) 
1log("This is an error message")
- log_critical(message) 
1log("This is a critical message")
Input functions
1. Input.is_key_pressed(key) Verifies if a specific key is being pressed
1if Input.is_key_pressed(Input.keycode.A) then
2    log("The key A is being pressed")
3end
2. Input.is_mouse_button_pressed(button) Verifies if a mouse button is being pressed
1If Input.is_mouse_button_pressed(Input.mousecode.LEFT)
2then
3    log("The left mouse button is being pressed")
4end
3. Input.get_mouse_position() Gets the actual position of the mouse on screen
1local x, y = Input.get_mouse_position()
2log("Mouse position: " .. x .. ", " .. y)
Mathematics functions (GLM)
- Vectors
- 1.1. Vector2 Represents a vector2D - 1local vec2 = Vector2.new(1.0, 2.0) 2log("Vector2: " .. vec2.x .. ", " .. vec2.y) - 1.2. Vector3 Represents a vector3D - 1local vec3 = Vector3.new(1.0, 2.0, 3.0) 2log("Vector3: " .. vec3.x .. ", " .. vec3.y .. ", " .. vec3.z) - 1.3. Vector4 Represents a vector4D - 1local vec4 = Vector4.new(1.0, 2.0, 3.0, 4.0) 2log("Vector4: " .. vec4.x .. ", " .. vec4.y .. ", " .. vec4.z .. ", " .. vec4.w) 
 
- Matrix
- 2.1. Mat4 - 1local mat = Mat4() 2mat = mat:translate(Vector3(1.0, 2.0, 3.0)) 3log("Translated matrix") 
 
- Quaternions
- 3.1. Quaternion - 1local quat = Quaternion.new(1.0, 0.0, 0.0, 0.0) 2log("Quaternion: " .. quat.x .. ", " .. quat.y .. ", " .. quat.z .. ", " .. quat.w) 
 
Entity functions
Entities are objects in the scene that can have associated components
- Creation and destruction of Entities
- 1.1. current_scene.create_entity() Creates a new entity in the current scene - 1local entity = current_scene.create_entity() - 1.2. current_scene.destroy_entity(entity) Destroys an entity in the current scene - 1current_scene.destroy_entity(entity) 
 
Note
If needed to refer to the entity running the script, instead of using “entity:”, we use “self:” in the following functions. For instance, instead of entity:get_component(“ComponentName”), use self:get_component(“ComponentName”) to refer to the entity that contains the script.
- Components
- 2.1. Entity.add_component(componentName) Adds a component to the entity - 1entity:add_component("TransformComponent") - 2.2. Entity.get_component(componentName) Gets a component of the entity - 1local transform = entity:get_component("TransformComponent") - 2.3. Entity.has_component(componentName) Verifies if the entity has a specific component - 1if entity:has_component("TransformComponent") 2then 3 log("The entity has a transformation component") 4end - 2.4. Entity.remove_component(componentName) Deletes a component from the entity - 1entity:remove_component("TransformComponent") 
 
- Entity hierarchy
- 3.1. Entity.set_parent(parent) Sets the parent entity - 1entity:set_parent(parentEntity) - 3.2. Entity.get_parent() Gets the parent entity - 1local parent = entity:get_parent() - 3.3. Entity.get_child() Gets the first child of the entity - 1local child = entity:get_child() - 3.4. Entity.get_children() Gets all entity children - 1local children = entity:get_children() 
 
Components
1. TagComponent Stores a label for the entity
1local tag = entity:get_component("TagComponent")
2tag.tag = "Player"
2. TransformComponent Stores the position, rotation and scale of the entity
1local transform = entity:get_component("TransformComponent")
2transform.position = Vector3(1.0, 2.0, 3.0)
3. CameraComponent Represents a camera
1local camera = entity:get_component("CameraComponent")
4. MeshComponent Represents a 3D mesh
1local mesh = entity:get_component("MeshComponent")
5. MaterialComponent Represents a material
1local material = entity:get_component("MaterialComponent")
6. LightComponent Represents a light
1local light = entity:get_component("LightComponent")
2light.color = Vector3(1.0, 1.0, 1.0)
7. ScriptComponent Allows scripts to be attached to the entity
1local script = entity:get_component("ScriptComponent")
2script:call("update")
Scenes
1. current_scene.get_entity_by_name(name) Gets an entity by name
1local entity = current_scene.get_entity_by_name("Player")
2. current_scene.get_all_entities() Gets all entities in the current scene
1local entities = current_scene.get_all_entities()
Script Execution
1. LuaBackend.CreateScript(path) Creates a script from a file
1auto script = LuaBackend::CreateScript("path/to/script.lua");
2. LuaBackend.ExecuteScript(script) Executes a script
1LuaBackend::ExecuteScript(*script);