From 6256da58581bbb5f618e60b7373b4e6332d8f68a Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 20 Jul 2024 16:01:24 +0300 Subject: [PATCH 01/17] Refactor panthera animation/prev animation handling, add layer support, rename panthera_system -> panthera_internal --- docs_editor/getting_started.md | 7 + example/test_layer/test_layer.collection | 39 +++ example/test_layer/test_layer.gui | 307 ++++++++++++++++++ example/test_layer/test_layer.gui_script | 8 + panthera/adapters/adapter_go.lua | 41 ++- panthera/adapters/adapter_gui.lua | 9 +- panthera/annotations.lua | 4 +- panthera/panthera.lua | 101 +++--- ...thera_system.lua => panthera_internal.lua} | 0 resources/test_layer.json | 1 + 10 files changed, 458 insertions(+), 59 deletions(-) create mode 100644 example/test_layer/test_layer.collection create mode 100644 example/test_layer/test_layer.gui create mode 100644 example/test_layer/test_layer.gui_script rename panthera/{panthera_system.lua => panthera_internal.lua} (100%) create mode 100644 resources/test_layer.json diff --git a/docs_editor/getting_started.md b/docs_editor/getting_started.md index 7ec759f..11bf79a 100644 --- a/docs_editor/getting_started.md +++ b/docs_editor/getting_started.md @@ -43,6 +43,7 @@ Quickly dive into creating animations with **Panthera Editor 2.0** using this st - [Adjust Gizmo Settings](#adjust-gizmo-settings) * [Scene Gizmo Settings](#scene-gizmo-settings) * [Timeline Gizmo Settings](#timeline-gizmo-settings) +- [Adjust Font Size](#adjust-font-size) - [Using Hotkeys](#using-hotkeys) # Important Notes @@ -319,6 +320,12 @@ To discard changes in the Properties panel, follow these steps: > Note: You can use "Reset all" button in the Properties panel to reset all the properties to the initial state. If there are no changed properties., the node will be reset to the initial state. +## Set Empty or Default Value + +To set the empty or default value for the property, follow these steps: + +1. Right click on the property name in the Properties panel. +2. Select "Set Default". # Working with Timeline Keys diff --git a/example/test_layer/test_layer.collection b/example/test_layer/test_layer.collection new file mode 100644 index 0000000..72bd584 --- /dev/null +++ b/example/test_layer/test_layer.collection @@ -0,0 +1,39 @@ +name: "test_layer" +scale_along_z: 0 +embedded_instances { + id: "go" + data: "components {\n" + " id: \"test_layer\"\n" + " component: \"/example/test_layer/test_layer.gui\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + " property_decls {\n" + " }\n" + "}\n" + "" + position { + x: 0.0 + y: 0.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} diff --git a/example/test_layer/test_layer.gui b/example/test_layer/test_layer.gui new file mode 100644 index 0000000..3f816a1 --- /dev/null +++ b/example/test_layer/test_layer.gui @@ -0,0 +1,307 @@ +script: "/example/test_layer/test_layer.gui_script" +background_color { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 +} +nodes { + position { + x: 489.0 + y: 330.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 0.5 + y: 0.5 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "" + id: "root" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: false + material: "" +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 300.0 + y: 400.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.2 + y: 0.0 + z: 0.2 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "" + id: "card_1" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "root" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 268.0 + y: 370.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "" + id: "inner_1" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "card_1" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 245.0 + y: -55.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 300.0 + y: 400.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 0.4 + z: 0.4 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "" + id: "card_2" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "root" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 268.0 + y: 370.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "" + id: "inner_2" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "card_2" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +layers { + name: "up" +} +material: "/builtins/materials/gui.material" +adjust_reference: ADJUST_REFERENCE_PARENT +max_nodes: 512 diff --git a/example/test_layer/test_layer.gui_script b/example/test_layer/test_layer.gui_script new file mode 100644 index 0000000..907a892 --- /dev/null +++ b/example/test_layer/test_layer.gui_script @@ -0,0 +1,8 @@ +local panthera = require("panthera.panthera") + +function init(self) + local animation = panthera.create_gui("/resources/test_layer.json") + panthera.play(animation, "spin", { + is_loop = true + }) +end diff --git a/panthera/adapters/adapter_go.lua b/panthera/adapters/adapter_go.lua index 6084c1b..936a853 100644 --- a/panthera/adapters/adapter_go.lua +++ b/panthera/adapters/adapter_go.lua @@ -125,10 +125,7 @@ local function get_trigger_property_id(node, property_id) return label.get_text(node) end if defold_property_id == "texture" then - local texture_name = sprite.get_flipbook(node) - if texture_name == "" then - return "" - end + local texture_name = go.get(node, "animation") local splitted = split(texture_name, "/") return splitted[#splitted] end @@ -233,8 +230,44 @@ local function get_node(node_id) end +---@param template string|nil +---@param nodes table|nil +---@return function(node_id: string): hash|url +local function get_node_fn(template, nodes) + return function(node_id) + if template then + node_id = template .. "/" .. node_id + end + + local split_index = string.find(node_id, "#") + if split_index then + local object_id = string.sub(node_id, 1, split_index - 1) + local fragment_id = string.sub(node_id, split_index + 1) + + local object_path = hash("/" .. object_id) + if nodes then + object_path = nodes[object_path] + end + + local object_url = msg.url(object_path) + object_url.fragment = fragment_id + + return object_url + end + + local object_path = hash("/" .. node_id) + if nodes then + object_path = nodes[object_path] + end + + return object_path + end +end + + local M = { get_node = get_node, + get_node_fn = get_node_fn, get_easing = get_easing, set_node_property = set_node_property, get_node_property = get_node_property, diff --git a/panthera/adapters/adapter_gui.lua b/panthera/adapters/adapter_gui.lua index 32afc28..f2f2688 100644 --- a/panthera/adapters/adapter_gui.lua +++ b/panthera/adapters/adapter_gui.lua @@ -1,3 +1,4 @@ +---@diagnostic disable: undefined-field, return-type-mismatch -- In Defold 1.2.180+ gui.set and gui.get functions were added. Rotation was changed to Euler local IS_DEFOLD_180 = (gui.set and gui.get) @@ -38,6 +39,7 @@ local PROPERTY_TO_DEFOLD_TWEEN_PROPERTY = { local PROPERTY_TO_DEFOLD_TRIGGER_PROPERTY = { ["text"] = "text", + ["layer"] = "layer", ["texture"] = "texture", ["enabled"] = "enabled", ["visible"] = "visible", @@ -113,7 +115,7 @@ local BLEND_MODE_TO_DEFOLD_BLEND_MODE = { ["alpha"] = gui.BLEND_ALPHA, ["add"] = gui.BLEND_ADD, ["multiply"] = gui.BLEND_MULT, - ["screen"] = 4, -- No screen blend mode in Defold gui* bindings, pick from source + ["screen"] = gui.BLEND_SCREEN } local OUTER_BOUNDS_TO_DEFOLD_OUTER_BOUNDS = { @@ -174,6 +176,7 @@ local TWEEN_DEFOLD_SET_GET = { local TRIGGER_DEFOLD_SET_GET = { ["text"] = { "text", "text", gui.get_text, gui.set_text }, + ["layer"] = { "layer", "layer", gui.get_layer, gui.set_layer }, ["texture"] = { "texture", "texture", gui.get_texture, gui.set_texture }, ["enabled"] = { "enabled", "enabled", gui.is_enabled, gui.set_enabled }, ["visible"] = { "visible", "visible", gui.get_visible, gui.set_visible }, @@ -204,10 +207,14 @@ local function split(inputstr, sep) end +local LAYER_EMPTY = hash("") local DEFOLD_TRIGGER_SETTER = { ["text"] = function(node, value) gui.set_text(node, value) end, + ["layer"] = function(node, value) + gui.set_layer(node, value or LAYER_EMPTY) + end, ["texture"] = function(node, texture_name) if texture_name ~= "" then local splitted = split(texture_name, "/") diff --git a/panthera/annotations.lua b/panthera/annotations.lua index 8f5cc3e..3d64128 100644 --- a/panthera/annotations.lua +++ b/panthera/annotations.lua @@ -38,8 +38,8 @@ ---@field nodes table @Animation nodes used in animation ---@field childs panthera.animation.state[]|nil @List of active child animations ---@field get_node fun(node_id: string): node @Function to get node by node_id. Default is defined in adapter ----@field previous_animation panthera.animation.data.animation|nil @Previous runned animation ----@field animation panthera.animation.data.animation|nil @Current animation +---@field animation_id string|nil @Current animation id +---@field previous_animation_id string|nil @Previous runned animation id ---@field animation_path string @Animation path to JSON file ---@field animation_keys_index number @Animation keys index ---@field timer_id hash|nil @Timer id for animation diff --git a/panthera/panthera.lua b/panthera/panthera.lua index b764376..93717bd 100644 --- a/panthera/panthera.lua +++ b/panthera/panthera.lua @@ -1,6 +1,6 @@ local adapter_go = require("panthera.adapters.adapter_go") local adapter_gui = require("panthera.adapters.adapter_gui") -local panthera_system = require("panthera.panthera_system") +local panthera_internal = require("panthera.panthera_internal") ---@class panthera local M = {} @@ -9,13 +9,13 @@ local TIMER_DELAY = 1/60 ---@param logger_instance panthera.logger|nil function M.set_logger(logger_instance) - panthera_system.logger = logger_instance or panthera_system.empty_logger + panthera_internal.logger = logger_instance or panthera_internal.empty_logger end ---Load animation from JSON file and create it with Panthera GO adapter ---@param animation_path string ----@param get_node (fun(node_id: string): hash|url)|nil @Function to get node by node_id. Default is defined in adapter +---@param get_node (fun(node_id: string): userdata|hash|url)|nil @Function to get node by node_id. Default is defined in adapter ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message function M.create_go(animation_path, get_node) return M.create(animation_path, adapter_go, get_node) @@ -37,9 +37,9 @@ end ---@param get_node (fun(node_id: string): node)|nil @Function to get node by node_id. Default is defined in adapter ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message function M.create(animation_path, adapter, get_node) - local animation_data, error_reason = panthera_system.load(animation_path, false) + local animation_data, error_reason = panthera_internal.load(animation_path, false) if not animation_data then - panthera_system.logger:error("Can't load Panthera animation", error_reason) + panthera_internal.logger:error("Can't load Panthera animation", error_reason) return nil end @@ -78,52 +78,52 @@ end ---@param options panthera.options|nil function M.play(animation_state, animation_id, options) if not animation_state then - panthera_system.logger:warn("Can't play animation, animation_state is nil", animation_id) + panthera_internal.logger:warn("Can't play animation, animation_state is nil", animation_id) return end - local animation_data = panthera_system.get_animation_data(animation_state) + local animation_data = panthera_internal.get_animation_data(animation_state) if not animation_data then - panthera_system.logger:warn("Can't play animation, animation_data is nil", { + panthera_internal.logger:warn("Can't play animation, animation_data is nil", { animation_path = animation_state.animation_path, animation_id = animation_id, }) return nil end - local animation = panthera_system.get_animation_by_animation_id(animation_data, animation_id) + local animation = panthera_internal.get_animation_by_animation_id(animation_data, animation_id) if not animation then - panthera_system.logger:warn("Animation is not found", { + panthera_internal.logger:warn("Animation is not found", { animation_path = animation_state.animation_path, animation_id = animation_id, }) return nil end - if animation_state.animation then + if animation_state.animation_id then M.stop(animation_state) end options = options or {} - animation_state.animation = animation + animation_state.animation_id = animation.animation_id animation_state.animation_keys_index = 1 if not options.is_skip_init then -- Reset all previuosly animated nodes to initial state - if animation_state.previous_animation then - panthera_system.reset_animation_state(animation_state, animation_state.previous_animation.animation_id) - animation_state.previous_animation = nil + if animation_state.previous_animation_id then + panthera_internal.reset_animation_state(animation_state, animation_state.previous_animation_id) + animation_state.previous_animation_id = nil end -- If we have initial animation, we should set up it here? if animation.initial_state and animation_state ~= "" then - local initial_animation = panthera_system.get_animation_by_animation_id(animation_data, animation.initial_state) + local initial_animation = panthera_internal.get_animation_by_animation_id(animation_data, animation.initial_state) if initial_animation then - panthera_system.set_animation_state_at_time(animation_state, initial_animation.animation_id, initial_animation.duration) + panthera_internal.set_animation_state_at_time(animation_state, initial_animation.animation_id, initial_animation.duration) end end - panthera_system.set_animation_state_at_time(animation_state, animation.animation_id, 0) + panthera_internal.set_animation_state_at_time(animation_state, animation.animation_id, 0) end -- Start animation update timer @@ -135,17 +135,17 @@ function M.play(animation_state, animation_id, options) local speed = (options.speed or 1) * animation_state.speed animation_state.current_time = animation_state.current_time + dt * speed - M._update_animation(animation_state, options) + M._update_animation(animation, animation_state, options) end) timer.trigger(animation_state.timer_id) end ---@private +---@param animation panthera.animation.data.animation ---@param animation_state panthera.animation.state ---@param options panthera.options -function M._update_animation(animation_state, options) - local animation = animation_state.animation +function M._update_animation(animation, animation_state, options) if not animation then return end @@ -159,7 +159,7 @@ function M._update_animation(animation_state, options) animation_state.animation_keys_index = index + 1 if key.key_type ~= "animation" then - panthera_system.run_timeline_key(animation_state, key, options) + panthera_internal.run_timeline_key(animation_state, key, options) else -- Create a new animation child track local animation_path = animation_state.animation_path @@ -178,7 +178,7 @@ function M._update_animation(animation_state, options) is_skip_init = true, speed = (animation_duration / key.duration) * speed, callback = function() - panthera_system.remove_child_animation(animation_state, child_state) + panthera_internal.remove_child_animation(animation_state, child_state) end }) end @@ -190,7 +190,7 @@ function M._update_animation(animation_state, options) end -- If current time >= animation duration - stop animation - if animation_state.current_time >= animation_state.animation.duration then + if animation_state.current_time >= animation.duration then M.stop(animation_state) if options.callback then @@ -209,26 +209,26 @@ end ---@param animation_id string ---@param time number function M.set_time(animation_state, animation_id, time) - local animation_data = panthera_system.get_animation_data(animation_state) + local animation_data = panthera_internal.get_animation_data(animation_state) assert(animation_data, "Animation data is not loaded") - local animation = panthera_system.get_animation_by_animation_id(animation_data, animation_id) + local animation = panthera_internal.get_animation_by_animation_id(animation_data, animation_id) assert(animation, "Animation is not found: " .. animation_id) if M.is_playing(animation_state) then M.stop(animation_state) end - if animation_state.previous_animation then - panthera_system.reset_animation_state(animation_state, animation_state.previous_animation.animation_id) - animation_state.previous_animation = nil + if animation_state.previous_animation_id then + panthera_internal.reset_animation_state(animation_state, animation_state.previous_animation_id) + animation_state.previous_animation_id = nil end animation_state.current_time = time - animation_state.animation = animation + animation_state.animation_id = animation.animation_id animation_state.animation_keys_index = 1 - panthera_system.set_animation_state_at_time(animation_state, animation.animation_id, time) + panthera_internal.set_animation_state_at_time(animation_state, animation.animation_id, time) end @@ -245,7 +245,7 @@ end ---@return boolean @True if animation was stopped, false if animation is not playing function M.stop(animation_state) if not animation_state then - panthera_system.logger:warn("Can't stop animation, animation_state is nil") + panthera_internal.logger:warn("Can't stop animation, animation_state is nil") return false end @@ -254,22 +254,22 @@ function M.stop(animation_state) animation_state.timer_id = nil end - local previous_animation = animation_state.animation - animation_state.previous_animation = previous_animation + local previous_animation_id = animation_state.animation_id + animation_state.previous_animation_id = previous_animation_id -- Stop all tweens started by animation - if previous_animation then + if previous_animation_id then local adapter = animation_state.adapter - local animation_data = panthera_system.get_animation_data(animation_state) + local animation_data = panthera_internal.get_animation_data(animation_state) if animation_data then - local group_keys = animation_data.group_animation_keys[previous_animation.animation_id] + local group_keys = animation_data.group_animation_keys[previous_animation_id] for node_id, node_keys in pairs(group_keys) do for property_id, keys in pairs(node_keys) do if keys[1] and keys[1].key_type == "tween" then local key_end_time = keys[1].start_time + keys[1].duration local is_finished = key_end_time <= animation_state.current_time - local node = panthera_system.get_node(animation_state, node_id) + local node = panthera_internal.get_node(animation_state, node_id) if node and not is_finished then adapter.stop_tween(node, property_id) end @@ -277,14 +277,14 @@ function M.stop(animation_state) end end else - panthera_system.logger:warn("Can't stop animation, animation_data is nil", { + panthera_internal.logger:warn("Can't stop animation, animation_data is nil", { animation_path = animation_state.animation_path, - animation_id = previous_animation.animation_id + animation_id = previous_animation_id }) end end - animation_state.animation = nil + animation_state.animation_id = nil animation_state.current_time = 0 animation_state.animation_keys_index = 1 @@ -303,10 +303,10 @@ end ---@param animation_id string ---@return number function M.get_duration(animation_state, animation_id) - local animation_data = panthera_system.get_animation_data(animation_state) + local animation_data = panthera_internal.get_animation_data(animation_state) assert(animation_data, "Animation data is not loaded") - local animation = panthera_system.get_animation_by_animation_id(animation_data, animation_id) + local animation = panthera_internal.get_animation_by_animation_id(animation_data, animation_id) assert(animation, "Animation is not found: " .. animation_id) return animation.duration @@ -321,14 +321,11 @@ function M.is_playing(animation_state) end ----Get current animation id +---Get current animation ---@param animation_state panthera.animation.state @Animation state ---@return string|nil @Animation id or nil if animation is not playing function M.get_latest_animation_id(animation_state) - if animation_state.animation then - return animation_state.animation.animation_id - end - return animation_state.previous_animation and animation_state.previous_animation.animation_id or nil + return animation_state.animation_id or animation_state.previous_animation_id end @@ -336,7 +333,7 @@ end ---@param animation_state panthera.animation.state ---@return string[] function M.get_animations(animation_state) - local animation_data = panthera_system.get_animation_data(animation_state) + local animation_data = panthera_internal.get_animation_data(animation_state) if not animation_data then return {} end @@ -358,10 +355,10 @@ end ---@param animation_path string|nil @If nil - reload all loaded animations function M.reload_animation(animation_path) if animation_path then - panthera_system.load(animation_path, true) + panthera_internal.load(animation_path, true) else - for path in pairs(panthera_system.LOADED_ANIMATIONS) do - panthera_system.load(path, true) + for path in pairs(panthera_internal.LOADED_ANIMATIONS) do + panthera_internal.load(path, true) end end end diff --git a/panthera/panthera_system.lua b/panthera/panthera_internal.lua similarity index 100% rename from panthera/panthera_system.lua rename to panthera/panthera_internal.lua diff --git a/resources/test_layer.json b/resources/test_layer.json new file mode 100644 index 0000000..cdd8198 --- /dev/null +++ b/resources/test_layer.json @@ -0,0 +1 @@ +{"data":{"animations":[{"animation_id":"default","animation_keys":[{"duration":0.34,"easing":"outsine","end_value":-125,"key_type":"tween","node_id":"card_1","property_id":"position_x"},{"duration":0.34,"easing":"outsine","end_value":-15,"key_type":"tween","node_id":"card_2","property_id":"rotation_z"},{"duration":0.34,"easing":"outsine","end_value":5,"key_type":"tween","node_id":"card_2","property_id":"position_y","start_value":-55},{"duration":0.34,"easing":"outsine","end_value":15,"key_type":"tween","node_id":"card_1","property_id":"rotation_z"},{"duration":0.34,"easing":"outsine","end_value":20,"key_type":"tween","node_id":"card_1","property_id":"position_y"},{"duration":0.34,"easing":"outsine","end_value":365,"key_type":"tween","node_id":"card_2","property_id":"position_x","start_value":245},{"duration":0.35,"easing":"outsine","end_value":-55,"key_type":"tween","node_id":"card_2","property_id":"position_y","start_time":0.34,"start_value":5},{"duration":0.35,"easing":"outsine","key_type":"tween","node_id":"card_1","property_id":"position_y","start_time":0.34,"start_value":20},{"duration":0.35,"easing":"outsine","key_type":"tween","node_id":"card_1","property_id":"rotation_z","start_time":0.34,"start_value":15},{"duration":0.35,"easing":"outsine","key_type":"tween","node_id":"card_2","property_id":"rotation_z","start_time":0.34,"start_value":-15},{"duration":0.35,"easing":"outsine","end_value":30,"key_type":"tween","node_id":"card_1","property_id":"position_x","start_time":0.34,"start_value":-125},{"duration":0.35,"easing":"outsine","end_value":245,"key_type":"tween","node_id":"card_2","property_id":"position_x","start_time":0.34,"start_value":365},{"data":"up","easing":"linear","key_type":"trigger","node_id":"card_1","property_id":"layer","start_time":0.36},{"duration":0.34,"easing":"outsine","end_value":-15,"key_type":"tween","node_id":"card_2","property_id":"rotation_z","start_time":1.11},{"duration":0.34,"easing":"outsine","end_value":5,"key_type":"tween","node_id":"card_2","property_id":"position_y","start_time":1.11,"start_value":-55},{"duration":0.34,"easing":"outsine","end_value":365,"key_type":"tween","node_id":"card_2","property_id":"position_x","start_time":1.11,"start_value":245},{"duration":0.34,"easing":"outsine","end_value":-125,"key_type":"tween","node_id":"card_1","property_id":"position_x","start_time":1.19,"start_value":30},{"duration":0.34,"easing":"outsine","end_value":15,"key_type":"tween","node_id":"card_1","property_id":"rotation_z","start_time":1.19},{"duration":0.34,"easing":"outsine","end_value":20,"key_type":"tween","node_id":"card_1","property_id":"position_y","start_time":1.19},{"duration":0.35,"easing":"outsine","end_value":-55,"key_type":"tween","node_id":"card_2","property_id":"position_y","start_time":1.45,"start_value":5},{"duration":0.35,"easing":"outsine","key_type":"tween","node_id":"card_2","property_id":"rotation_z","start_time":1.45,"start_value":-15},{"duration":0.35,"easing":"outsine","end_value":245,"key_type":"tween","node_id":"card_2","property_id":"position_x","start_time":1.45,"start_value":365},{"duration":0.35,"easing":"outsine","key_type":"tween","node_id":"card_1","property_id":"position_y","start_time":1.53,"start_value":20},{"duration":0.35,"easing":"outsine","key_type":"tween","node_id":"card_1","property_id":"rotation_z","start_time":1.53,"start_value":15},{"duration":0.35,"easing":"outsine","end_value":30,"key_type":"tween","node_id":"card_1","property_id":"position_x","start_time":1.53,"start_value":-125},{"easing":"linear","key_type":"trigger","node_id":"card_1","property_id":"layer","start_data":"up","start_time":1.54}],"duration":2},{"animation_id":"asd","animation_keys":[],"duration":1},{"animation_id":"spin","animation_keys":[{"easing":"outsine","end_value":-200,"key_type":"tween","node_id":"card_1","property_id":"position_x"},{"data":"up","easing":"linear","key_type":"trigger","node_id":"card_1","property_id":"layer"},{"easing":"outsine","key_type":"tween","node_id":"card_2","property_id":"position_y","start_value":-55},{"easing":"outsine","end_value":200,"key_type":"tween","node_id":"card_2","property_id":"position_x","start_value":245},{"duration":0.5,"easing":"linear","end_value":-150,"key_type":"tween","node_id":"card_1","property_id":"position_y"},{"duration":0.5,"easing":"insine","key_type":"tween","node_id":"card_1","property_id":"position_x","start_value":-200},{"duration":0.5,"easing":"insine","key_type":"tween","node_id":"card_2","property_id":"position_x","start_value":200},{"duration":0.5,"easing":"outsine","end_value":0.9,"key_type":"tween","node_id":"card_2","property_id":"scale_x","start_value":1},{"duration":0.5,"easing":"outsine","end_value":0.9,"key_type":"tween","node_id":"card_2","property_id":"scale_y","start_value":1},{"duration":0.5,"easing":"outsine","end_value":1.1,"key_type":"tween","node_id":"card_1","property_id":"scale_x","start_value":1},{"duration":0.5,"easing":"outsine","end_value":1.1,"key_type":"tween","node_id":"card_1","property_id":"scale_y","start_value":1},{"duration":0.5,"easing":"linear","end_value":150,"key_type":"tween","node_id":"card_2","property_id":"position_y"},{"duration":0.5,"easing":"outsine","end_value":-200,"key_type":"tween","node_id":"card_2","property_id":"position_x","start_time":0.5},{"duration":0.5,"easing":"linear","key_type":"tween","node_id":"card_1","property_id":"position_y","start_time":0.5,"start_value":-150},{"duration":0.5,"easing":"linear","key_type":"tween","node_id":"card_2","property_id":"position_y","start_time":0.5,"start_value":150},{"duration":0.5,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"card_1","property_id":"scale_x","start_time":0.5,"start_value":1.1},{"duration":0.5,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"card_1","property_id":"scale_y","start_time":0.5,"start_value":1.1},{"duration":0.5,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"card_2","property_id":"scale_x","start_time":0.5,"start_value":0.9},{"duration":0.5,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"card_2","property_id":"scale_y","start_time":0.5,"start_value":0.9},{"duration":0.5,"easing":"outsine","end_value":200,"key_type":"tween","node_id":"card_1","property_id":"position_x","start_time":0.5},{"easing":"linear","key_type":"trigger","node_id":"card_1","property_id":"layer","start_data":"up","start_time":1},{"duration":0.5,"easing":"linear","end_value":-150,"key_type":"tween","node_id":"card_2","property_id":"position_y","start_time":1},{"duration":0.5,"easing":"insine","key_type":"tween","node_id":"card_1","property_id":"position_x","start_time":1,"start_value":200},{"duration":0.5,"easing":"insine","key_type":"tween","node_id":"card_2","property_id":"position_x","start_time":1,"start_value":-200},{"duration":0.5,"easing":"outsine","end_value":0.9,"key_type":"tween","node_id":"card_1","property_id":"scale_x","start_time":1,"start_value":1},{"duration":0.5,"easing":"outsine","end_value":0.9,"key_type":"tween","node_id":"card_1","property_id":"scale_y","start_time":1,"start_value":1},{"duration":0.5,"easing":"outsine","end_value":1.1,"key_type":"tween","node_id":"card_2","property_id":"scale_x","start_time":1,"start_value":1},{"duration":0.5,"easing":"outsine","end_value":1.1,"key_type":"tween","node_id":"card_2","property_id":"scale_y","start_time":1,"start_value":1},{"duration":0.5,"easing":"linear","end_value":155,"key_type":"tween","node_id":"card_1","property_id":"position_y","start_time":1},{"duration":0.5,"easing":"outsine","end_value":-200,"key_type":"tween","node_id":"card_1","property_id":"position_x","start_time":1.5},{"duration":0.5,"easing":"linear","key_type":"tween","node_id":"card_1","property_id":"position_y","start_time":1.5,"start_value":155},{"duration":0.5,"easing":"linear","key_type":"tween","node_id":"card_2","property_id":"position_y","start_time":1.5,"start_value":-150},{"duration":0.5,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"card_1","property_id":"scale_x","start_time":1.5,"start_value":0.9},{"duration":0.5,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"card_1","property_id":"scale_y","start_time":1.5,"start_value":0.9},{"duration":0.5,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"card_2","property_id":"scale_x","start_time":1.5,"start_value":1.1},{"duration":0.5,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"card_2","property_id":"scale_y","start_time":1.5,"start_value":1.1},{"duration":0.5,"easing":"outsine","end_value":200,"key_type":"tween","node_id":"card_2","property_id":"position_x","start_time":1.5}],"duration":2}],"metadata":{"fps":60,"gizmo_steps":[],"layers":[{"color":"19C352","name":"up"}],"settings":{"font_size":30}},"nodes":[{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":0.411,"color_g":0.8,"color_r":0.665,"enabled":true,"inherit_alpha":true,"node_id":"card_1","node_index":1,"node_type":"box","pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":300,"size_y":400,"visible":true},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"inherit_alpha":true,"node_id":"inner_1","node_index":2,"node_type":"box","parent":"card_1","pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":268,"size_y":370,"visible":true},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":0.8,"color_g":0.411,"color_r":0.426,"enabled":true,"inherit_alpha":true,"node_id":"card_2","node_index":3,"node_type":"box","pivot":"pivot_center","position_x":245,"position_y":-55,"scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":300,"size_y":400,"visible":true},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"inherit_alpha":true,"node_id":"inner_2","node_index":4,"node_type":"box","parent":"card_2","pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":268,"size_y":370,"visible":true}]},"format":"json","type":"animation_editor","version":1} \ No newline at end of file From bc6c1403fc2ac1bf1ea5a48e8ab2b0bbe47785c3 Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 20 Jul 2024 16:25:38 +0300 Subject: [PATCH 02/17] Add example for run animations on GUI / Template / cloned GUI / Cloned template --- .vscode/settings.json | 3 +- .../example_go_gui_templates.collection | 79 ++ .../example_go_gui_templates.gui | 1154 +++++++++++++++++ .../example_go_gui_templates.gui_script | 33 + .../test_collection.collection | 1 + .../test_game_object.go | 0 example/example_go_gui_templates/test_gui.gui | 259 ++++ .../test_gui_template.gui | 18 + resources/test_gui.json | 1 + 9 files changed, 1547 insertions(+), 1 deletion(-) create mode 100644 example/example_go_gui_templates/example_go_gui_templates.collection create mode 100644 example/example_go_gui_templates/example_go_gui_templates.gui create mode 100644 example/example_go_gui_templates/example_go_gui_templates.gui_script create mode 100644 example/example_go_gui_templates/test_collection.collection create mode 100644 example/example_go_gui_templates/test_game_object.go create mode 100644 example/example_go_gui_templates/test_gui.gui create mode 100644 example/example_go_gui_templates/test_gui_template.gui create mode 100644 resources/test_gui.json diff --git a/.vscode/settings.json b/.vscode/settings.json index cc97795..c2d8edd 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -11,6 +11,7 @@ "timer", "pprint", "json", - "go" + "go", + "vmath" ] } diff --git a/example/example_go_gui_templates/example_go_gui_templates.collection b/example/example_go_gui_templates/example_go_gui_templates.collection new file mode 100644 index 0000000..a7385d7 --- /dev/null +++ b/example/example_go_gui_templates/example_go_gui_templates.collection @@ -0,0 +1,79 @@ +name: "example_go_gui_templates" +collection_instances { + id: "test_collection" + collection: "/example/example_go_gui_templates/test_collection.collection" + position { + x: 0.0 + y: 0.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} +scale_along_z: 0 +embedded_instances { + id: "gui" + data: "components {\n" + " id: \"example_go_gui_templates\"\n" + " component: \"/example/example_go_gui_templates/example_go_gui_templates.gui\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + " property_decls {\n" + " }\n" + "}\n" + "" + position { + x: 0.0 + y: 0.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} +embedded_instances { + id: "test_go" + data: "" + position { + x: 0.0 + y: 0.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} diff --git a/example/example_go_gui_templates/example_go_gui_templates.gui b/example/example_go_gui_templates/example_go_gui_templates.gui new file mode 100644 index 0000000..fab129b --- /dev/null +++ b/example/example_go_gui_templates/example_go_gui_templates.gui @@ -0,0 +1,1154 @@ +script: "/example/example_go_gui_templates/example_go_gui_templates.gui_script" +fonts { + name: "troika" + font: "/example/assets/troika.font" +} +textures { + name: "example" + texture: "/example/assets/example.atlas" +} +background_color { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 +} +nodes { + position { + x: 480.0 + y: 320.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 960.0 + y: 640.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/empty" + id: "root" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_STRETCH + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: false + material: "" +} +nodes { + position { + x: -200.0 + y: 290.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "GUI Nodes" + font: "troika" + id: "text_gui_nodes" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: false + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: -200.0 + y: 120.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 300.0 + y: 300.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/pixel" + id: "test_gui_inline" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "root" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 50.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.091 + y: 0.088 + z: 0.088 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "Text" + font: "troika" + id: "text" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "test_gui_inline" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: false + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: -60.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "box" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "test_gui_inline" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 60.0 + y: -2.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_PIE + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "pie" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "test_gui_inline" + layer: "" + inherit_alpha: true + outerBounds: PIEBOUNDS_RECTANGLE + innerRadius: 0.0 + perimeterVertices: 10 + pieFillAngle: 360.0 + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 200.0 + y: 290.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "GUI Template" + font: "troika" + id: "text_gui_template" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: false + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 200.0 + y: 120.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_TEMPLATE + id: "test_gui" + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + template: "/example/example_go_gui_templates/test_gui.gui" + template_node_child: false + custom_type: 0 + enabled: true +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 300.0 + y: 300.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/pixel" + id: "test_gui/root" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "test_gui" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: true + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 50.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.091 + y: 0.088 + z: 0.088 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "Text" + font: "troika" + id: "test_gui/text" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "test_gui/root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: true + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: -60.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "test_gui/box" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "test_gui/root" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: true + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 60.0 + y: -2.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_PIE + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "test_gui/pie" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "test_gui/root" + layer: "" + inherit_alpha: true + outerBounds: PIEBOUNDS_RECTANGLE + innerRadius: 0.0 + perimeterVertices: 10 + pieFillAngle: 360.0 + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: true + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: -200.0 + y: -60.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "GUI Cloned Nodes" + font: "troika" + id: "text_gui_nodes_clone" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: false + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 200.0 + y: -60.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "GUI Cloned Template" + font: "troika" + id: "text_gui_template_clone" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: false + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 200.0 + y: -240.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_TEMPLATE + id: "test_gui1" + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + template: "/example/example_go_gui_templates/test_gui.gui" + template_node_child: false + custom_type: 0 + enabled: true +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 300.0 + y: 300.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/pixel" + id: "test_gui1/root" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "test_gui1" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: true + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 50.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.091 + y: 0.088 + z: 0.088 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "Text" + font: "troika" + id: "test_gui1/text" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "test_gui1/root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: true + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: -60.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "test_gui1/box" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "test_gui1/root" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: true + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 60.0 + y: -2.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_PIE + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "test_gui1/pie" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "test_gui1/root" + layer: "" + inherit_alpha: true + outerBounds: PIEBOUNDS_RECTANGLE + innerRadius: 0.0 + perimeterVertices: 10 + pieFillAngle: 360.0 + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: true + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +material: "/builtins/materials/gui.material" +adjust_reference: ADJUST_REFERENCE_PARENT +max_nodes: 512 diff --git a/example/example_go_gui_templates/example_go_gui_templates.gui_script b/example/example_go_gui_templates/example_go_gui_templates.gui_script new file mode 100644 index 0000000..77d7681 --- /dev/null +++ b/example/example_go_gui_templates/example_go_gui_templates.gui_script @@ -0,0 +1,33 @@ +local panthera = require("panthera.panthera") +local PATH = "/resources/test_gui.json" + +function init(self) + -- Run Panthera animation on GUI nodes + local animation_inline = panthera.create_gui(PATH) + panthera.play(animation_inline, "default", { is_loop = true }) + + + -- Run Panthera animation on GUI template nodes + local animation_template = panthera.create_gui(PATH, function(node_id) + return gui.get_node("test_gui/" .. node_id) + end) + panthera.play(animation_template, "default", { is_loop = true }) + + + --- Run Panthera animation on cloned GUI nodes + local nodes = gui.clone_tree(gui.get_node("test_gui_inline")) + gui.set_position(nodes["test_gui_inline"], vmath.vector3(-200, -240, 0)) + local animation_nodes = panthera.create_gui(PATH, function(node_id) + return nodes[node_id] + end) + panthera.play(animation_nodes, "default", { is_loop = true }) + + + -- Run Panthera animation on cloned GUI template nodes + local template_nodes = gui.clone_tree(gui.get_node("test_gui/root")) + gui.set_position(template_nodes["test_gui/root"], vmath.vector3(200, -240, 0)) + local animation_template_nodes = panthera.create_gui(PATH, function(node_id) + return template_nodes["test_gui/" .. node_id] + end) + panthera.play(animation_template_nodes, "default", { is_loop = true }) +end \ No newline at end of file diff --git a/example/example_go_gui_templates/test_collection.collection b/example/example_go_gui_templates/test_collection.collection new file mode 100644 index 0000000..8090f59 --- /dev/null +++ b/example/example_go_gui_templates/test_collection.collection @@ -0,0 +1 @@ +name: "test_collection" diff --git a/example/example_go_gui_templates/test_game_object.go b/example/example_go_gui_templates/test_game_object.go new file mode 100644 index 0000000..e69de29 diff --git a/example/example_go_gui_templates/test_gui.gui b/example/example_go_gui_templates/test_gui.gui new file mode 100644 index 0000000..7ed1a46 --- /dev/null +++ b/example/example_go_gui_templates/test_gui.gui @@ -0,0 +1,259 @@ +script: "" +fonts { + name: "troika" + font: "/example/assets/troika.font" +} +textures { + name: "example" + texture: "/example/assets/example.atlas" +} +background_color { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 300.0 + y: 300.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/pixel" + id: "root" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 50.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.091 + y: 0.088 + z: 0.088 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "Text" + font: "troika" + id: "text" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: false + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: -60.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "box" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "root" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 60.0 + y: -2.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_PIE + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "pie" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "root" + layer: "" + inherit_alpha: true + outerBounds: PIEBOUNDS_RECTANGLE + innerRadius: 0.0 + perimeterVertices: 10 + pieFillAngle: 360.0 + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +material: "/builtins/materials/gui.material" +adjust_reference: ADJUST_REFERENCE_PARENT +max_nodes: 512 diff --git a/example/example_go_gui_templates/test_gui_template.gui b/example/example_go_gui_templates/test_gui_template.gui new file mode 100644 index 0000000..59ead4d --- /dev/null +++ b/example/example_go_gui_templates/test_gui_template.gui @@ -0,0 +1,18 @@ +script: "" +fonts { + name: "troika" + font: "/example/assets/troika.font" +} +textures { + name: "example" + texture: "/example/assets/example.atlas" +} +background_color { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 +} +material: "/builtins/materials/gui.material" +adjust_reference: ADJUST_REFERENCE_PARENT +max_nodes: 512 diff --git a/resources/test_gui.json b/resources/test_gui.json new file mode 100644 index 0000000..ca28b85 --- /dev/null +++ b/resources/test_gui.json @@ -0,0 +1 @@ +{"data":{"animations":[{"animation_id":"default","animation_keys":[{"duration":1,"easing":"outsine","end_value":-1,"key_type":"tween","node_id":"box","property_id":"scale_x","start_value":1},{"duration":1,"easing":"outsine","key_type":"tween","node_id":"pie","property_id":"fill_angle","start_value":360},{"duration":1.5,"easing":"outsine","end_value":0.27,"key_type":"tween","node_id":"text","property_id":"color_b","start_value":0.088},{"duration":1.5,"easing":"outsine","end_value":0.27,"key_type":"tween","node_id":"text","property_id":"color_g","start_value":0.088},{"duration":1.5,"easing":"outsine","end_value":0.83,"key_type":"tween","node_id":"text","property_id":"color_r","start_value":0.091},{"data":"Just","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Text","start_time":0.5},{"data":"Test","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Just","start_time":1},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"box","property_id":"scale_x","start_time":1,"start_value":-1},{"duration":1,"easing":"outsine","end_value":360,"key_type":"tween","node_id":"pie","property_id":"fill_angle","start_time":1},{"data":"Text Change","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Test","start_time":1.5},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_b","start_time":1.5,"start_value":0.27},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_g","start_time":1.5,"start_value":0.27},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_r","start_time":1.5,"start_value":0.83}],"duration":3}],"metadata":{"fps":60,"gizmo_steps":{"time":0.1},"gui_path":"/example/example_go_gui_templates/test_gui.gui","settings":{"font_size":40}},"nodes":[]},"format":"json","type":"animation_editor","version":1} \ No newline at end of file From 9a51a51ac2b02fbf9bf23fd14973465f8aafc2b4 Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 20 Jul 2024 17:13:52 +0300 Subject: [PATCH 03/17] Add GUI and GO examples how to run Panthera over nodes/cloned nodes/cloned with templates --- .vscode/settings.json | 5 +- README.md | 24 +- .../go/example_go_template_nodes.collection | 464 ++++++++++++++++++ .../go/example_go_template_nodes.script | 28 ++ .../go/test_collection.collection | 93 ++++ .../example_go_gui_templates/go/test_go.go | 71 +++ .../go/test_inner_collection.collection | 22 + .../example_gui_template_nodes.collection} | 4 +- .../example_gui_template_nodes.gui} | 288 +---------- .../example_gui_template_nodes.gui_script} | 12 +- .../{ => gui}/test_gui.gui | 0 .../test_collection.collection | 1 - .../test_gui_template.gui | 18 - game.project | 2 +- panthera/adapters/adapter_go.lua | 21 +- panthera/adapters/adapter_gui.lua | 19 + panthera/panthera.lua | 12 +- resources/test_go.json | 1 + resources/test_gui.json | 2 +- 19 files changed, 745 insertions(+), 342 deletions(-) create mode 100644 example/example_go_gui_templates/go/example_go_template_nodes.collection create mode 100644 example/example_go_gui_templates/go/example_go_template_nodes.script create mode 100644 example/example_go_gui_templates/go/test_collection.collection create mode 100644 example/example_go_gui_templates/go/test_go.go create mode 100644 example/example_go_gui_templates/go/test_inner_collection.collection rename example/example_go_gui_templates/{example_go_gui_templates.collection => gui/example_gui_template_nodes.collection} (83%) rename example/example_go_gui_templates/{example_go_gui_templates.gui => gui/example_gui_template_nodes.gui} (74%) rename example/example_go_gui_templates/{example_go_gui_templates.gui_script => gui/example_gui_template_nodes.gui_script} (72%) rename example/example_go_gui_templates/{ => gui}/test_gui.gui (100%) delete mode 100644 example/example_go_gui_templates/test_collection.collection delete mode 100644 example/example_go_gui_templates/test_gui_template.gui create mode 100644 resources/test_go.json diff --git a/.vscode/settings.json b/.vscode/settings.json index c2d8edd..e215621 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -12,6 +12,9 @@ "pprint", "json", "go", - "vmath" + "vmath", + "collectionfactory", + "label", + "sprite" ] } diff --git a/README.md b/README.md index 0085a25..ba72885 100644 --- a/README.md +++ b/README.md @@ -161,12 +161,13 @@ Load and create a GUI animation state from a JSON file. The Panthera uses `sys.load_resource` to load the animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. ```lua -panthera.create_gui(animation_path, [get_node]) +panthera.create_gui(animation_path, [template], [nodes]) ``` - **Parameters:** - `animation_path`: The path to the animation JSON file. Example: `/animations/my_gui_animation.json`. - - `get_node` (optional): A function to resolve nodes by their ID within the GUI. If not provided, the adapter uses its default method from adapter implementation. + - `template` (optional): The GUI template id to load nodes from. Pass nil if no template is used. + - `nodes` (optional): Table with nodes from `gui.clone_tree()` function. Pass nil if nodes are not cloned. - **Returns:** An animation state object or `nil` if the animation cannot be loaded. @@ -174,13 +175,20 @@ panthera.create_gui(animation_path, [get_node]) ```lua local gui_animation = panthera.create_gui("/animations/my_gui_animation.json") -``` -```lua -local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", function(node_id) - -- If we inside a Druid's component, we can use this function to get a node by its ID instead of gui.get_node(node_id) - return self:get_node(node_id) -end +-- Create animation over GUI template +local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", "template_name") + +-- Create animation over cloned GUI template +local nodes = gui.clone_tree(gui.get_node("template_name/root")) +local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", "template_name", nodes) + +-- Create animation over cloned GUI nodes +local nodes = gui.clone_tree(gui.get_node("root")) +local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", nil, nodes) + +-- Using Druid: +local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", self:get_template(), self:get_nodes()) ``` **panthera.create_go** diff --git a/example/example_go_gui_templates/go/example_go_template_nodes.collection b/example/example_go_gui_templates/go/example_go_template_nodes.collection new file mode 100644 index 0000000..c170439 --- /dev/null +++ b/example/example_go_gui_templates/go/example_go_template_nodes.collection @@ -0,0 +1,464 @@ +name: "test_collection" +collection_instances { + id: "test_collection" + collection: "/example/example_go_gui_templates/go/test_collection.collection" + position { + x: 640.0 + y: 480.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} +collection_instances { + id: "test_inner_collection" + collection: "/example/example_go_gui_templates/go/test_inner_collection.collection" + position { + x: 320.0 + y: 160.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} +scale_along_z: 0 +embedded_instances { + id: "root" + children: "panthera" + data: "components {\n" + " id: \"example_go_template_nodes\"\n" + " component: \"/example/example_go_gui_templates/go/example_go_template_nodes.script\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + " property_decls {\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"collectionfactory\"\n" + " type: \"collectionfactory\"\n" + " data: \"prototype: \\\"/example/example_go_gui_templates/go/test_collection.collection\\\"\\n" + "load_dynamically: false\\n" + "dynamic_prototype: false\\n" + "\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"collectionfactory_inner\"\n" + " type: \"collectionfactory\"\n" + " data: \"prototype: \\\"/example/example_go_gui_templates/go/test_inner_collection.collection\\\"\\n" + "load_dynamically: false\\n" + "dynamic_prototype: false\\n" + "\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"label_game_object\"\n" + " type: \"label\"\n" + " data: \"size {\\n" + " x: 128.0\\n" + " y: 32.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "color {\\n" + " x: 1.0\\n" + " y: 1.0\\n" + " z: 1.0\\n" + " w: 1.0\\n" + "}\\n" + "outline {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "shadow {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "leading: 1.0\\n" + "tracking: 0.0\\n" + "pivot: PIVOT_CENTER\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "line_break: false\\n" + "text: \\\"Game Object\\\"\\n" + "font: \\\"/example/assets/troika.font\\\"\\n" + "material: \\\"/builtins/fonts/label-df.material\\\"\\n" + "\"\n" + " position {\n" + " x: -160.0\n" + " y: 280.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"label_collection\"\n" + " type: \"label\"\n" + " data: \"size {\\n" + " x: 128.0\\n" + " y: 32.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "color {\\n" + " x: 1.0\\n" + " y: 1.0\\n" + " z: 1.0\\n" + " w: 1.0\\n" + "}\\n" + "outline {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "shadow {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "leading: 1.0\\n" + "tracking: 0.0\\n" + "pivot: PIVOT_CENTER\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "line_break: false\\n" + "text: \\\"Collection\\\"\\n" + "font: \\\"/example/assets/troika.font\\\"\\n" + "material: \\\"/builtins/fonts/label-df.material\\\"\\n" + "\"\n" + " position {\n" + " x: 160.0\n" + " y: 280.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"label_nested_collection\"\n" + " type: \"label\"\n" + " data: \"size {\\n" + " x: 128.0\\n" + " y: 32.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "color {\\n" + " x: 1.0\\n" + " y: 1.0\\n" + " z: 1.0\\n" + " w: 1.0\\n" + "}\\n" + "outline {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "shadow {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "leading: 1.0\\n" + "tracking: 0.0\\n" + "pivot: PIVOT_CENTER\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "line_break: false\\n" + "text: \\\"Nested Collection\\\"\\n" + "font: \\\"/example/assets/troika.font\\\"\\n" + "material: \\\"/builtins/fonts/label-df.material\\\"\\n" + "\"\n" + " position {\n" + " x: -160.0\n" + " y: -40.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + " scale {\n" + " x: 0.7\n" + " y: 0.7\n" + " z: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"label_collection_cloned\"\n" + " type: \"label\"\n" + " data: \"size {\\n" + " x: 128.0\\n" + " y: 32.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "color {\\n" + " x: 1.0\\n" + " y: 1.0\\n" + " z: 1.0\\n" + " w: 1.0\\n" + "}\\n" + "outline {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "shadow {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "leading: 1.0\\n" + "tracking: 0.0\\n" + "pivot: PIVOT_CENTER\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "line_break: true\\n" + "text: \\\"Spawned Collection\\\"\\n" + "font: \\\"/example/assets/troika.font\\\"\\n" + "material: \\\"/builtins/fonts/label-df.material\\\"\\n" + "\"\n" + " position {\n" + " x: 160.0\n" + " y: -40.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + " scale {\n" + " x: 0.7\n" + " y: 0.7\n" + " z: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"label_collection_nested_cloned\"\n" + " type: \"label\"\n" + " data: \"size {\\n" + " x: 128.0\\n" + " y: 32.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "color {\\n" + " x: 1.0\\n" + " y: 1.0\\n" + " z: 1.0\\n" + " w: 1.0\\n" + "}\\n" + "outline {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "shadow {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "leading: 1.0\\n" + "tracking: 0.0\\n" + "pivot: PIVOT_CENTER\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "line_break: true\\n" + "text: \\\"Spawned Nested\\\"\\n" + "font: \\\"/example/assets/troika.font\\\"\\n" + "material: \\\"/builtins/fonts/label-df.material\\\"\\n" + "\"\n" + " position {\n" + " x: 380.0\n" + " y: -40.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + " scale {\n" + " x: 0.7\n" + " y: 0.7\n" + " z: 1.0\n" + " }\n" + "}\n" + "" + position { + x: 480.0 + y: 320.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} +embedded_instances { + id: "panthera" + data: "embedded_components {\n" + " id: \"sprite\"\n" + " type: \"sprite\"\n" + " data: \"default_animation: \\\"panthera\\\"\\n" + "material: \\\"/builtins/materials/sprite.material\\\"\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "textures {\\n" + " sampler: \\\"texture_sampler\\\"\\n" + " texture: \\\"/example/assets/example.atlas\\\"\\n" + "}\\n" + "\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"label\"\n" + " type: \"label\"\n" + " data: \"size {\\n" + " x: 128.0\\n" + " y: 32.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "color {\\n" + " x: 1.0\\n" + " y: 1.0\\n" + " z: 1.0\\n" + " w: 1.0\\n" + "}\\n" + "outline {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "shadow {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "leading: 1.0\\n" + "tracking: 0.0\\n" + "pivot: PIVOT_CENTER\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "line_break: false\\n" + "text: \\\"Text\\\"\\n" + "font: \\\"/example/assets/troika.font\\\"\\n" + "material: \\\"/builtins/fonts/label-df.material\\\"\\n" + "\"\n" + " position {\n" + " x: 0.0\n" + " y: 70.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "" + position { + x: -160.0 + y: 160.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} diff --git a/example/example_go_gui_templates/go/example_go_template_nodes.script b/example/example_go_gui_templates/go/example_go_template_nodes.script new file mode 100644 index 0000000..9e0723c --- /dev/null +++ b/example/example_go_gui_templates/go/example_go_template_nodes.script @@ -0,0 +1,28 @@ +local panthera = require("panthera.panthera") +local PATH = "/resources/test_go.json" + +function init(self) + -- Run Panthera over Game Object in collection + local go_animation = panthera.create_go(PATH) + panthera.play(go_animation, "default", { is_loop = true }) + + -- Run Panthera over collection + local go_animation = panthera.create_go(PATH, "test_collection") + panthera.play(go_animation, "default", { is_loop = true }) + + -- Run Panthera over nested collection + local go_animation = panthera.create_go(PATH, "test_inner_collection/test_collection") + panthera.play(go_animation, "default", { is_loop = true }) + + -- Run Panthera over collection from collectionfactory + local objects = collectionfactory.create("#collectionfactory") + go.set_position(vmath.vector3(640, 160, 0), objects["/panthera"]) + local go_animation = panthera.create_go(PATH, nil, objects) + panthera.play(go_animation, "default", { is_loop = true }) + + -- Run Panthera over nested collection from collectionfactory + local objects = collectionfactory.create("#collectionfactory_inner") + go.set_position(vmath.vector3(860, 160, 0), objects["/test_collection/panthera"]) + local go_animation = panthera.create_go(PATH, "test_collection", objects) + panthera.play(go_animation, "default", { is_loop = true }) +end \ No newline at end of file diff --git a/example/example_go_gui_templates/go/test_collection.collection b/example/example_go_gui_templates/go/test_collection.collection new file mode 100644 index 0000000..a224ad2 --- /dev/null +++ b/example/example_go_gui_templates/go/test_collection.collection @@ -0,0 +1,93 @@ +name: "test_collection" +scale_along_z: 0 +embedded_instances { + id: "panthera" + data: "embedded_components {\n" + " id: \"label\"\n" + " type: \"label\"\n" + " data: \"size {\\n" + " x: 128.0\\n" + " y: 32.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "color {\\n" + " x: 1.0\\n" + " y: 1.0\\n" + " z: 1.0\\n" + " w: 1.0\\n" + "}\\n" + "outline {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "shadow {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "leading: 1.0\\n" + "tracking: 0.0\\n" + "pivot: PIVOT_CENTER\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "line_break: false\\n" + "text: \\\"Text\\\"\\n" + "font: \\\"/example/assets/troika.font\\\"\\n" + "material: \\\"/builtins/fonts/label-df.material\\\"\\n" + "\"\n" + " position {\n" + " x: 0.0\n" + " y: 70.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"sprite\"\n" + " type: \"sprite\"\n" + " data: \"default_animation: \\\"panthera\\\"\\n" + "material: \\\"/builtins/materials/sprite.material\\\"\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "textures {\\n" + " sampler: \\\"texture_sampler\\\"\\n" + " texture: \\\"/example/assets/example.atlas\\\"\\n" + "}\\n" + "\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "" + position { + x: 0.0 + y: 0.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} diff --git a/example/example_go_gui_templates/go/test_go.go b/example/example_go_gui_templates/go/test_go.go new file mode 100644 index 0000000..eae6c36 --- /dev/null +++ b/example/example_go_gui_templates/go/test_go.go @@ -0,0 +1,71 @@ +embedded_components { + id: "label" + type: "label" + data: "size {\n" + " x: 128.0\n" + " y: 32.0\n" + " z: 0.0\n" + " w: 0.0\n" + "}\n" + "color {\n" + " x: 1.0\n" + " y: 1.0\n" + " z: 1.0\n" + " w: 1.0\n" + "}\n" + "outline {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 0.0\n" + "}\n" + "shadow {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 0.0\n" + "}\n" + "leading: 1.0\n" + "tracking: 0.0\n" + "pivot: PIVOT_CENTER\n" + "blend_mode: BLEND_MODE_ALPHA\n" + "line_break: false\n" + "text: \"Text\"\n" + "font: \"/example/assets/troika.font\"\n" + "material: \"/builtins/fonts/label-df.material\"\n" + "" + position { + x: 0.0 + y: 70.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } +} +embedded_components { + id: "sprite" + type: "sprite" + data: "default_animation: \"panthera\"\n" + "material: \"/builtins/materials/sprite.material\"\n" + "blend_mode: BLEND_MODE_ALPHA\n" + "textures {\n" + " sampler: \"texture_sampler\"\n" + " texture: \"/example/assets/example.atlas\"\n" + "}\n" + "" + position { + x: 0.0 + y: 0.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } +} diff --git a/example/example_go_gui_templates/go/test_inner_collection.collection b/example/example_go_gui_templates/go/test_inner_collection.collection new file mode 100644 index 0000000..c6e4db5 --- /dev/null +++ b/example/example_go_gui_templates/go/test_inner_collection.collection @@ -0,0 +1,22 @@ +name: "test_collection" +collection_instances { + id: "test_collection" + collection: "/example/example_go_gui_templates/go/test_collection.collection" + position { + x: 0.0 + y: 0.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} +scale_along_z: 0 diff --git a/example/example_go_gui_templates/example_go_gui_templates.collection b/example/example_go_gui_templates/gui/example_gui_template_nodes.collection similarity index 83% rename from example/example_go_gui_templates/example_go_gui_templates.collection rename to example/example_go_gui_templates/gui/example_gui_template_nodes.collection index a7385d7..a89ef60 100644 --- a/example/example_go_gui_templates/example_go_gui_templates.collection +++ b/example/example_go_gui_templates/gui/example_gui_template_nodes.collection @@ -1,7 +1,7 @@ name: "example_go_gui_templates" collection_instances { id: "test_collection" - collection: "/example/example_go_gui_templates/test_collection.collection" + collection: "/example/example_go_gui_templates/go/example_go_template_nodes.collection" position { x: 0.0 y: 0.0 @@ -24,7 +24,7 @@ embedded_instances { id: "gui" data: "components {\n" " id: \"example_go_gui_templates\"\n" - " component: \"/example/example_go_gui_templates/example_go_gui_templates.gui\"\n" + " component: \"/example/example_go_gui_templates/gui/example_gui_template_nodes.gui\"\n" " position {\n" " x: 0.0\n" " y: 0.0\n" diff --git a/example/example_go_gui_templates/example_go_gui_templates.gui b/example/example_go_gui_templates/gui/example_gui_template_nodes.gui similarity index 74% rename from example/example_go_gui_templates/example_go_gui_templates.gui rename to example/example_go_gui_templates/gui/example_gui_template_nodes.gui index fab129b..675821d 100644 --- a/example/example_go_gui_templates/example_go_gui_templates.gui +++ b/example/example_go_gui_templates/gui/example_gui_template_nodes.gui @@ -1,4 +1,4 @@ -script: "/example/example_go_gui_templates/example_go_gui_templates.gui_script" +script: "/example/example_go_gui_templates/gui/example_gui_template_nodes.gui_script" fonts { name: "troika" font: "/example/assets/troika.font" @@ -484,7 +484,7 @@ nodes { layer: "" inherit_alpha: true alpha: 1.0 - template: "/example/example_go_gui_templates/test_gui.gui" + template: "/example/example_go_gui_templates/gui/test_gui.gui" template_node_child: false custom_type: 0 enabled: true @@ -865,290 +865,6 @@ nodes { visible: true material: "" } -nodes { - position { - x: 200.0 - y: -240.0 - z: 0.0 - w: 1.0 - } - rotation { - x: 0.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - scale { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - size { - x: 200.0 - y: 100.0 - z: 0.0 - w: 1.0 - } - color { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - type: TYPE_TEMPLATE - id: "test_gui1" - parent: "root" - layer: "" - inherit_alpha: true - alpha: 1.0 - template: "/example/example_go_gui_templates/test_gui.gui" - template_node_child: false - custom_type: 0 - enabled: true -} -nodes { - position { - x: 0.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - rotation { - x: 0.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - scale { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - size { - x: 300.0 - y: 300.0 - z: 0.0 - w: 1.0 - } - color { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - type: TYPE_BOX - blend_mode: BLEND_MODE_ALPHA - texture: "example/pixel" - id: "test_gui1/root" - xanchor: XANCHOR_NONE - yanchor: YANCHOR_NONE - pivot: PIVOT_CENTER - adjust_mode: ADJUST_MODE_FIT - parent: "test_gui1" - layer: "" - inherit_alpha: true - slice9 { - x: 0.0 - y: 0.0 - z: 0.0 - w: 0.0 - } - clipping_mode: CLIPPING_MODE_NONE - clipping_visible: true - clipping_inverted: false - alpha: 1.0 - template_node_child: true - size_mode: SIZE_MODE_MANUAL - custom_type: 0 - enabled: true - visible: true - material: "" -} -nodes { - position { - x: 0.0 - y: 100.0 - z: 0.0 - w: 1.0 - } - rotation { - x: 0.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - scale { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - size { - x: 200.0 - y: 50.0 - z: 0.0 - w: 1.0 - } - color { - x: 0.091 - y: 0.088 - z: 0.088 - w: 1.0 - } - type: TYPE_TEXT - blend_mode: BLEND_MODE_ALPHA - text: "Text" - font: "troika" - id: "test_gui1/text" - xanchor: XANCHOR_NONE - yanchor: YANCHOR_NONE - pivot: PIVOT_CENTER - outline { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - shadow { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - adjust_mode: ADJUST_MODE_FIT - line_break: false - parent: "test_gui1/root" - layer: "" - inherit_alpha: true - alpha: 1.0 - outline_alpha: 0.0 - shadow_alpha: 0.0 - template_node_child: true - text_leading: 1.0 - text_tracking: 0.0 - custom_type: 0 - enabled: true - visible: true - material: "" -} -nodes { - position { - x: -60.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - rotation { - x: 0.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - scale { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - size { - x: 200.0 - y: 100.0 - z: 0.0 - w: 1.0 - } - color { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - type: TYPE_BOX - blend_mode: BLEND_MODE_ALPHA - texture: "example/panthera" - id: "test_gui1/box" - xanchor: XANCHOR_NONE - yanchor: YANCHOR_NONE - pivot: PIVOT_CENTER - adjust_mode: ADJUST_MODE_FIT - parent: "test_gui1/root" - layer: "" - inherit_alpha: true - slice9 { - x: 0.0 - y: 0.0 - z: 0.0 - w: 0.0 - } - clipping_mode: CLIPPING_MODE_NONE - clipping_visible: true - clipping_inverted: false - alpha: 1.0 - template_node_child: true - size_mode: SIZE_MODE_AUTO - custom_type: 0 - enabled: true - visible: true - material: "" -} -nodes { - position { - x: 60.0 - y: -2.0 - z: 0.0 - w: 1.0 - } - rotation { - x: 0.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - scale { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - size { - x: 200.0 - y: 100.0 - z: 0.0 - w: 1.0 - } - color { - x: 1.0 - y: 1.0 - z: 1.0 - w: 1.0 - } - type: TYPE_PIE - blend_mode: BLEND_MODE_ALPHA - texture: "example/panthera" - id: "test_gui1/pie" - xanchor: XANCHOR_NONE - yanchor: YANCHOR_NONE - pivot: PIVOT_CENTER - adjust_mode: ADJUST_MODE_FIT - parent: "test_gui1/root" - layer: "" - inherit_alpha: true - outerBounds: PIEBOUNDS_RECTANGLE - innerRadius: 0.0 - perimeterVertices: 10 - pieFillAngle: 360.0 - clipping_mode: CLIPPING_MODE_NONE - clipping_visible: true - clipping_inverted: false - alpha: 1.0 - template_node_child: true - size_mode: SIZE_MODE_AUTO - custom_type: 0 - enabled: true - visible: true - material: "" -} material: "/builtins/materials/gui.material" adjust_reference: ADJUST_REFERENCE_PARENT max_nodes: 512 diff --git a/example/example_go_gui_templates/example_go_gui_templates.gui_script b/example/example_go_gui_templates/gui/example_gui_template_nodes.gui_script similarity index 72% rename from example/example_go_gui_templates/example_go_gui_templates.gui_script rename to example/example_go_gui_templates/gui/example_gui_template_nodes.gui_script index 77d7681..55062ca 100644 --- a/example/example_go_gui_templates/example_go_gui_templates.gui_script +++ b/example/example_go_gui_templates/gui/example_gui_template_nodes.gui_script @@ -8,26 +8,20 @@ function init(self) -- Run Panthera animation on GUI template nodes - local animation_template = panthera.create_gui(PATH, function(node_id) - return gui.get_node("test_gui/" .. node_id) - end) + local animation_template = panthera.create_gui(PATH, "test_gui") panthera.play(animation_template, "default", { is_loop = true }) --- Run Panthera animation on cloned GUI nodes local nodes = gui.clone_tree(gui.get_node("test_gui_inline")) gui.set_position(nodes["test_gui_inline"], vmath.vector3(-200, -240, 0)) - local animation_nodes = panthera.create_gui(PATH, function(node_id) - return nodes[node_id] - end) + local animation_nodes = panthera.create_gui(PATH, nil, nodes) panthera.play(animation_nodes, "default", { is_loop = true }) -- Run Panthera animation on cloned GUI template nodes local template_nodes = gui.clone_tree(gui.get_node("test_gui/root")) gui.set_position(template_nodes["test_gui/root"], vmath.vector3(200, -240, 0)) - local animation_template_nodes = panthera.create_gui(PATH, function(node_id) - return template_nodes["test_gui/" .. node_id] - end) + local animation_template_nodes = panthera.create_gui(PATH, "test_gui", template_nodes) panthera.play(animation_template_nodes, "default", { is_loop = true }) end \ No newline at end of file diff --git a/example/example_go_gui_templates/test_gui.gui b/example/example_go_gui_templates/gui/test_gui.gui similarity index 100% rename from example/example_go_gui_templates/test_gui.gui rename to example/example_go_gui_templates/gui/test_gui.gui diff --git a/example/example_go_gui_templates/test_collection.collection b/example/example_go_gui_templates/test_collection.collection deleted file mode 100644 index 8090f59..0000000 --- a/example/example_go_gui_templates/test_collection.collection +++ /dev/null @@ -1 +0,0 @@ -name: "test_collection" diff --git a/example/example_go_gui_templates/test_gui_template.gui b/example/example_go_gui_templates/test_gui_template.gui deleted file mode 100644 index 59ead4d..0000000 --- a/example/example_go_gui_templates/test_gui_template.gui +++ /dev/null @@ -1,18 +0,0 @@ -script: "" -fonts { - name: "troika" - font: "/example/assets/troika.font" -} -textures { - name: "example" - texture: "/example/assets/example.atlas" -} -background_color { - x: 0.0 - y: 0.0 - z: 0.0 - w: 0.0 -} -material: "/builtins/materials/gui.material" -adjust_reference: ADJUST_REFERENCE_PARENT -max_nodes: 512 diff --git a/game.project b/game.project index aa7ed59..321e138 100644 --- a/game.project +++ b/game.project @@ -1,5 +1,5 @@ [bootstrap] -main_collection = /example/example.collectionc +main_collection = /example/example_go_gui_templates/go/example_go_template_nodes.collectionc render = /example/default.renderc [script] diff --git a/panthera/adapters/adapter_go.lua b/panthera/adapters/adapter_go.lua index 936a853..6c6d707 100644 --- a/panthera/adapters/adapter_go.lua +++ b/panthera/adapters/adapter_go.lua @@ -230,13 +230,13 @@ local function get_node(node_id) end ----@param template string|nil ----@param nodes table|nil +---@param collection_name string|nil +---@param objects table|nil ---@return function(node_id: string): hash|url -local function get_node_fn(template, nodes) +local function get_node_function(collection_name, objects) return function(node_id) - if template then - node_id = template .. "/" .. node_id + if collection_name then + node_id = collection_name .. "/" .. node_id end local split_index = string.find(node_id, "#") @@ -245,8 +245,8 @@ local function get_node_fn(template, nodes) local fragment_id = string.sub(node_id, split_index + 1) local object_path = hash("/" .. object_id) - if nodes then - object_path = nodes[object_path] + if objects then + object_path = objects[object_path] end local object_url = msg.url(object_path) @@ -256,10 +256,9 @@ local function get_node_fn(template, nodes) end local object_path = hash("/" .. node_id) - if nodes then - object_path = nodes[object_path] + if objects then + object_path = objects[object_path] end - return object_path end end @@ -267,7 +266,7 @@ end local M = { get_node = get_node, - get_node_fn = get_node_fn, + get_node_function = get_node_function, get_easing = get_easing, set_node_property = set_node_property, get_node_property = get_node_property, diff --git a/panthera/adapters/adapter_gui.lua b/panthera/adapters/adapter_gui.lua index f2f2688..216bf75 100644 --- a/panthera/adapters/adapter_gui.lua +++ b/panthera/adapters/adapter_gui.lua @@ -261,6 +261,24 @@ local DEFOLD_TRIGGER_SETTER = { } +---@param template string|nil @GUI template path to load nodes from. Pass nil if no template is used +---@param nodes table|nil @Table with nodes from gui.clone_tree() function. Pass nil if no nodes are used +---@return fun(node_id: string): node +local function get_node_function(template, nodes) + return function(node_id) + if template then + node_id = template .. "/" .. node_id + end + + if nodes then + return nodes[node_id] + else + return gui.get_node(node_id) + end + end +end + + ---@param node node ---@param property_id string ---@param value any @@ -388,6 +406,7 @@ end local M = { get_node = gui.get_node, + get_node_function = get_node_function, get_easing = get_easing, stop_tween = stop_tween, set_node_property = set_node_property, diff --git a/panthera/panthera.lua b/panthera/panthera.lua index 93717bd..deaee19 100644 --- a/panthera/panthera.lua +++ b/panthera/panthera.lua @@ -15,18 +15,22 @@ end ---Load animation from JSON file and create it with Panthera GO adapter ---@param animation_path string ----@param get_node (fun(node_id: string): userdata|hash|url)|nil @Function to get node by node_id. Default is defined in adapter +---@param collection_name string|nil @Collection name to load nodes from. Pass nil if no collection is used +---@param objects table|nil @Table with game objects from collectionfactory. Pass nil if no objects are used ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message -function M.create_go(animation_path, get_node) +function M.create_go(animation_path, collection_name, objects) + local get_node = adapter_go.get_node_function(collection_name, objects) return M.create(animation_path, adapter_go, get_node) end ---Load animation from JSON file and create it with Panthera GUI adapter ---@param animation_path string ----@param get_node (fun(node_id: string): node)|nil @Function to get node by node_id. Default is defined in adapter +---@param template string|nil @The GUI template id to load nodes from. Pass nil if no template is used +---@param nodes table|nil @Table with nodes from gui.clone_tree() function. Pass nil if no nodes are used ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message -function M.create_gui(animation_path, get_node) +function M.create_gui(animation_path, template, nodes) + local get_node = adapter_gui.get_node_function(template, nodes) return M.create(animation_path, adapter_gui, get_node) end diff --git a/resources/test_go.json b/resources/test_go.json new file mode 100644 index 0000000..5f57304 --- /dev/null +++ b/resources/test_go.json @@ -0,0 +1 @@ +{"data":{"animations":[{"animation_id":"default","animation_keys":[{"duration":1,"easing":"outsine","end_value":1.4,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_x","start_value":1},{"duration":1,"easing":"outsine","end_value":1.4,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_y","start_value":1},{"duration":2,"easing":"outsine","end_value":0.189,"key_type":"tween","node_id":"panthera#label","property_id":"color_b","start_value":1},{"duration":2,"easing":"outsine","end_value":0.189,"key_type":"tween","node_id":"panthera#label","property_id":"color_g","start_value":1},{"duration":2,"easing":"outsine","end_value":0.816,"key_type":"tween","node_id":"panthera#label","property_id":"color_r","start_value":1},{"data":"Hey!","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Text","start_time":0.5},{"data":"Text is","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Hey!","start_time":1},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_x","start_time":1,"start_value":1.4},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_y","start_time":1,"start_value":1.4},{"data":"CHANING","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Text is","start_time":2},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_b","start_time":2,"start_value":0.189},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_g","start_time":2,"start_value":0.189},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_r","start_time":2,"start_value":0.816}],"duration":3}],"metadata":{"fps":60,"gizmo_steps":{"time":0.1},"settings":{"font_size":40}},"nodes":[{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"inherit_alpha":true,"node_id":"panthera","node_index":1,"node_type":"box","pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":1,"size_y":1},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"fill_angle":360,"inherit_alpha":true,"node_id":"panthera#sprite","node_index":2,"node_type":"box","outer_bounds":"ellipse","parent":"panthera","perimeter_vertices":10,"pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"auto","size_x":128,"size_y":128,"text_leading":1,"texture":"example/panthera","visible":true},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"fill_angle":360,"inherit_alpha":true,"node_id":"panthera#label","node_index":3,"node_type":"text","outer_bounds":"ellipse","parent":"panthera","perimeter_vertices":10,"pivot":"pivot_center","position_y":70,"scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":128,"size_y":32,"text":"Text","text_leading":1,"visible":true}]},"format":"json","type":"animation_editor","version":1} \ No newline at end of file diff --git a/resources/test_gui.json b/resources/test_gui.json index ca28b85..4790db6 100644 --- a/resources/test_gui.json +++ b/resources/test_gui.json @@ -1 +1 @@ -{"data":{"animations":[{"animation_id":"default","animation_keys":[{"duration":1,"easing":"outsine","end_value":-1,"key_type":"tween","node_id":"box","property_id":"scale_x","start_value":1},{"duration":1,"easing":"outsine","key_type":"tween","node_id":"pie","property_id":"fill_angle","start_value":360},{"duration":1.5,"easing":"outsine","end_value":0.27,"key_type":"tween","node_id":"text","property_id":"color_b","start_value":0.088},{"duration":1.5,"easing":"outsine","end_value":0.27,"key_type":"tween","node_id":"text","property_id":"color_g","start_value":0.088},{"duration":1.5,"easing":"outsine","end_value":0.83,"key_type":"tween","node_id":"text","property_id":"color_r","start_value":0.091},{"data":"Just","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Text","start_time":0.5},{"data":"Test","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Just","start_time":1},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"box","property_id":"scale_x","start_time":1,"start_value":-1},{"duration":1,"easing":"outsine","end_value":360,"key_type":"tween","node_id":"pie","property_id":"fill_angle","start_time":1},{"data":"Text Change","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Test","start_time":1.5},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_b","start_time":1.5,"start_value":0.27},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_g","start_time":1.5,"start_value":0.27},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_r","start_time":1.5,"start_value":0.83}],"duration":3}],"metadata":{"fps":60,"gizmo_steps":{"time":0.1},"gui_path":"/example/example_go_gui_templates/test_gui.gui","settings":{"font_size":40}},"nodes":[]},"format":"json","type":"animation_editor","version":1} \ No newline at end of file +{"data":{"animations":[{"animation_id":"default","animation_keys":[{"duration":1,"easing":"outsine","end_value":-1,"key_type":"tween","node_id":"box","property_id":"scale_x","start_value":1},{"duration":1,"easing":"outsine","key_type":"tween","node_id":"pie","property_id":"fill_angle","start_value":360},{"duration":1,"easing":"outsine","end_value":25,"key_type":"tween","node_id":"box","property_id":"rotation_z"},{"duration":1.5,"easing":"outsine","end_value":0.27,"key_type":"tween","node_id":"text","property_id":"color_b","start_value":0.088},{"duration":1.5,"easing":"outsine","end_value":0.27,"key_type":"tween","node_id":"text","property_id":"color_g","start_value":0.088},{"duration":1.5,"easing":"outsine","end_value":0.83,"key_type":"tween","node_id":"text","property_id":"color_r","start_value":0.091},{"data":"Just","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Text","start_time":0.5},{"data":"Test","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Just","start_time":1},{"duration":1,"easing":"outsine","key_type":"tween","node_id":"box","property_id":"rotation_z","start_time":1,"start_value":25},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"box","property_id":"scale_x","start_time":1,"start_value":-1},{"duration":1,"easing":"outsine","end_value":360,"key_type":"tween","node_id":"pie","property_id":"fill_angle","start_time":1},{"data":"Text Change","easing":"linear","key_type":"trigger","node_id":"text","property_id":"text","start_data":"Test","start_time":1.5},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_b","start_time":1.5,"start_value":0.27},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_g","start_time":1.5,"start_value":0.27},{"duration":1.5,"easing":"outsine","end_value":0.09,"key_type":"tween","node_id":"text","property_id":"color_r","start_time":1.5,"start_value":0.83}],"duration":3}],"metadata":{"fps":60,"gizmo_steps":{"time":0.1},"gui_path":"/example/example_go_gui_templates/test_gui.gui","settings":{"font_size":40}},"nodes":[]},"format":"json","type":"animation_editor","version":1} \ No newline at end of file From 01f50ea83ac81801c27f714daa7284d55236ca5e Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 20 Jul 2024 17:41:13 +0300 Subject: [PATCH 04/17] Update README to match new create_go/gui API --- README.md | 50 ++++++++++--------- .../go/example_go_template_nodes.script | 11 ++++ 2 files changed, 38 insertions(+), 23 deletions(-) diff --git a/README.md b/README.md index ba72885..c4783cb 100644 --- a/README.md +++ b/README.md @@ -174,21 +174,24 @@ panthera.create_gui(animation_path, [template], [nodes]) - **Usage Example:** ```lua -local gui_animation = panthera.create_gui("/animations/my_gui_animation.json") +local PATH = "/animations/my_gui_animation.json" --- Create animation over GUI template -local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", "template_name") +-- Run over gui on current scene +local gui_animation = panthera.create_gui(PATH) --- Create animation over cloned GUI template -local nodes = gui.clone_tree(gui.get_node("template_name/root")) -local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", "template_name", nodes) +-- Run over GUI template on current scene +local gui_animation = panthera.create_gui(PATH, "template_name") --- Create animation over cloned GUI nodes +-- Run over cloned GUI nodes local nodes = gui.clone_tree(gui.get_node("root")) -local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", nil, nodes) +local gui_animation = panthera.create_gui(PATH, nil, nodes) + +-- Create animation over cloned GUI template +local nodes = gui.clone_tree(gui.get_node("template_name/root")) +local gui_animation = panthera.create_gui(PATH, "template_name", nodes) -- Using Druid: -local gui_animation = panthera.create_gui("/animations/my_gui_animation.json", self:get_template(), self:get_nodes()) +local gui_animation = panthera.create_gui(PATH, self:get_template(), self:get_nodes()) ``` **panthera.create_go** @@ -198,12 +201,13 @@ Load and create a game object (GO) animation state from a JSON file. The Panthera uses `sys.load_resource` to load the animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. ```lua -panthera.create_go(animation_path, [get_node]) +panthera.create_go(animation_path, collection_name, objects) ``` - **Parameters:** - `animation_path`: The path to the animation JSON file. Example: `/animations/my_animation.json`. - - `get_node` (optional): A function to resolve nodes by their ID within the GO. If not provided, the adapter uses its default method from adapter implementation. + - `collection_name` (optional): The name of the collection to load objects from. Pass `nil` if no collection is used. + - `objects` (optional): Table with object ids from collectionfactory.create() function. Pass `nil` if objects are not created. - **Returns:** An animation state object or `nil` if the animation cannot be loaded. @@ -214,21 +218,21 @@ local go_animation = panthera.create_go("/animations/my_animation.json") ``` ```lua -local go_animation = panthera.create_go("/animations/my_animation.json", function(node_id) - -- This is the default get_node function in adapter_go. - -- The node_id for object components should be in the format "object_id#component_id", example: "player#sprite" - if string.find(node_id, "#") then - local object_id = string.sub(node_id, 1, string.find(node_id, "#") - 1) - local fragment_id = string.sub(node_id, string.find(node_id, "#") + 1) +local PATH = "/animations/my_animation.json" - local object_url = msg.url(hash("/" .. object_id)) - object_url.fragment = fragment_id +-- Run over objects on current scene +local go_animation = panthera.create_go(PATH) - return object_url - end +-- Run over collection on current scene +local go_animation = panthera.create_go(PATH, "collection_name") - return hash("/" .. node_id) -end +-- Run over objects from collection +local objects = collectionfactory.create("#collectionfactory") +local go_animation = panthera.create_go(PATH, nil, objects) + +-- Run over objects from collection inside spawned collection +local objects = collectionfactory.create("#collectionfactory") +local go_animation = panthera.create_go(PATH, "collection_name", objects) ``` **panthera.create** diff --git a/example/example_go_gui_templates/go/example_go_template_nodes.script b/example/example_go_gui_templates/go/example_go_template_nodes.script index 9e0723c..9d326ec 100644 --- a/example/example_go_gui_templates/go/example_go_template_nodes.script +++ b/example/example_go_gui_templates/go/example_go_template_nodes.script @@ -3,24 +3,35 @@ local PATH = "/resources/test_go.json" function init(self) -- Run Panthera over Game Object in collection + -- No any collection name or created objects local go_animation = panthera.create_go(PATH) panthera.play(go_animation, "default", { is_loop = true }) + -- Run Panthera over collection + -- Is a collection name, but no any created objects local go_animation = panthera.create_go(PATH, "test_collection") panthera.play(go_animation, "default", { is_loop = true }) + -- Run Panthera over nested collection + -- Is a still a collection, just inside another collection, so we concatenate collection names local go_animation = panthera.create_go(PATH, "test_inner_collection/test_collection") panthera.play(go_animation, "default", { is_loop = true }) + -- Run Panthera over collection from collectionfactory + -- We create a collection from collectionfactory and use this objects to run Panthera + -- The paths to the objects inside this collection are just paths without any collection names local objects = collectionfactory.create("#collectionfactory") go.set_position(vmath.vector3(640, 160, 0), objects["/panthera"]) local go_animation = panthera.create_go(PATH, nil, objects) panthera.play(go_animation, "default", { is_loop = true }) + -- Run Panthera over nested collection from collectionfactory + -- But here when we create a collection from collectionfactory, inside created objects we have a collection + -- So add a collection name and created objects local objects = collectionfactory.create("#collectionfactory_inner") go.set_position(vmath.vector3(860, 160, 0), objects["/test_collection/panthera"]) local go_animation = panthera.create_go(PATH, "test_collection", objects) From 86eae7e09b283bf19bd5e33eaf62281a98c187fd Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 20 Jul 2024 18:06:28 +0300 Subject: [PATCH 05/17] Add Defold annotations, refactor adapters --- .vscode/settings.json | 4 +- annotations/defold_annotations/b2d.body.lua | 275 ++++ annotations/defold_annotations/b2d.lua | 27 + annotations/defold_annotations/bit.lua | 104 ++ annotations/defold_annotations/buffer.lua | 107 ++ annotations/defold_annotations/builtins.lua | 32 + annotations/defold_annotations/camera.lua | 26 + .../defold_annotations/collectionfactory.lua | 86 ++ .../defold_annotations/collectionproxy.lua | 40 + annotations/defold_annotations/crash.lua | 117 ++ .../defold_annotations/defold_types.lua | 46 + annotations/defold_annotations/factory.lua | 78 ++ annotations/defold_annotations/go.lua | 355 +++++ annotations/defold_annotations/gui.lua | 1240 +++++++++++++++++ annotations/defold_annotations/html5.lua | 37 + annotations/defold_annotations/http.lua | 49 + annotations/defold_annotations/image.lua | 78 ++ annotations/defold_annotations/json.lua | 41 + annotations/defold_annotations/label.lua | 28 + annotations/defold_annotations/liveupdate.lua | 155 +++ annotations/defold_annotations/model.lua | 92 ++ annotations/defold_annotations/msg.lua | 54 + annotations/defold_annotations/particlefx.lua | 85 ++ annotations/defold_annotations/physics.lua | 307 ++++ annotations/defold_annotations/profiler.lua | 126 ++ annotations/defold_annotations/render.lua | 689 +++++++++ annotations/defold_annotations/resource.lua | 760 ++++++++++ annotations/defold_annotations/socket.lua | 173 +++ annotations/defold_annotations/sound.lua | 160 +++ annotations/defold_annotations/sprite.lua | 62 + annotations/defold_annotations/sys.lua | 314 +++++ annotations/defold_annotations/tilemap.lua | 90 ++ annotations/defold_annotations/timer.lua | 68 + annotations/defold_annotations/types.lua | 140 ++ annotations/defold_annotations/vmath.lua | 404 ++++++ annotations/defold_annotations/window.lua | 110 ++ annotations/defold_annotations/zlib.lua | 28 + docs/panthera_adapter.md | 6 +- example/default.render_script | 4 +- example/example.gui_script | 2 +- panthera/adapters/adapter_go.lua | 90 +- panthera/adapters/adapter_gui.lua | 7 +- panthera/panthera.lua | 10 +- resources/test_go.json | 2 +- 44 files changed, 6636 insertions(+), 72 deletions(-) create mode 100644 annotations/defold_annotations/b2d.body.lua create mode 100644 annotations/defold_annotations/b2d.lua create mode 100644 annotations/defold_annotations/bit.lua create mode 100644 annotations/defold_annotations/buffer.lua create mode 100644 annotations/defold_annotations/builtins.lua create mode 100644 annotations/defold_annotations/camera.lua create mode 100644 annotations/defold_annotations/collectionfactory.lua create mode 100644 annotations/defold_annotations/collectionproxy.lua create mode 100644 annotations/defold_annotations/crash.lua create mode 100644 annotations/defold_annotations/defold_types.lua create mode 100644 annotations/defold_annotations/factory.lua create mode 100644 annotations/defold_annotations/go.lua create mode 100644 annotations/defold_annotations/gui.lua create mode 100644 annotations/defold_annotations/html5.lua create mode 100644 annotations/defold_annotations/http.lua create mode 100644 annotations/defold_annotations/image.lua create mode 100644 annotations/defold_annotations/json.lua create mode 100644 annotations/defold_annotations/label.lua create mode 100644 annotations/defold_annotations/liveupdate.lua create mode 100644 annotations/defold_annotations/model.lua create mode 100644 annotations/defold_annotations/msg.lua create mode 100644 annotations/defold_annotations/particlefx.lua create mode 100644 annotations/defold_annotations/physics.lua create mode 100644 annotations/defold_annotations/profiler.lua create mode 100644 annotations/defold_annotations/render.lua create mode 100644 annotations/defold_annotations/resource.lua create mode 100644 annotations/defold_annotations/socket.lua create mode 100644 annotations/defold_annotations/sound.lua create mode 100644 annotations/defold_annotations/sprite.lua create mode 100644 annotations/defold_annotations/sys.lua create mode 100644 annotations/defold_annotations/tilemap.lua create mode 100644 annotations/defold_annotations/timer.lua create mode 100644 annotations/defold_annotations/types.lua create mode 100644 annotations/defold_annotations/vmath.lua create mode 100644 annotations/defold_annotations/window.lua create mode 100644 annotations/defold_annotations/zlib.lua diff --git a/.vscode/settings.json b/.vscode/settings.json index e215621..606ee1d 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -15,6 +15,8 @@ "vmath", "collectionfactory", "label", - "sprite" + "sprite", + "update", + "on_message" ] } diff --git a/annotations/defold_annotations/b2d.body.lua b/annotations/defold_annotations/b2d.body.lua new file mode 100644 index 0000000..d8434d3 --- /dev/null +++ b/annotations/defold_annotations/b2d.body.lua @@ -0,0 +1,275 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Box2D b2Body documentation + + Functions for interacting with Box2D bodies. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.b2d.body +b2d.body = {} + +---Dynamic body +b2d.body.B2_DYNAMIC_BODY = nil + +---Kinematic body +b2d.body.B2_KINEMATIC_BODY = nil + +---Static (immovable) body +b2d.body.B2_STATIC_BODY = nil + +---Apply an angular impulse. +---@param body b2Body body +---@param impulse number impulse the angular impulse in units of kgmm/s +function b2d.body.apply_angular_impulse(body, impulse) end + +---Apply a force at a world point. If the force is not +---applied at the center of mass, it will generate a torque and +---affect the angular velocity. This wakes up the body. +---@param body b2Body body +---@param force vector3 the world force vector, usually in Newtons (N). +---@param point vector3 the world position of the point of application. +function b2d.body.apply_force(body, force, point) end + +---Apply a force to the center of mass. This wakes up the body. +---@param body b2Body body +---@param force vector3 the world force vector, usually in Newtons (N). +function b2d.body.apply_force_to_center(body, force) end + +---Apply an impulse at a point. This immediately modifies the velocity. +---It also modifies the angular velocity if the point of application +---is not at the center of mass. This wakes up the body. +---@param body b2Body body +---@param impulse vector3 the world impulse vector, usually in N-seconds or kg-m/s. +---@param point vector3 the world position of the point of application. +function b2d.body.apply_linear_impulse(body, impulse, point) end + +---Apply a torque. This affects the angular velocity +---without affecting the linear velocity of the center of mass. +---This wakes up the body. +---@param body b2Body body +---@param torque number torque about the z-axis (out of the screen), usually in N-m. +function b2d.body.apply_torque(body, torque) end + +---Print the body representation to the log output +---@param body b2Body body +function b2d.body.dump(body) end + +---Get the angular damping of the body. +---@param body b2Body body +---@return number damping the damping +function b2d.body.get_angular_damping(body) end + +---Get the angular velocity. +---@param body b2Body body +---@return number velocity the angular velocity in radians/second. +function b2d.body.get_angular_velocity(body) end + +---Set the angular velocity. +---@param body b2Body body +---@param omega number the new angular velocity in radians/second. +function b2d.body.get_angular_velocity(body, omega) end + +---Get the gravity scale of the body. +---@param body b2Body body +---@return number scale the scale +function b2d.body.get_gravity_scale(body) end + +---Get the rotational inertia of the body about the local origin. +---@param body b2Body body +---@return number inertia the rotational inertia, usually in kg-m^2. +function b2d.body.get_inertia(body) end + +---Get the linear damping of the body. +---@param body b2Body body +---@return number damping the damping +function b2d.body.get_linear_damping(body) end + +---Get the linear velocity of the center of mass. +---@param body b2Body body +---@return vector3 velocity the linear velocity of the center of mass. +function b2d.body.get_linear_velocity(body) end + +---Get the world velocity of a local point. +---@param body b2Body body +---@param local_point vector3 a point in local coordinates. +---@return vector3 velocity the world velocity of a point. +function b2d.body.get_linear_velocity_from_local_point(body, local_point) end + +---Get the world linear velocity of a world point attached to this body. +---@param body b2Body body +---@param world_point vector3 a point in world coordinates. +---@return vector3 velocity the world velocity of a point. +function b2d.body.get_linear_velocity_from_world_point(body, world_point) end + +---Get the local position of the center of mass. +---@param body b2Body body +---@return vector3 center Get the local position of the center of mass. +function b2d.body.get_local_center(body) end + +---Gets a local point relative to the body's origin given a world point. +---@param body b2Body body +---@param world_point vector3 a point in world coordinates. +---@return vector3 vector the corresponding local point relative to the body's origin. +function b2d.body.get_local_point(body, world_point) end + +---Gets a local vector given a world vector. +---@param body b2Body body +---@param world_vector vector3 a vector in world coordinates. +---@return vector3 vector the corresponding local vector. +function b2d.body.get_local_vector(body, world_vector) end + +---Get the total mass of the body. +---@param body b2Body body +---@return number mass the mass, usually in kilograms (kg). +function b2d.body.get_mass(body) end + +---Get the next body in the world's body list. +---@param body b2Body body +---@return b2Body body the next body +function b2d.body.get_next(body) end + +---Get the world body origin position. +---@param body b2Body body +---@return vector3 position the world position of the body's origin. +function b2d.body.get_position(body) end + +---Get the type of this body. +---@param body b2Body body +---@return b2BodyType type the body type +function b2d.body.get_type(body) end + +---Get the parent world of this body. +---@param body b2Body body +---@return b2World world +function b2d.body.get_world(body) end + +---Get the angle in radians. +---@param body b2Body body +---@return number angle the current world rotation angle in radians. +function b2d.body.get_world_center(body) end + +---Get the world position of the center of mass. +---@param body b2Body body +---@return vector3 center Get the world position of the center of mass. +function b2d.body.get_world_center(body) end + +---Get the world coordinates of a point given the local coordinates. +---@param body b2Body body +---@param local_vector vector3 localPoint a point on the body measured relative the the body's origin. +---@return vector3 vector the same point expressed in world coordinates. +function b2d.body.get_world_point(body, local_vector) end + +---Get the world coordinates of a vector given the local coordinates. +---@param body b2Body body +---@param local_vector vector3 a vector fixed in the body. +---@return vector3 vector the same vector expressed in world coordinates. +function b2d.body.get_world_vector(body, local_vector) end + +---Get the active state of the body. +---@param body b2Body body +---@return bool enabled is the body active +function b2d.body.is_active(body) end + +---Get the sleeping state of this body. +---@param body b2Body body +---@return bool enabled true if the body is awake, false if it's sleeping. +function b2d.body.is_awake(body) end + +---Is this body in bullet mode +---@param body b2Body body +---@return bool enabled true if the body is in bullet mode +function b2d.body.is_bullet(body) end + +---Does this body have fixed rotation? +---@param body b2Body body +---@return bool enabled is the rotation fixed +function b2d.body.is_fixed_rotation(body) end + +---Is this body allowed to sleep +---@param body b2Body body +---@return bool enabled true if the body is allowed to sleep +function b2d.body.is_sleeping_allowed(body) end + +---This resets the mass properties to the sum of the mass properties of the fixtures. +---This normally does not need to be called unless you called SetMassData to override +---@param body b2Body body +function b2d.body.reset_mass_data(body) end + +---Set the active state of the body. An inactive body is not +---simulated and cannot be collided with or woken up. +---If you pass a flag of true, all fixtures will be added to the +---broad-phase. +---If you pass a flag of false, all fixtures will be removed from +---the broad-phase and all contacts will be destroyed. +---Fixtures and joints are otherwise unaffected. You may continue +---to create/destroy fixtures and joints on inactive bodies. +---Fixtures on an inactive body are implicitly inactive and will +---not participate in collisions, ray-casts, or queries. +---Joints connected to an inactive body are implicitly inactive. +---An inactive body is still owned by a b2World object and remains +---in the body list. +---@param body b2Body body +---@param enable bool true if the body should be active +function b2d.body.set_active(body, enable) end + +---Set the angular damping of the body. +---@param body b2Body body +---@param damping number the damping +function b2d.body.set_angular_damping(body, damping) end + +---Set the sleep state of the body. A sleeping body has very low CPU cost. +---@param body b2Body body +---@param enable bool flag set to false to put body to sleep, true to wake it. +function b2d.body.set_awake(body, enable) end + +---Should this body be treated like a bullet for continuous collision detection? +---@param body b2Body body +---@param enable bool if true, the body will be in bullet mode +function b2d.body.set_bullet(body, enable) end + +---Set this body to have fixed rotation. This causes the mass to be reset. +---@param body b2Body body +---@param enable bool true if the rotation should be fixed +function b2d.body.set_fixed_rotation(body, enable) end + +---Set the gravity scale of the body. +---@param body b2Body body +---@param scale number the scale +function b2d.body.set_gravity_scale(body, scale) end + +---Set the linear damping of the body. +---@param body b2Body body +---@param damping number the damping +function b2d.body.set_linear_damping(body, damping) end + +---Set the linear velocity of the center of mass. +---@param body b2Body body +---@param velocity vector3 the new linear velocity of the center of mass. +function b2d.body.set_linear_velocity(body, velocity) end + +---You can disable sleeping on this body. If you disable sleeping, the body will be woken. +---@param body b2Body body +---@param enable bool if false, the body will never sleep, and consume more CPU +function b2d.body.set_sleeping_allowed(body, enable) end + +---Set the position of the body's origin and rotation. +---This breaks any contacts and wakes the other bodies. +---Manipulating a body's transform may cause non-physical behavior. +---@param body b2Body body +---@param position vector3 the world position of the body's local origin. +---@param angle number the world position of the body's local origin. +function b2d.body.set_transform(body, position, angle) end + +---Set the type of this body. This may alter the mass and velocity. +---@param body b2Body body +---@param type b2BodyType the body type +function b2d.body.set_type(body, type) end + +return b2d.body \ No newline at end of file diff --git a/annotations/defold_annotations/b2d.lua b/annotations/defold_annotations/b2d.lua new file mode 100644 index 0000000..4741330 --- /dev/null +++ b/annotations/defold_annotations/b2d.lua @@ -0,0 +1,27 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Box2D documentation + + Functions for interacting with Box2D. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.b2d +b2d = {} + +---Get the Box2D body from a collision object +---@param url string|hash|url the url to the game object collision component +---@return b2Body body the body if successful. Otherwise nil. +function b2d.get_body(url) end + +---Get the Box2D world from the current collection +---@return b2World world the world if successful. Otherwise nil. +function b2d.get_world() end + +return b2d \ No newline at end of file diff --git a/annotations/defold_annotations/bit.lua b/annotations/defold_annotations/bit.lua new file mode 100644 index 0000000..46ac0c6 --- /dev/null +++ b/annotations/defold_annotations/bit.lua @@ -0,0 +1,104 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Bitwise operations API documentation + + Lua BitOp is a C extension module for Lua 5.1/5.2 which adds bitwise operations on numbers. + Lua BitOp is Copyright © 2008-2012 Mike Pall. + Lua BitOp is free software, released under the MIT license (same license as the Lua core). + Lua BitOp is compatible with the built-in bitwise operations in LuaJIT 2.0 and is used + on platforms where Defold runs without LuaJIT. + For clarity the examples assume the definition of a helper function printx(). + This prints its argument as an unsigned 32 bit hexadecimal number on all platforms: + function printx(x) + print("0x"..bit.tohex(x)) + end +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.bit +bit = {} + +---Returns the bitwise arithmetic right-shift of its first argument by the number of bits given by the second argument. +---Arithmetic right-shift treats the most-significant bit as a sign bit and replicates it. +---Only the lower 5 bits of the shift count are used (reduces to the range [0..31]). +---@param x number number +---@param n number number of bits +---@return number y bitwise arithmetic right-shifted number +function bit.arshift(x, n) end + +---Returns the bitwise and of all of its arguments. Note that more than two arguments are allowed. +---@param x1 number number +---@param ... number|nil number(s) +---@return number y bitwise and of the provided arguments +function bit.band(x1, ...) end + +---Returns the bitwise not of its argument. +---@param x number number +---@return number y bitwise not of number x +function bit.bnot(x) end + +---Returns the bitwise or of all of its arguments. Note that more than two arguments are allowed. +---@param x1 number number +---@param ... number|nil number(s) +---@return number y bitwise or of the provided arguments +function bit.bor(x1, ...) end + +---Swaps the bytes of its argument and returns it. This can be used to convert little-endian 32 bit numbers to big-endian 32 bit numbers or vice versa. +---@param x number number +---@return number y bitwise swapped number +function bit.bswap(x) end + +---Returns the bitwise xor of all of its arguments. Note that more than two arguments are allowed. +---@param x1 number number +---@param ... number|nil number(s) +---@return number y bitwise xor of the provided arguments +function bit.bxor(x1, ...) end + +---Returns the bitwise logical left-shift of its first argument by the number of bits given by the second argument. +---Logical shifts treat the first argument as an unsigned number and shift in 0-bits. +---Only the lower 5 bits of the shift count are used (reduces to the range [0..31]). +---@param x number number +---@param n number number of bits +---@return number y bitwise logical left-shifted number +function bit.lshift(x, n) end + +---Returns the bitwise left rotation of its first argument by the number of bits given by the second argument. Bits shifted out on one side are shifted back in on the other side. +---Only the lower 5 bits of the rotate count are used (reduces to the range [0..31]). +---@param x number number +---@param n number number of bits +---@return number y bitwise left-rotated number +function bit.rol(x, n) end + +---Returns the bitwise right rotation of its first argument by the number of bits given by the second argument. Bits shifted out on one side are shifted back in on the other side. +---Only the lower 5 bits of the rotate count are used (reduces to the range [0..31]). +---@param x number number +---@param n number number of bits +---@return number y bitwise right-rotated number +function bit.ror(x, n) end + +---Returns the bitwise logical right-shift of its first argument by the number of bits given by the second argument. +---Logical shifts treat the first argument as an unsigned number and shift in 0-bits. +---Only the lower 5 bits of the shift count are used (reduces to the range [0..31]). +---@param x number number +---@param n number number of bits +---@return number y bitwise logical right-shifted number +function bit.rshift(x, n) end + +---Normalizes a number to the numeric range for bit operations and returns it. This function is usually not needed since all bit operations already normalize all of their input arguments. +---@param x number number to normalize +---@return number y normalized number +function bit.tobit(x) end + +---Converts its first argument to a hex string. The number of hex digits is given by the absolute value of the optional second argument. Positive numbers between 1 and 8 generate lowercase hex digits. Negative numbers generate uppercase hex digits. Only the least-significant 4*|n| bits are used. The default is to generate 8 lowercase hex digits. +---@param x number number to convert +---@param n number number of hex digits to return +---@return string s hexadecimal string +function bit.tohex(x, n) end + +return bit \ No newline at end of file diff --git a/annotations/defold_annotations/buffer.lua b/annotations/defold_annotations/buffer.lua new file mode 100644 index 0000000..b44f05d --- /dev/null +++ b/annotations/defold_annotations/buffer.lua @@ -0,0 +1,107 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Buffer API documentation + + Functions for manipulating buffers and streams +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.buffer +buffer = {} + +---Float, single precision, 4 bytes +buffer.VALUE_TYPE_FLOAT32 = nil + +---Signed integer, 2 bytes +buffer.VALUE_TYPE_INT16 = nil + +---Signed integer, 4 bytes +buffer.VALUE_TYPE_INT32 = nil + +---Signed integer, 8 bytes +buffer.VALUE_TYPE_INT64 = nil + +---Signed integer, 1 byte +buffer.VALUE_TYPE_INT8 = nil + +---Unsigned integer, 2 bytes +buffer.VALUE_TYPE_UINT16 = nil + +---Unsigned integer, 4 bytes +buffer.VALUE_TYPE_UINT32 = nil + +---Unsigned integer, 8 bytes +buffer.VALUE_TYPE_UINT64 = nil + +---Unsigned integer, 1 byte +buffer.VALUE_TYPE_UINT8 = nil + +---Copy all data streams from one buffer to another, element wise. +--- Each of the source streams must have a matching stream in the +---destination buffer. The streams must match in both type and size. +---The source and destination buffer can be the same. +---@param dst buffer_data the destination buffer +---@param dstoffset number the offset to start copying data to +---@param src buffer_data the source data buffer +---@param srcoffset number the offset to start copying data from +---@param count number the number of elements to copy +function buffer.copy_buffer(dst, dstoffset, src, srcoffset, count) end + +---Copy a specified amount of data from one stream to another. +--- The value type and size must match between source and destination streams. +---The source and destination streams can be the same. +---@param dst buffer_stream the destination stream +---@param dstoffset number the offset to start copying data to (measured in value type) +---@param src buffer_stream the source data stream +---@param srcoffset number the offset to start copying data from (measured in value type) +---@param count number the number of values to copy (measured in value type) +function buffer.copy_stream(dst, dstoffset, src, srcoffset, count) end + +---Create a new data buffer containing a specified set of streams. A data buffer +---can contain one or more streams with typed data. This is useful for managing +---compound data, for instance a vertex buffer could contain separate streams for +---vertex position, color, normal etc. +---@param element_count number The number of elements the buffer should hold +---@param declaration { name:hash|string, type:constant, count:number }[] A table where each entry (table) describes a stream +--- +---hash | string name: The name of the stream +---constant type: The data type of the stream +---number count: The number of values each element should hold +--- +---@return buffer_data buffer the new buffer +function buffer.create(element_count, declaration) end + +---Get a copy of all the bytes from a specified stream as a Lua string. +---@param buffer buffer_data the source buffer +---@param stream_name hash the name of the stream +---@return string data the buffer data as a Lua string +function buffer.get_bytes(buffer, stream_name) end + +---Get a named metadata entry from a buffer along with its type. +---@param buf buffer_data the buffer to get the metadata from +---@param metadata_name hash|string name of the metadata entry +---@return number[]|nil values table of metadata values or nil if the entry does not exist +---@return constant|nil value_type numeric type of values or nil +function buffer.get_metadata(buf, metadata_name) end + +---Get a specified stream from a buffer. +---@param buffer buffer_data the buffer to get the stream from +---@param stream_name hash|string the stream name +---@return buffer_stream stream the data stream +function buffer.get_stream(buffer, stream_name) end + +---Creates or updates a metadata array entry on a buffer. +--- The value type and count given when updating the entry should match those used when first creating it. +---@param buf buffer_data the buffer to set the metadata on +---@param metadata_name hash|string name of the metadata entry +---@param values number[] actual metadata, an array of numeric values +---@param value_type constant type of values when stored +function buffer.set_metadata(buf, metadata_name, values, value_type) end + +return buffer \ No newline at end of file diff --git a/annotations/defold_annotations/builtins.lua b/annotations/defold_annotations/builtins.lua new file mode 100644 index 0000000..907dbb9 --- /dev/null +++ b/annotations/defold_annotations/builtins.lua @@ -0,0 +1,32 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Built-ins API documentation + + Built-in scripting functions. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---All ids in the engine are represented as hashes, so a string needs to be hashed +---before it can be compared with an id. +---@param s string string to hash +---@return hash hash a hashed string +function hash(s) end + +---Returns a hexadecimal representation of a hash value. +---The returned string is always padded with leading zeros. +---@param h hash hash value to get hex string for +---@return string hex hex representation of the hash +function hash_to_hex(h) end + +---Pretty printing of Lua values. This function prints Lua values +---in a manner similar to +print()+, but will also recurse into tables +---and pretty print them. There is a limit to how deep the function +---will recurse. +---@param ... any value to print +function pprint(...) end \ No newline at end of file diff --git a/annotations/defold_annotations/camera.lua b/annotations/defold_annotations/camera.lua new file mode 100644 index 0000000..a8152b3 --- /dev/null +++ b/annotations/defold_annotations/camera.lua @@ -0,0 +1,26 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.7.0 + + Camera API documentation + + Messages to control camera components and camera focus. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class camera +camera = {} + +---makes camera active +---@param url string|hash|url url of camera component +function camera.acquire_focus(url) end + +---deactivate camera +---@param url string|hash|url url of camera component +function camera.release_focus(url) end + +return camera \ No newline at end of file diff --git a/annotations/defold_annotations/collectionfactory.lua b/annotations/defold_annotations/collectionfactory.lua new file mode 100644 index 0000000..bb071a2 --- /dev/null +++ b/annotations/defold_annotations/collectionfactory.lua @@ -0,0 +1,86 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Collection factory API documentation + + Functions for controlling collection factory components which are + used to dynamically spawn collections into the runtime. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.collectionfactory +collectionfactory = {} + +---loaded +collectionfactory.STATUS_LOADED = nil + +---loading +collectionfactory.STATUS_LOADING = nil + +---unloaded +collectionfactory.STATUS_UNLOADED = nil + +---The URL identifies the collectionfactory component that should do the spawning. +---Spawning is instant, but spawned game objects get their first update calls the following frame. The supplied parameters for position, rotation and scale +---will be applied to the whole collection when spawned. +---Script properties in the created game objects can be overridden through +---a properties-parameter table. The table should contain game object ids +---(hash) as keys and property tables as values to be used when initiating each +---spawned game object. +---See go.property for more information on script properties. +---The function returns a table that contains a key for each game object +---id (hash), as addressed if the collection file was top level, and the +---corresponding spawned instance id (hash) as value with a unique path +---prefix added to each instance. +--- Calling collectionfactory.create create on a collection factory that is marked as dynamic without having loaded resources +---using collectionfactory.load will synchronously load and create resources which may affect application performance. +---@param url string|hash|url the collection factory component to be used +---@param position vector3|nil position to assign to the newly spawned collection +---@param rotation quaternion|nil rotation to assign to the newly spawned collection +---@param properties table|nil table of script properties to propagate to any new game object instances +---@param scale number|nil uniform scaling to apply to the newly spawned collection (must be greater than 0). +---@return table ids a table mapping the id:s from the collection to the new instance id:s +function collectionfactory.create(url, position, rotation, properties, scale) end + +---This returns status of the collection factory. +---Calling this function when the factory is not marked as dynamic loading always returns COMP_COLLECTION_FACTORY_STATUS_LOADED. +---@param url string|hash|url|nil the collection factory component to get status from +---@return constant status status of the collection factory component +--- +---collectionfactory.STATUS_UNLOADED +---collectionfactory.STATUS_LOADING +---collectionfactory.STATUS_LOADED +--- +function collectionfactory.get_status(url) end + +---Resources loaded are referenced by the collection factory component until the existing (parent) collection is destroyed or collectionfactory.unload is called. +---Calling this function when the factory is not marked as dynamic loading does nothing. +---@param url string|hash|url|nil the collection factory component to load +---@param complete_function fun(self, url, result)|nil function to call when resources are loaded. +--- +---self +---object The current object. +---url +---url url of the collection factory component +---result +---boolean True if resource were loaded successfully +--- +function collectionfactory.load(url, complete_function) end + +---Changes the prototype for the collection factory. +---Setting the prototype to "nil" will revert back to the original prototype. +---@param url string|hash|url|nil the collection factory component +---@param prototype string|nil the path to the new prototype, or nil +function collectionfactory.set_prototype(url, prototype) end + +---This decreases the reference count for each resource loaded with collectionfactory.load. If reference is zero, the resource is destroyed. +---Calling this function when the factory is not marked as dynamic loading does nothing. +---@param url string|hash|url|nil the collection factory component to unload +function collectionfactory.unload(url) end + +return collectionfactory \ No newline at end of file diff --git a/annotations/defold_annotations/collectionproxy.lua b/annotations/defold_annotations/collectionproxy.lua new file mode 100644 index 0000000..06648f4 --- /dev/null +++ b/annotations/defold_annotations/collectionproxy.lua @@ -0,0 +1,40 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Collection proxy API documentation + + Messages for controlling and interacting with collection proxies + which are used to dynamically load collections into the runtime. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.collectionproxy +collectionproxy = {} + +---return an indexed table of resources for a collection proxy. Each +---entry is a hexadecimal string that represents the data of the specific +---resource. This representation corresponds with the filename for each +---individual resource that is exported when you bundle an application with +---LiveUpdate functionality. +---@param collectionproxy url the collectionproxy to check for resources. +---@return string[] resources the resources +function collectionproxy.get_resources(collectionproxy) end + +---return an array of missing resources for a collection proxy. Each +---entry is a hexadecimal string that represents the data of the specific +---resource. This representation corresponds with the filename for each +---individual resource that is exported when you bundle an application with +---LiveUpdate functionality. It should be considered good practise to always +---check whether or not there are any missing resources in a collection proxy +---before attempting to load the collection proxy. +---@param collectionproxy url the collectionproxy to check for missing +---resources. +---@return string[] resources the missing resources +function collectionproxy.missing_resources(collectionproxy) end + +return collectionproxy \ No newline at end of file diff --git a/annotations/defold_annotations/crash.lua b/annotations/defold_annotations/crash.lua new file mode 100644 index 0000000..75cfc45 --- /dev/null +++ b/annotations/defold_annotations/crash.lua @@ -0,0 +1,117 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Crash API documentation + + Native crash logging functions and constants. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.crash +crash = {} + +---android build fingerprint +crash.SYSFIELD_ANDROID_BUILD_FINGERPRINT = nil + +---system device language as reported by sys.get_sys_info +crash.SYSFIELD_DEVICE_LANGUAGE = nil + +---device model as reported by sys.get_sys_info +crash.SYSFIELD_DEVICE_MODEL = nil + +---engine version as hash +crash.SYSFIELD_ENGINE_HASH = nil + +---engine version as release number +crash.SYSFIELD_ENGINE_VERSION = nil + +---system language as reported by sys.get_sys_info +crash.SYSFIELD_LANGUAGE = nil + +---device manufacturer as reported by sys.get_sys_info +crash.SYSFIELD_MANUFACTURER = nil + +---The max number of sysfields. +crash.SYSFIELD_MAX = nil + +---system name as reported by sys.get_sys_info +crash.SYSFIELD_SYSTEM_NAME = nil + +---system version as reported by sys.get_sys_info +crash.SYSFIELD_SYSTEM_VERSION = nil + +---system territory as reported by sys.get_sys_info +crash.SYSFIELD_TERRITORY = nil + +---The max number of user fields. +crash.USERFIELD_MAX = nil + +---The max size of a single user field. +crash.USERFIELD_SIZE = nil + +---A table is returned containing the addresses of the call stack. +---@param handle number crash dump handle +---@return table backtrace table containing the backtrace +function crash.get_backtrace(handle) end + +---The format of read text blob is platform specific +---and not guaranteed +---but can be useful for manual inspection. +---@param handle number crash dump handle +---@return string blob string with the platform specific data +function crash.get_extra_data(handle) end + +---The function returns a table containing entries with sub-tables that +---have fields 'name' and 'address' set for all loaded modules. +---@param handle number crash dump handle +---@return { name:string, address:string }[] modules module table +function crash.get_modules(handle) end + +---read signal number from a crash report +---@param handle number crash dump handle +---@return number signal signal number +function crash.get_signum(handle) end + +---reads a system field from a loaded crash dump +---@param handle number crash dump handle +---@param index number system field enum. Must be less than crash.SYSFIELD_MAX +---@return string|nil value value recorded in the crash dump, or nil if it didn't exist +function crash.get_sys_field(handle, index) end + +---reads user field from a loaded crash dump +---@param handle number crash dump handle +---@param index number user data slot index +---@return string value user data value recorded in the crash dump +function crash.get_user_field(handle, index) end + +---The crash dump will be removed from disk upon a successful +---load, so loading is one-shot. +---@return number|nil handle handle to the loaded dump, or nil if no dump was found +function crash.load_previous() end + +---releases a previously loaded crash dump +---@param handle number handle to loaded crash dump +function crash.release(handle) end + +---Crashes occuring before the path is set will be stored to a default engine location. +---@param path string file path to use +function crash.set_file_path(path) end + +---Store a user value that will get written to a crash dump when +---a crash occurs. This can be user id:s, breadcrumb data etc. +---There are 32 slots indexed from 0. Each slot stores at most 255 characters. +---@param index number slot index. 0-indexed +---@param value string string value to store +function crash.set_user_field(index, value) end + +---Performs the same steps as if a crash had just occured but +---allows the program to continue. +---The generated dump can be read by crash.load_previous +function crash.write_dump() end + +return crash \ No newline at end of file diff --git a/annotations/defold_annotations/defold_types.lua b/annotations/defold_annotations/defold_types.lua new file mode 100644 index 0000000..7b7821c --- /dev/null +++ b/annotations/defold_annotations/defold_types.lua @@ -0,0 +1,46 @@ +---@class action +---@field value number The amount of input given by the user. This is usually 1 for buttons and 0-1 for analogue inputs. This is not present for mouse movement. +---@field pressed boolean If the input was pressed this frame. This is not present for mouse movement. +---@field released boolean If the input was released this frame. This is not present for mouse movement. +---@field repeated boolean If the input was repeated this frame. This is similar to how a key on a keyboard is repeated when you hold it down. This is not present for mouse movement. +---@field x number The x value of a pointer device, if present. +---@field y number The y value of a pointer device, if present. +---@field screen_x number The screen space x value of a pointer device, if present. +---@field screen_y number The screen space y value of a pointer device, if present. +---@field dx number The change in x value of a pointer device, if present. +---@field dy number The change in y value of a pointer device, if present. +---@field screen_dx number The change in screen space x value of a pointer device, if present. +---@field screen_dy number The change in screen space y value of a pointer device, if present. +---@field gamepad number The index of the gamepad device that provided the input. +---@field touch touch[] List of touch input, one element per finger, if present. See table below about touch input + +---@class touch +---@field id number A number identifying the touch input during its duration. +---@field pressed boolean True if the finger was pressed this frame. +---@field released boolean True if the finger was released this frame. +---@field tap_count number Number of taps, one for single, two for double-tap, etc +---@field x number The x touch location. +---@field y number The y touch location. +---@field dx number The change in x value. +---@field dy number The change in y value. +---@field acc_x number|nil Accelerometer x value (if present). +---@field acc_y number|nil Accelerometer y value (if present). +---@field acc_z number|nil Accelerometer z value (if present). + +---@class utf8 +---@field len fun(s: string) +---@field sub fun(s: string, start_index: number, length: number) +---@field reverse fun() +---@field char fun() +---@field unicode fun() +---@field gensub fun() +---@field byte fun() +---@field find fun() +---@field match fun(s: string, m: string) +---@field gmatch fun(s: string, m: string) +---@field gsub fun() +---@field dump fun() +---@field format fun() +---@field lower fun() +---@field upper fun() +---@field rep fun() diff --git a/annotations/defold_annotations/factory.lua b/annotations/defold_annotations/factory.lua new file mode 100644 index 0000000..ba3c245 --- /dev/null +++ b/annotations/defold_annotations/factory.lua @@ -0,0 +1,78 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Factory API documentation + + Functions for controlling factory components which are used to + dynamically spawn game objects into the runtime. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.factory +factory = {} + +---loaded +factory.STATUS_LOADED = nil + +---loading +factory.STATUS_LOADING = nil + +---unloaded +factory.STATUS_UNLOADED = nil + +---The URL identifies which factory should create the game object. +---If the game object is created inside of the frame (e.g. from an update callback), the game object will be created instantly, but none of its component will be updated in the same frame. +---Properties defined in scripts in the created game object can be overridden through the properties-parameter below. +---See go.property for more information on script properties. +--- Calling factory.create on a factory that is marked as dynamic without having loaded resources +---using factory.load will synchronously load and create resources which may affect application performance. +---@param url string|hash|url the factory that should create a game object. +---@param position vector3|nil the position of the new game object, the position of the game object calling factory.create() is used by default, or if the value is nil. +---@param rotation quaternion|nil the rotation of the new game object, the rotation of the game object calling factory.create() is used by default, or if the value is nil. +---@param properties table|nil the properties defined in a script attached to the new game object. +---@param scale number|vector3|nil the scale of the new game object (must be greater than 0), the scale of the game object containing the factory is used by default, or if the value is nil +---@return hash id the global id of the spawned game object +function factory.create(url, position, rotation, properties, scale) end + +---This returns status of the factory. +---Calling this function when the factory is not marked as dynamic loading always returns +---factory.STATUS_LOADED. +---@param url string|hash|url|nil the factory component to get status from +---@return constant status status of the factory component +--- +---factory.STATUS_UNLOADED +---factory.STATUS_LOADING +---factory.STATUS_LOADED +--- +function factory.get_status(url) end + +---Resources are referenced by the factory component until the existing (parent) collection is destroyed or factory.unload is called. +---Calling this function when the factory is not marked as dynamic loading does nothing. +---@param url string|hash|url|nil the factory component to load +---@param complete_function fun(self, url, result)|nil function to call when resources are loaded. +--- +---self +---object The current object. +---url +---url url of the factory component +---result +---boolean True if resources were loaded successfully +--- +function factory.load(url, complete_function) end + +---Changes the prototype for the factory. +---@param url string|hash|url|nil the factory component +---@param prototype string|nil the path to the new prototype, or nil +function factory.set_prototype(url, prototype) end + +---This decreases the reference count for each resource loaded with factory.load. If reference is zero, the resource is destroyed. +---Calling this function when the factory is not marked as dynamic loading does nothing. +---@param url string|hash|url|nil the factory component to unload +function factory.unload(url) end + +return factory \ No newline at end of file diff --git a/annotations/defold_annotations/go.lua b/annotations/defold_annotations/go.lua new file mode 100644 index 0000000..60b4e5e --- /dev/null +++ b/annotations/defold_annotations/go.lua @@ -0,0 +1,355 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Game object API documentation + + Functions, core hooks, messages and constants for manipulation of + game objects. The "go" namespace is accessible from game object script + files. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.go +go = {} + +---in-back +go.EASING_INBACK = nil + +---in-bounce +go.EASING_INBOUNCE = nil + +---in-circlic +go.EASING_INCIRC = nil + +---in-cubic +go.EASING_INCUBIC = nil + +---in-elastic +go.EASING_INELASTIC = nil + +---in-exponential +go.EASING_INEXPO = nil + +---in-out-back +go.EASING_INOUTBACK = nil + +---in-out-bounce +go.EASING_INOUTBOUNCE = nil + +---in-out-circlic +go.EASING_INOUTCIRC = nil + +---in-out-cubic +go.EASING_INOUTCUBIC = nil + +---in-out-elastic +go.EASING_INOUTELASTIC = nil + +---in-out-exponential +go.EASING_INOUTEXPO = nil + +---in-out-quadratic +go.EASING_INOUTQUAD = nil + +---in-out-quartic +go.EASING_INOUTQUART = nil + +---in-out-quintic +go.EASING_INOUTQUINT = nil + +---in-out-sine +go.EASING_INOUTSINE = nil + +---in-quadratic +go.EASING_INQUAD = nil + +---in-quartic +go.EASING_INQUART = nil + +---in-quintic +go.EASING_INQUINT = nil + +---in-sine +go.EASING_INSINE = nil + +---linear interpolation +go.EASING_LINEAR = nil + +---out-back +go.EASING_OUTBACK = nil + +---out-bounce +go.EASING_OUTBOUNCE = nil + +---out-circlic +go.EASING_OUTCIRC = nil + +---out-cubic +go.EASING_OUTCUBIC = nil + +---out-elastic +go.EASING_OUTELASTIC = nil + +---out-exponential +go.EASING_OUTEXPO = nil + +---out-in-back +go.EASING_OUTINBACK = nil + +---out-in-bounce +go.EASING_OUTINBOUNCE = nil + +---out-in-circlic +go.EASING_OUTINCIRC = nil + +---out-in-cubic +go.EASING_OUTINCUBIC = nil + +---out-in-elastic +go.EASING_OUTINELASTIC = nil + +---out-in-exponential +go.EASING_OUTINEXPO = nil + +---out-in-quadratic +go.EASING_OUTINQUAD = nil + +---out-in-quartic +go.EASING_OUTINQUART = nil + +---out-in-quintic +go.EASING_OUTINQUINT = nil + +---out-in-sine +go.EASING_OUTINSINE = nil + +---out-quadratic +go.EASING_OUTQUAD = nil + +---out-quartic +go.EASING_OUTQUART = nil + +---out-quintic +go.EASING_OUTQUINT = nil + +---out-sine +go.EASING_OUTSINE = nil + +---loop backward +go.PLAYBACK_LOOP_BACKWARD = nil + +---loop forward +go.PLAYBACK_LOOP_FORWARD = nil + +---ping pong loop +go.PLAYBACK_LOOP_PINGPONG = nil + +---no playback +go.PLAYBACK_NONE = nil + +---once backward +go.PLAYBACK_ONCE_BACKWARD = nil + +---once forward +go.PLAYBACK_ONCE_FORWARD = nil + +---once ping pong +go.PLAYBACK_ONCE_PINGPONG = nil + +---This is only supported for numerical properties. If the node property is already being +---animated, that animation will be canceled and replaced by the new one. +---If a complete_function (lua function) is specified, that function will be called when the animation has completed. +---By starting a new animation in that function, several animations can be sequenced together. See the examples for more information. +--- If you call go.animate() from a game object's final() function, +---any passed complete_function will be ignored and never called upon animation completion. +---See the properties guide for which properties can be animated and the animation guide for how +---them. +---@param url string|hash|url url of the game object or component having the property +---@param property string|hash id of the property to animate +---@param playback constant playback mode of the animation +--- +---go.PLAYBACK_ONCE_FORWARD +---go.PLAYBACK_ONCE_BACKWARD +---go.PLAYBACK_ONCE_PINGPONG +---go.PLAYBACK_LOOP_FORWARD +---go.PLAYBACK_LOOP_BACKWARD +---go.PLAYBACK_LOOP_PINGPONG +--- +---@param to number|vector3|vector4|quaternion target property value +---@param easing constant|vector4|vector3 easing to use during animation. Either specify a constant, see the animation guide for a complete list, or a vmath.vector with a curve +---@param duration number duration of the animation in seconds +---@param delay number|nil delay before the animation starts in seconds +---@param complete_function fun(self, url, property)|nil optional function to call when the animation has completed +--- +---self +--- +---object The current object. +--- +---url +--- +---url The game object or component instance for which the property is animated. +--- +---property +--- +---hash The id of the animated property. +--- +--- +function go.animate(url, property, playback, to, easing, duration, delay, complete_function) end + +---By calling this function, all or specified stored property animations of the game object or component will be canceled. +---See the properties guide for which properties can be animated and the animation guide for how to animate them. +---@param url string|hash|url url of the game object or component +---@param property string|hash|nil optional id of the property to cancel +function go.cancel_animations(url, property) end + +---Delete one or more game objects identified by id. Deletion is asynchronous meaning that +---the game object(s) are scheduled for deletion which will happen at the end of the current +---frame. Note that game objects scheduled for deletion will be counted against +---max_instances in "game.project" until they are actually removed. +--- Deleting a game object containing a particle FX component emitting particles will not immediately stop the particle FX from emitting particles. You need to manually stop the particle FX using particlefx.stop(). +--- Deleting a game object containing a sound component that is playing will not immediately stop the sound from playing. You need to manually stop the sound using sound.stop(). +---@param id string|hash|url|table|nil optional id or table of id's of the instance(s) to delete, the instance of the calling script is deleted by default +---@param recursive boolean|nil optional boolean, set to true to recursively delete child hiearchy in child to parent order +function go.delete(id, recursive) end + +---check if the specified game object exists +---@param url string|hash|url url of the game object to check +---@return bool exists true if the game object exists +function go.exists(url) end + +---gets a named property of the specified game object or component +---@param url string|hash|url url of the game object or component having the property +---@param property string|hash id of the property to retrieve +---@param options table|nil optional options table +---- index integer index into array property (1 based) +---- key hash name of internal property +---@return any value the value of the specified property +function go.get(url, property, options) end + +---Returns or constructs an instance identifier. The instance id is a hash +---of the absolute path to the instance. +---If path is specified, it can either be absolute or relative to the instance of the calling script. +---If path is not specified, the id of the game object instance the script is attached to will be returned. +---@param path string|nil path of the instance for which to return the id +---@return hash id instance id +function go.get_id(path) end + +---Get the parent for a game object instance. +---@param id string|hash|url|nil optional id of the game object instance to get parent for, defaults to the instance containing the calling script +---@return hash|nil parent_id parent instance or nil +function go.get_parent(id) end + +---The position is relative the parent (if any). Use go.get_world_position to retrieve the global world position. +---@param id string|hash|url|nil optional id of the game object instance to get the position for, by default the instance of the calling script +---@return vector3 position instance position +function go.get_position(id) end + +---The rotation is relative to the parent (if any). Use go.get_world_rotation to retrieve the global world rotation. +---@param id string|hash|url|nil optional id of the game object instance to get the rotation for, by default the instance of the calling script +---@return quaternion rotation instance rotation +function go.get_rotation(id) end + +---The scale is relative the parent (if any). Use go.get_world_scale to retrieve the global world 3D scale factor. +---@param id string|hash|url|nil optional id of the game object instance to get the scale for, by default the instance of the calling script +---@return vector3 scale instance scale factor +function go.get_scale(id) end + +---The uniform scale is relative the parent (if any). If the underlying scale vector is non-uniform the min element of the vector is returned as the uniform scale factor. +---@param id string|hash|url|nil optional id of the game object instance to get the uniform scale for, by default the instance of the calling script +---@return number scale uniform instance scale factor +function go.get_scale_uniform(id) end + +---The function will return the world position calculated at the end of the previous frame. +---Use go.get_position to retrieve the position relative to the parent. +---@param id string|hash|url|nil optional id of the game object instance to get the world position for, by default the instance of the calling script +---@return vector3 position instance world position +function go.get_world_position(id) end + +---The function will return the world rotation calculated at the end of the previous frame. +---Use go.get_rotation to retrieve the rotation relative to the parent. +---@param id string|hash|url|nil optional id of the game object instance to get the world rotation for, by default the instance of the calling script +---@return quaternion rotation instance world rotation +function go.get_world_rotation(id) end + +---The function will return the world 3D scale factor calculated at the end of the previous frame. +---Use go.get_scale to retrieve the 3D scale factor relative to the parent. +---This vector is derived by decomposing the transformation matrix and should be used with care. +---For most cases it should be fine to use go.get_world_scale_uniform instead. +---@param id string|hash|url|nil optional id of the game object instance to get the world scale for, by default the instance of the calling script +---@return vector3 scale instance world 3D scale factor +function go.get_world_scale(id) end + +---The function will return the world scale factor calculated at the end of the previous frame. +---Use go.get_scale_uniform to retrieve the scale factor relative to the parent. +---@param id string|hash|url|nil optional id of the game object instance to get the world scale for, by default the instance of the calling script +---@return number scale instance world scale factor +function go.get_world_scale_uniform(id) end + +---The function will return the world transform matrix calculated at the end of the previous frame. +---@param id string|hash|url|nil optional id of the game object instance to get the world transform for, by default the instance of the calling script +---@return matrix4 transform instance world transform +function go.get_world_transform(id) end + +---This function defines a property which can then be used in the script through the self-reference. +---The properties defined this way are automatically exposed in the editor in game objects and collections which use the script. +---Note that you can only use this function outside any callback-functions like init and update. +---@param name string the id of the property +---@param value number|hash|url|vector3|vector4|quaternion|resource_data|boolean default value of the property. In the case of a url, only the empty constructor msg.url() is allowed. In the case of a resource one of the resource constructors (eg resource.atlas(), resource.font() etc) is expected. +function go.property(name, value) end + +---sets a named property of the specified game object or component, or a material constant +---@param url string|hash|url url of the game object or component having the property +---@param property string|hash id of the property to set +---@param value any|table the value to set +---@param options table|nil optional options table +---- index integer index into array property (1 based) +---- key hash name of internal property +function go.set(url, property, value, options) end + +---Sets the parent for a game object instance. This means that the instance will exist in the geometrical space of its parent, +---like a basic transformation hierarchy or scene graph. If no parent is specified, the instance will be detached from any parent and exist in world +---space. +---This function will generate a set_parent message. It is not until the message has been processed that the change actually takes effect. This +---typically happens later in the same frame or the beginning of the next frame. Refer to the manual to learn how messages are processed by the +---engine. +---@param id string|hash|url|nil optional id of the game object instance to set parent for, defaults to the instance containing the calling script +---@param parent_id string|hash|url|nil optional id of the new parent game object, defaults to detaching game object from its parent +---@param keep_world_transform boolean|nil optional boolean, set to true to maintain the world transform when changing spaces. Defaults to false. +function go.set_parent(id, parent_id, keep_world_transform) end + +---The position is relative to the parent (if any). The global world position cannot be manually set. +---@param position vector3 position to set +---@param id string|hash|url|nil optional id of the game object instance to set the position for, by default the instance of the calling script +function go.set_position(position, id) end + +---The rotation is relative to the parent (if any). The global world rotation cannot be manually set. +---@param rotation quaternion rotation to set +---@param id string|hash|url|nil optional id of the game object instance to get the rotation for, by default the instance of the calling script +function go.set_rotation(rotation, id) end + +---The scale factor is relative to the parent (if any). The global world scale factor cannot be manually set. +--- Physics are currently not affected when setting scale from this function. +---@param scale number|vector3 vector or uniform scale factor, must be greater than 0 +---@param id string|hash|url|nil optional id of the game object instance to get the scale for, by default the instance of the calling script +function go.set_scale(scale, id) end + +--- The function uses world transformation calculated at the end of previous frame. +---@param position vector3 position which need to be converted +---@param url string|hash|url url of the game object which coordinate system convert to +---@return vector3 converted_postion converted position +function go.world_to_local_position(position, url) end + +--- The function uses world transformation calculated at the end of previous frame. +---@param transformation matrix4 transformation which need to be converted +---@param url string|hash|url url of the game object which coordinate system convert to +---@return matrix4 converted_transform converted transformation +function go.world_to_local_transform(transformation, url) end + + + +return go \ No newline at end of file diff --git a/annotations/defold_annotations/gui.lua b/annotations/defold_annotations/gui.lua new file mode 100644 index 0000000..3fa05ff --- /dev/null +++ b/annotations/defold_annotations/gui.lua @@ -0,0 +1,1240 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + GUI API documentation + + GUI core hooks, functions, messages, properties and constants for + creation and manipulation of GUI nodes. The "gui" namespace is + accessible only from gui scripts. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.gui +gui = {} + +---Adjust mode is used when the screen resolution differs from the project settings. +---The fit mode ensures that the entire node is visible in the adjusted gui scene. +gui.ADJUST_FIT = nil + +---Adjust mode is used when the screen resolution differs from the project settings. +---The stretch mode ensures that the node is displayed as is in the adjusted gui scene, which might scale it non-uniformally. +gui.ADJUST_STRETCH = nil + +---Adjust mode is used when the screen resolution differs from the project settings. +---The zoom mode ensures that the node fills its entire area and might make the node exceed it. +gui.ADJUST_ZOOM = nil + +---bottom y-anchor +gui.ANCHOR_BOTTOM = nil + +---left x-anchor +gui.ANCHOR_LEFT = nil + +---no anchor +gui.ANCHOR_NONE = nil + +---right x-anchor +gui.ANCHOR_RIGHT = nil + +---top y-anchor +gui.ANCHOR_TOP = nil + +---additive blending +gui.BLEND_ADD = nil + +---additive alpha blending +gui.BLEND_ADD_ALPHA = nil + +---alpha blending +gui.BLEND_ALPHA = nil + +---multiply blending +gui.BLEND_MULT = nil + +---screen blending +gui.BLEND_SCREEN = nil + +---clipping mode none +gui.CLIPPING_MODE_NONE = nil + +---clipping mode stencil +gui.CLIPPING_MODE_STENCIL = nil + +---in-back +gui.EASING_INBACK = nil + +---in-bounce +gui.EASING_INBOUNCE = nil + +---in-circlic +gui.EASING_INCIRC = nil + +---in-cubic +gui.EASING_INCUBIC = nil + +---in-elastic +gui.EASING_INELASTIC = nil + +---in-exponential +gui.EASING_INEXPO = nil + +---in-out-back +gui.EASING_INOUTBACK = nil + +---in-out-bounce +gui.EASING_INOUTBOUNCE = nil + +---in-out-circlic +gui.EASING_INOUTCIRC = nil + +---in-out-cubic +gui.EASING_INOUTCUBIC = nil + +---in-out-elastic +gui.EASING_INOUTELASTIC = nil + +---in-out-exponential +gui.EASING_INOUTEXPO = nil + +---in-out-quadratic +gui.EASING_INOUTQUAD = nil + +---in-out-quartic +gui.EASING_INOUTQUART = nil + +---in-out-quintic +gui.EASING_INOUTQUINT = nil + +---in-out-sine +gui.EASING_INOUTSINE = nil + +---in-quadratic +gui.EASING_INQUAD = nil + +---in-quartic +gui.EASING_INQUART = nil + +---in-quintic +gui.EASING_INQUINT = nil + +---in-sine +gui.EASING_INSINE = nil + +---linear interpolation +gui.EASING_LINEAR = nil + +---out-back +gui.EASING_OUTBACK = nil + +---out-bounce +gui.EASING_OUTBOUNCE = nil + +---out-circlic +gui.EASING_OUTCIRC = nil + +---out-cubic +gui.EASING_OUTCUBIC = nil + +---out-elastic +gui.EASING_OUTELASTIC = nil + +---out-exponential +gui.EASING_OUTEXPO = nil + +---out-in-back +gui.EASING_OUTINBACK = nil + +---out-in-bounce +gui.EASING_OUTINBOUNCE = nil + +---out-in-circlic +gui.EASING_OUTINCIRC = nil + +---out-in-cubic +gui.EASING_OUTINCUBIC = nil + +---out-in-elastic +gui.EASING_OUTINELASTIC = nil + +---out-in-exponential +gui.EASING_OUTINEXPO = nil + +---out-in-quadratic +gui.EASING_OUTINQUAD = nil + +---out-in-quartic +gui.EASING_OUTINQUART = nil + +---out-in-quintic +gui.EASING_OUTINQUINT = nil + +---out-in-sine +gui.EASING_OUTINSINE = nil + +---out-quadratic +gui.EASING_OUTQUAD = nil + +---out-quartic +gui.EASING_OUTQUART = nil + +---out-quintic +gui.EASING_OUTQUINT = nil + +---out-sine +gui.EASING_OUTSINE = nil + +---default keyboard +gui.KEYBOARD_TYPE_DEFAULT = nil + +---email keyboard +gui.KEYBOARD_TYPE_EMAIL = nil + +---number input keyboard +gui.KEYBOARD_TYPE_NUMBER_PAD = nil + +---password keyboard +gui.KEYBOARD_TYPE_PASSWORD = nil + +---elliptical pie node bounds +gui.PIEBOUNDS_ELLIPSE = nil + +---rectangular pie node bounds +gui.PIEBOUNDS_RECTANGLE = nil + +---center pivot +gui.PIVOT_CENTER = nil + +---east pivot +gui.PIVOT_E = nil + +---north pivot +gui.PIVOT_N = nil + +---north-east pivot +gui.PIVOT_NE = nil + +---north-west pivot +gui.PIVOT_NW = nil + +---south pivot +gui.PIVOT_S = nil + +---south-east pivot +gui.PIVOT_SE = nil + +---south-west pivot +gui.PIVOT_SW = nil + +---west pivot +gui.PIVOT_W = nil + +---loop backward +gui.PLAYBACK_LOOP_BACKWARD = nil + +---loop forward +gui.PLAYBACK_LOOP_FORWARD = nil + +---ping pong loop +gui.PLAYBACK_LOOP_PINGPONG = nil + +---once backward +gui.PLAYBACK_ONCE_BACKWARD = nil + +---once forward +gui.PLAYBACK_ONCE_FORWARD = nil + +---once forward and then backward +gui.PLAYBACK_ONCE_PINGPONG = nil + +---color property +gui.PROP_COLOR = nil + +---euler property +gui.PROP_EULER = nil + +---fill_angle property +gui.PROP_FILL_ANGLE = nil + +---inner_radius property +gui.PROP_INNER_RADIUS = nil + +---outline color property +gui.PROP_OUTLINE = nil + +---position property +gui.PROP_POSITION = nil + +---rotation property +gui.PROP_ROTATION = nil + +---scale property +gui.PROP_SCALE = nil + +---shadow color property +gui.PROP_SHADOW = nil + +---size property +gui.PROP_SIZE = nil + +---slice9 property +gui.PROP_SLICE9 = nil + +---The provided data is not in the expected format or is in some other way +---incorrect, for instance the image data provided to gui.new_texture(). +gui.RESULT_DATA_ERROR = nil + +---The system is out of resources, for instance when trying to create a new +---texture using gui.new_texture(). +gui.RESULT_OUT_OF_RESOURCES = nil + +---The texture id already exists when trying to use gui.new_texture(). +gui.RESULT_TEXTURE_ALREADY_EXISTS = nil + +---The size of the node is determined by the currently assigned texture. +gui.SIZE_MODE_AUTO = nil + +---The size of the node is determined by the size set in the editor, the constructor or by gui.set_size() +gui.SIZE_MODE_MANUAL = nil + +---This starts an animation of a node property according to the specified parameters. +---If the node property is already being animated, that animation will be canceled and +---replaced by the new one. Note however that several different node properties +---can be animated simultaneously. Use gui.cancel_animation to stop the animation +---before it has completed. +---Composite properties of type vector3, vector4 or quaternion +---also expose their sub-components (x, y, z and w). +---You can address the components individually by suffixing the name with a dot '.' +---and the name of the component. +---For instance, "position.x" (the position x coordinate) or "color.w" +---(the color alpha value). +---If a complete_function (Lua function) is specified, that function will be called +---when the animation has completed. +---By starting a new animation in that function, several animations can be sequenced +---together. See the examples below for more information. +---@param node node node to animate +---@param property string|constant property to animate +--- +---"position" +---"rotation" +---"euler" +---"scale" +---"color" +---"outline" +---"shadow" +---"size" +---"fill_angle" (pie) +---"inner_radius" (pie) +---"slice9" (slice9) +--- +---The following property constants are defined equaling the corresponding property string names. +--- +---gui.PROP_POSITION +---gui.PROP_ROTATION +---gui.PROP_EULER +---gui.PROP_SCALE +---gui.PROP_COLOR +---gui.PROP_OUTLINE +---gui.PROP_SHADOW +---gui.PROP_SIZE +---gui.PROP_FILL_ANGLE +---gui.PROP_INNER_RADIUS +---gui.PROP_SLICE9 +--- +---@param to number|vector3|vector4|quaternion target property value +---@param easing constant|vector4|vector3 easing to use during animation. +--- Either specify one of the gui.EASING_* constants or provide a +--- vector with a custom curve. See the animation guide for more information. +---@param duration number duration of the animation in seconds. +---@param delay number|nil delay before the animation starts in seconds. +---@param complete_function fun(self, node)|nil function to call when the +--- animation has completed +---@param playback constant|nil playback mode +--- +---gui.PLAYBACK_ONCE_FORWARD +---gui.PLAYBACK_ONCE_BACKWARD +---gui.PLAYBACK_ONCE_PINGPONG +---gui.PLAYBACK_LOOP_FORWARD +---gui.PLAYBACK_LOOP_BACKWARD +---gui.PLAYBACK_LOOP_PINGPONG +--- +function gui.animate(node, property, to, easing, duration, delay, complete_function, playback) end + +---If an animation of the specified node is currently running (started by gui.animate), it will immediately be canceled. +---@param node node node that should have its animation canceled +---@param property string|constant property for which the animation should be canceled +--- +---"position" +---"rotation" +---"euler" +---"scale" +---"color" +---"outline" +---"shadow" +---"size" +---"fill_angle" (pie) +---"inner_radius" (pie) +---"slice9" (slice9) +--- +function gui.cancel_animation(node, property) end + +---Cancels any running flipbook animation on the specified node. +---@param node node node cancel flipbook animation for +function gui.cancel_flipbook(node) end + +---Make a clone instance of a node. The cloned node will be identical to the +---original node, except the id which is generated as the string "node" plus +---a sequential unsigned integer value. +---This function does not clone the supplied node's children nodes. +---Use gui.clone_tree for that purpose. +---@param node node node to clone +---@return node clone the cloned node +function gui.clone(node) end + +---Make a clone instance of a node and all its children. +---Use gui.clone to clone a node excluding its children. +---@param node node root node to clone +---@return table clones a table mapping node ids to the corresponding cloned nodes +function gui.clone_tree(node) end + +---Deletes the specified node. Any child nodes of the specified node will be +---recursively deleted. +---@param node node node to delete +function gui.delete_node(node) end + +---Delete a dynamically created texture. +---@param texture string|hash texture id +function gui.delete_texture(texture) end + +---Instead of using specific getters such as gui.get_position or gui.get_scale, +---you can use gui.get instead and supply the property as a string or a hash. +---While this function is similar to go.get, there are a few more restrictions +---when operating in the gui namespace. Most notably, only these propertie identifiers are supported: +---"position" +---"rotation" +---"euler" +---"scale" +---"color" +---"outline" +---"shadow" +---"size" +---"fill_angle" (pie) +---"inner_radius" (pie) +---"slice9" (slice9) +---The value returned will either be a vmath.vector4 or a single number, i.e getting the "position" +---property will return a vec4 while getting the "position.x" property will return a single value. +---@param node node node to get the property for +---@param property string|hash|constant the property to retrieve +function gui.get(node, property) end + +---Returns the adjust mode of a node. +---The adjust mode defines how the node will adjust itself to screen +---resolutions that differs from the one in the project settings. +---@param node node node from which to get the adjust mode (node) +---@return constant adjust_mode the current adjust mode +--- +---gui.ADJUST_FIT +---gui.ADJUST_ZOOM +---gui.ADJUST_STRETCH +--- +function gui.get_adjust_mode(node) end + +---gets the node alpha +---@param node node node from which to get alpha +function gui.get_alpha(node) end + +---Returns the blend mode of a node. +---Blend mode defines how the node will be blended with the background. +---@param node node node from which to get the blend mode +---@return constant blend_mode blend mode +--- +---gui.BLEND_ALPHA +---gui.BLEND_ADD +---gui.BLEND_ADD_ALPHA +---gui.BLEND_MULT +---gui.BLEND_SCREEN +--- +function gui.get_blend_mode(node) end + +---If node is set as an inverted clipping node, it will clip anything inside as opposed to outside. +---@param node node node from which to get the clipping inverted state +---@return boolean inverted true or false +function gui.get_clipping_inverted(node) end + +---Clipping mode defines how the node will clip it's children nodes +---@param node node node from which to get the clipping mode +---@return constant clipping_mode clipping mode +--- +--- gui.CLIPPING_MODE_NONE +--- gui.CLIPPING_MODE_STENCIL +--- +function gui.get_clipping_mode(node) end + +---If node is set as visible clipping node, it will be shown as well as clipping. Otherwise, it will only clip but not show visually. +---@param node node node from which to get the clipping visibility state +---@return boolean visible true or false +function gui.get_clipping_visible(node) end + +---Returns the color of the supplied node. The components +---of the returned vector4 contains the color channel values: +---Component +---Color value +---x +---Red value +---y +---Green value +---z +---Blue value +---w +---Alpha value +---@param node node node to get the color from +---@return vector4 color node color +function gui.get_color(node) end + +---Returns the rotation of the supplied node. +---The rotation is expressed in degree Euler angles. +---@param node node node to get the rotation from +---@return vector3 rotation node rotation +function gui.get_euler(node) end + +---Returns the sector angle of a pie node. +---@param node node node from which to get the fill angle +---@return number angle sector angle +function gui.get_fill_angle(node) end + +---Get node flipbook animation. +---@param node node node to get flipbook animation from +---@return hash animation animation id +function gui.get_flipbook(node) end + +---This is only useful nodes with flipbook animations. Gets the normalized cursor of the flipbook animation on a node. +---@param node node node to get the cursor for (node) +---@return number cursor cursor value +function gui.get_flipbook_cursor(node) end + +---This is only useful nodes with flipbook animations. Gets the playback rate of the flipbook animation on a node. +---@param node node node to set the cursor for +---@return number rate playback rate +function gui.get_flipbook_playback_rate(node) end + +---This is only useful for text nodes. The font must be mapped to the gui scene in the gui editor. +---@param node node node from which to get the font +---@return hash font font id +function gui.get_font(node) end + +---This is only useful for text nodes. The font must be mapped to the gui scene in the gui editor. +---@param font_name hash|string font of which to get the path hash +---@return hash hash path hash to resource +function gui.get_font_resource(font_name) end + +---Returns the scene height. +---@return number height scene height +function gui.get_height() end + +---Retrieves the id of the specified node. +---@param node node the node to retrieve the id from +---@return hash id the id of the node +function gui.get_id(node) end + +---Retrieve the index of the specified node among its siblings. +---The index defines the order in which a node appear in a GUI scene. +---Higher index means the node is drawn on top of lower indexed nodes. +---@param node node the node to retrieve the id from +---@return number index the index of the node +function gui.get_index(node) end + +---gets the node inherit alpha state +---@param node node node from which to get the inherit alpha state +function gui.get_inherit_alpha(node) end + +---Returns the inner radius of a pie node. +---The radius is defined along the x-axis. +---@param node node node from where to get the inner radius +---@return number radius inner radius +function gui.get_inner_radius(node) end + +---The layer must be mapped to the gui scene in the gui editor. +---@param node node node from which to get the layer +---@return hash layer layer id +function gui.get_layer(node) end + +---gets the scene current layout +---@return hash layout layout id +function gui.get_layout() end + +---Returns the leading value for a text node. +---@param node node node from where to get the leading +---@return number leading leading scaling value (default=1) +function gui.get_leading(node) end + +---Returns whether a text node is in line-break mode or not. +---This is only useful for text nodes. +---@param node node node from which to get the line-break for +---@return boolean line_break true or false +function gui.get_line_break(node) end + +---Returns the material of a node. +---The material must be mapped to the gui scene in the gui editor. +---@param node node node to get the material for +function gui.get_material(node) end + +---Retrieves the node with the specified id. +---@param id string|hash id of the node to retrieve +---@return node instance a new node instance +function gui.get_node(id) end + +---Returns the outer bounds mode for a pie node. +---@param node node node from where to get the outer bounds mode +---@return constant bounds_mode the outer bounds mode of the pie node: +--- +---gui.PIEBOUNDS_RECTANGLE +---gui.PIEBOUNDS_ELLIPSE +--- +function gui.get_outer_bounds(node) end + +---Returns the outline color of the supplied node. +---See gui.get_color for info how vectors encode color values. +---@param node node node to get the outline color from +---@return vector4 color outline color +function gui.get_outline(node) end + +---Returns the parent node of the specified node. +---If the supplied node does not have a parent, nil is returned. +---@param node node the node from which to retrieve its parent +---@return node|nil parent parent instance or nil +function gui.get_parent(node) end + +---Get the paricle fx for a gui node +---@param node node node to get particle fx for +---@return hash particlefx particle fx id +function gui.get_particlefx(node) end + +---Returns the number of generated vertices around the perimeter +---of a pie node. +---@param node node pie node +---@return number vertices vertex count +function gui.get_perimeter_vertices(node) end + +---The pivot specifies how the node is drawn and rotated from its position. +---@param node node node to get pivot from +---@return constant pivot pivot constant +--- +--- gui.PIVOT_CENTER +--- gui.PIVOT_N +--- gui.PIVOT_NE +--- gui.PIVOT_E +--- gui.PIVOT_SE +--- gui.PIVOT_S +--- gui.PIVOT_SW +--- gui.PIVOT_W +--- gui.PIVOT_NW +--- +function gui.get_pivot(node) end + +---Returns the position of the supplied node. +---@param node node node to get the position from +---@return vector3 position node position +function gui.get_position(node) end + +---Returns the rotation of the supplied node. +---The rotation is expressed as a quaternion +---@param node node node to get the rotation from +---@return quaternion rotation node rotation +function gui.get_rotation(node) end + +---Returns the scale of the supplied node. +---@param node node node to get the scale from +---@return vector3 scale node scale +function gui.get_scale(node) end + +---Returns the screen position of the supplied node. This function returns the +---calculated transformed position of the node, taking into account any parent node +---transforms. +---@param node node node to get the screen position from +---@return vector3 position node screen position +function gui.get_screen_position(node) end + +---Returns the shadow color of the supplied node. +---See gui.get_color for info how vectors encode color values. +---@param node node node to get the shadow color from +---@return vector4 color node shadow color +function gui.get_shadow(node) end + +---Returns the size of the supplied node. +---@param node node node to get the size from +---@return vector3 size node size +function gui.get_size(node) end + +---Returns the size of a node. +---The size mode defines how the node will adjust itself in size. Automatic +---size mode alters the node size based on the node's content. Automatic size +---mode works for Box nodes and Pie nodes which will both adjust their size +---to match the assigned image. Particle fx and Text nodes will ignore +---any size mode setting. +---@param node node node from which to get the size mode (node) +---@return constant size_mode the current size mode +--- +---gui.SIZE_MODE_MANUAL +---gui.SIZE_MODE_AUTO +--- +function gui.get_size_mode(node) end + +---Returns the slice9 configuration values for the node. +---@param node node node to manipulate +---@return vector4 values configuration values +function gui.get_slice9(node) end + +---Returns the text value of a text node. This is only useful for text nodes. +---@param node node node from which to get the text +---@return string text text value +function gui.get_text(node) end + +---Returns the texture of a node. +---This is currently only useful for box or pie nodes. +---The texture must be mapped to the gui scene in the gui editor. +---@param node node node to get texture from +---@return hash texture texture id +function gui.get_texture(node) end + +---Returns the tracking value of a text node. +---@param node node node from where to get the tracking +---@return number tracking tracking scaling number (default=0) +function gui.get_tracking(node) end + +---Get a node and all its children as a Lua table. +---@param node node root node to get node tree from +---@return table clones a table mapping node ids to the corresponding nodes +function gui.get_tree(node) end + +---Returns true if a node is visible and false if it's not. +---Invisible nodes are not rendered. +---@param node node node to query +---@return boolean visible whether the node is visible or not +function gui.get_visible(node) end + +---Returns the scene width. +---@return number width scene width +function gui.get_width() end + +---The x-anchor specifies how the node is moved when the game is run in a different resolution. +---@param node node node to get x-anchor from +---@return constant anchor anchor constant +--- +---gui.ANCHOR_NONE +---gui.ANCHOR_LEFT +---gui.ANCHOR_RIGHT +--- +function gui.get_xanchor(node) end + +---The y-anchor specifies how the node is moved when the game is run in a different resolution. +---@param node node node to get y-anchor from +---@return constant anchor anchor constant +--- +---gui.ANCHOR_NONE +---gui.ANCHOR_TOP +---gui.ANCHOR_BOTTOM +--- +function gui.get_yanchor(node) end + +---Hides the on-display touch keyboard on the device. +function gui.hide_keyboard() end + +---Returns true if a node is enabled and false if it's not. +---Disabled nodes are not rendered and animations acting on them are not evaluated. +---@param node node node to query +---@param recursive boolean|nil check hierarchy recursively +---@return boolean enabled whether the node is enabled or not +function gui.is_enabled(node, recursive) end + +---Alters the ordering of the two supplied nodes by moving the first node +---above the second. +---If the second argument is nil the first node is moved to the top. +---@param node node to move +---@param reference node|nil reference node above which the first node should be moved +function gui.move_above(node, reference) end + +---Alters the ordering of the two supplied nodes by moving the first node +---below the second. +---If the second argument is nil the first node is moved to the bottom. +---@param node node to move +---@param reference node|nil reference node below which the first node should be moved +function gui.move_below(node, reference) end + +---Dynamically create a new box node. +---@param pos vector3|vector4 node position +---@param size vector3 node size +---@return node node new box node +function gui.new_box_node(pos, size) end + +---Dynamically create a particle fx node. +---@param pos vector3|vector4 node position +---@param particlefx hash|string particle fx resource name +---@return node node new particle fx node +function gui.new_particlefx_node(pos, particlefx) end + +---Dynamically create a new pie node. +---@param pos vector3|vector4 node position +---@param size vector3 node size +---@return node node new pie node +function gui.new_pie_node(pos, size) end + +---Dynamically create a new text node. +---@param pos vector3|vector4 node position +---@param text string node text +---@return node node new text node +function gui.new_text_node(pos, text) end + +---Dynamically create a new texture. +---@param texture_id string|hash texture id +---@param width number texture width +---@param height number texture height +---@param type string|constant texture type +--- +---"rgb" - RGB +---"rgba" - RGBA +---"l" - LUMINANCE +--- +---@param buffer string texture data +---@param flip boolean flip texture vertically +---@return boolean success texture creation was successful +---@return number code one of the gui.RESULT_* codes if unsuccessful +function gui.new_texture(texture_id, width, height, type, buffer, flip) end + +---Tests whether a coordinate is within the bounding box of a +---node. +---@param node node node to be tested for picking +---@param x number x-coordinate (see on_input ) +---@param y number y-coordinate (see on_input ) +---@return boolean pickable pick result +function gui.pick_node(node, x, y) end + +---Play flipbook animation on a box or pie node. +---The current node texture must contain the animation. +---Use this function to set one-frame still images on the node. +---@param node node node to set animation for +---@param animation string|hash animation id +---@param complete_function fun(self, node)|nil optional function to call when the animation has completed +--- +---self +--- +---object The current object. +--- +---node +--- +---node The node that is animated. +--- +--- +---@param play_properties { offset:number|nil, playback_rate:number|nil }|nil optional table with properties +--- +---offset +---number The normalized initial value of the animation cursor when the animation starts playing +---playback_rate +---number The rate with which the animation will be played. Must be positive +--- +function gui.play_flipbook(node, animation, complete_function, play_properties) end + +---Plays the paricle fx for a gui node +---@param node node node to play particle fx for +---@param emitter_state_function fun(self, node, emitter, state)|nil optional callback function that will be called when an emitter attached to this particlefx changes state. +--- +---self +---object The current object +---node +---hash The particle fx node, or nil if the node was deleted +---emitter +---hash The id of the emitter +---state +---constant the new state of the emitter: +--- +--- +---particlefx.EMITTER_STATE_SLEEPING +---particlefx.EMITTER_STATE_PRESPAWN +---particlefx.EMITTER_STATE_SPAWNING +---particlefx.EMITTER_STATE_POSTSPAWN +--- +function gui.play_particlefx(node, emitter_state_function) end + +---Resets the input context of keyboard. This will clear marked text. +function gui.reset_keyboard() end + +---Resets the node material to the material assigned in the gui scene. +---@param node node node to reset the material for +function gui.reset_material(node) end + +---Resets all nodes in the current GUI scene to their initial state. +---The reset only applies to static node loaded from the scene. +---Nodes that are created dynamically from script are not affected. +function gui.reset_nodes() end + +---Convert the screen position to the local position of supplied node +---@param node node node used for getting local transformation matrix +---@param screen_position vector3 screen position +---@return vector3 local_position local position +function gui.screen_to_local(node, screen_position) end + +---Instead of using specific setteres such as gui.set_position or gui.set_scale, +---you can use gui.set instead and supply the property as a string or a hash. +---While this function is similar to go.get and go.set, there are a few more restrictions +---when operating in the gui namespace. Most notably, only these propertie identifiers are supported: +---"position" +---"rotation" +---"euler" +---"scale" +---"color" +---"outline" +---"shadow" +---"size" +---"fill_angle" (pie) +---"inner_radius" (pie) +---"slice9" (slice9) +---The value to set must either be a vmath.vector4, vmath.vector3, vmath.quat or a single number and depends on the property name you want to set. +---I.e when setting the "position" property, you need to use a vmath.vector4 and when setting a single component of the property, +---such as "position.x", you need to use a single value. +---Note: When setting the rotation using the "rotation" property, you need to pass in a vmath.quat. This behaviour is different than from the gui.set_rotation function, +---the intention is to move new functionality closer to go namespace so that migrating between gui and go is easier. To set the rotation using degrees instead, +---use the "euler" property instead. The rotation and euler properties are linked, changing one of them will change the backing data of the other. +---@param node node node to set the property for +---@param property string|hash|constant the property to set +---@param value number|vector4|vector3|quaternion the property to set +function gui.set(node, property, value) end + +---Sets the adjust mode on a node. +---The adjust mode defines how the node will adjust itself to screen +---resolutions that differs from the one in the project settings. +---@param node node node to set adjust mode for +---@param adjust_mode constant adjust mode to set +--- +---gui.ADJUST_FIT +---gui.ADJUST_ZOOM +---gui.ADJUST_STRETCH +--- +function gui.set_adjust_mode(node, adjust_mode) end + +---sets the node alpha +---@param node node node for which to set alpha +---@param alpha number 0..1 alpha color +function gui.set_alpha(node, alpha) end + +---Set the blend mode of a node. +---Blend mode defines how the node will be blended with the background. +---@param node node node to set blend mode for +---@param blend_mode constant blend mode to set +--- +---gui.BLEND_ALPHA +---gui.BLEND_ADD +---gui.BLEND_ADD_ALPHA +---gui.BLEND_MULT +---gui.BLEND_SCREEN +--- +function gui.set_blend_mode(node, blend_mode) end + +---If node is set as an inverted clipping node, it will clip anything inside as opposed to outside. +---@param node node node to set clipping inverted state for +---@param inverted boolean true or false +function gui.set_clipping_inverted(node, inverted) end + +---Clipping mode defines how the node will clip it's children nodes +---@param node node node to set clipping mode for +---@param clipping_mode constant clipping mode to set +--- +--- gui.CLIPPING_MODE_NONE +--- gui.CLIPPING_MODE_STENCIL +--- +function gui.set_clipping_mode(node, clipping_mode) end + +---If node is set as an visible clipping node, it will be shown as well as clipping. Otherwise, it will only clip but not show visually. +---@param node node node to set clipping visibility for +---@param visible boolean true or false +function gui.set_clipping_visible(node, visible) end + +---Sets the color of the supplied node. The components +---of the supplied vector3 or vector4 should contain the color channel values: +---Component +---Color value +---x +---Red value +---y +---Green value +---z +---Blue value +---w vector4 +---Alpha value +---@param node node node to set the color for +---@param color vector3|vector4 new color +function gui.set_color(node, color) end + +---Sets a node to the disabled or enabled state. +---Disabled nodes are not rendered and animations acting on them are not evaluated. +---@param node node node to be enabled/disabled +---@param enabled boolean whether the node should be enabled or not +function gui.set_enabled(node, enabled) end + +---Sets the rotation of the supplied node. +---The rotation is expressed in degree Euler angles. +---@param node node node to set the rotation for +---@param rotation vector3|vector4 new rotation +function gui.set_euler(node, rotation) end + +---Set the sector angle of a pie node. +---@param node node node to set the fill angle for +---@param angle number sector angle +function gui.set_fill_angle(node, angle) end + +---This is only useful nodes with flipbook animations. The cursor is normalized. +---@param node node node to set the cursor for +---@param cursor number cursor value +function gui.set_flipbook_cursor(node, cursor) end + +---This is only useful nodes with flipbook animations. Sets the playback rate of the flipbook animation on a node. Must be positive. +---@param node node node to set the cursor for +---@param playback_rate number playback rate +function gui.set_flipbook_playback_rate(node, playback_rate) end + +---This is only useful for text nodes. +---The font must be mapped to the gui scene in the gui editor. +---@param node node node for which to set the font +---@param font string|hash font id +function gui.set_font(node, font) end + +---Set the id of the specicied node to a new value. +---Nodes created with the gui.new_*_node() functions get +---an empty id. This function allows you to give dynamically +---created nodes an id. +--- No checking is done on the uniqueness of supplied ids. +---It is up to you to make sure you use unique ids. +---@param node node node to set the id for +---@param id string|hash id to set +function gui.set_id(node, id) end + +---sets the node inherit alpha state +---@param node node node from which to set the inherit alpha state +---@param inherit_alpha boolean true or false +function gui.set_inherit_alpha(node, inherit_alpha) end + +---Sets the inner radius of a pie node. +---The radius is defined along the x-axis. +---@param node node node to set the inner radius for +---@param radius number inner radius +function gui.set_inner_radius(node, radius) end + +---The layer must be mapped to the gui scene in the gui editor. +---@param node node node for which to set the layer +---@param layer string|hash layer id +function gui.set_layer(node, layer) end + +---Sets the leading value for a text node. This value is used to +---scale the line spacing of text. +---@param node node node for which to set the leading +---@param leading number a scaling value for the line spacing (default=1) +function gui.set_leading(node, leading) end + +---Sets the line-break mode on a text node. +---This is only useful for text nodes. +---@param node node node to set line-break for +---@param line_break boolean true or false +function gui.set_line_break(node, line_break) end + +---Set the material on a node. The material must be mapped to the gui scene in the gui editor, +---and assigning a material is supported for all node types. To set the default material that +---is assigned to the gui scene node, use gui.reset_material(node_id) instead. +---@param node node node to set material for +---@param material string|hash material id +function gui.set_material(node, material) end + +---Sets the outer bounds mode for a pie node. +---@param node node node for which to set the outer bounds mode +---@param bounds_mode constant the outer bounds mode of the pie node: +--- +---gui.PIEBOUNDS_RECTANGLE +---gui.PIEBOUNDS_ELLIPSE +--- +function gui.set_outer_bounds(node, bounds_mode) end + +---Sets the outline color of the supplied node. +---See gui.set_color for info how vectors encode color values. +---@param node node node to set the outline color for +---@param color vector3|vector4 new outline color +function gui.set_outline(node, color) end + +---Sets the parent node of the specified node. +---@param node node node for which to set its parent +---@param parent node|nil parent node to set, pass nil to remove parent +---@param keep_scene_transform boolean|nil optional flag to make the scene position being perserved +function gui.set_parent(node, parent, keep_scene_transform) end + +---Set the paricle fx for a gui node +---@param node node node to set particle fx for +---@param particlefx hash|string particle fx id +function gui.set_particlefx(node, particlefx) end + +---Sets the number of generated vertices around the perimeter of a pie node. +---@param node node pie node +---@param vertices number vertex count +function gui.set_perimeter_vertices(node, vertices) end + +---The pivot specifies how the node is drawn and rotated from its position. +---@param node node node to set pivot for +---@param pivot constant pivot constant +--- +--- gui.PIVOT_CENTER +--- gui.PIVOT_N +--- gui.PIVOT_NE +--- gui.PIVOT_E +--- gui.PIVOT_SE +--- gui.PIVOT_S +--- gui.PIVOT_SW +--- gui.PIVOT_W +--- gui.PIVOT_NW +--- +function gui.set_pivot(node, pivot) end + +---Sets the position of the supplied node. +---@param node node node to set the position for +---@param position vector3|vector4 new position +function gui.set_position(node, position) end + +---Set the order number for the current GUI scene. +---The number dictates the sorting of the "gui" render predicate, +---in other words in which order the scene will be rendered in relation +---to other currently rendered GUI scenes. +---The number must be in the range 0 to 15. +---@param order number rendering order (0-15) +function gui.set_render_order(order) end + +---Sets the rotation of the supplied node. +---The rotation is expressed as a quaternion +---@param node node node to set the rotation for +---@param rotation quaternion|vector4 new rotation +function gui.set_rotation(node, rotation) end + +---Sets the scaling of the supplied node. +---@param node node node to set the scale for +---@param scale vector3|vector4 new scale +function gui.set_scale(node, scale) end + +---Set the screen position to the supplied node +---@param node node node to set the screen position to +---@param screen_position vector3 screen position +function gui.set_screen_position(node, screen_position) end + +---Sets the shadow color of the supplied node. +---See gui.set_color for info how vectors encode color values. +---@param node node node to set the shadow color for +---@param color vector3|vector4 new shadow color +function gui.set_shadow(node, color) end + +---Sets the size of the supplied node. +--- You can only set size on nodes with size mode set to SIZE_MODE_MANUAL +---@param node node node to set the size for +---@param size vector3|vector4 new size +function gui.set_size(node, size) end + +---Sets the size mode of a node. +---The size mode defines how the node will adjust itself in size. Automatic +---size mode alters the node size based on the node's content. Automatic size +---mode works for Box nodes and Pie nodes which will both adjust their size +---to match the assigned image. Particle fx and Text nodes will ignore +---any size mode setting. +---@param node node node to set size mode for +---@param size_mode constant size mode to set +--- +---gui.SIZE_MODE_MANUAL +---gui.SIZE_MODE_AUTO +--- +function gui.set_size_mode(node, size_mode) end + +---Set the slice9 configuration values for the node. +---@param node node node to manipulate +---@param values vector4 new values +function gui.set_slice9(node, values) end + +---Set the text value of a text node. This is only useful for text nodes. +---@param node node node to set text for +---@param text string|number text to set +function gui.set_text(node, text) end + +---Set the texture on a box or pie node. The texture must be mapped to +---the gui scene in the gui editor. The function points out which texture +---the node should render from. If the texture is an atlas, further +---information is needed to select which image/animation in the atlas +---to render. In such cases, use gui.play_flipbook() in +---addition to this function. +---@param node node node to set texture for +---@param texture string|hash texture id +function gui.set_texture(node, texture) end + +---Set the texture buffer data for a dynamically created texture. +---@param texture string|hash texture id +---@param width number texture width +---@param height number texture height +---@param type string|constant texture type +--- +--- "rgb" - RGB +--- "rgba" - RGBA +--- "l" - LUMINANCE +--- +---@param buffer string texture data +---@param flip boolean flip texture vertically +---@return boolean success setting the data was successful +function gui.set_texture_data(texture, width, height, type, buffer, flip) end + +---Sets the tracking value of a text node. This value is used to +---adjust the vertical spacing of characters in the text. +---@param node node node for which to set the tracking +---@param tracking number a scaling number for the letter spacing (default=0) +function gui.set_tracking(node, tracking) end + +---Set if a node should be visible or not. Only visible nodes are rendered. +---@param node node node to be visible or not +---@param visible boolean whether the node should be visible or not +function gui.set_visible(node, visible) end + +---The x-anchor specifies how the node is moved when the game is run in a different resolution. +---@param node node node to set x-anchor for +---@param anchor constant anchor constant +--- +---gui.ANCHOR_NONE +---gui.ANCHOR_LEFT +---gui.ANCHOR_RIGHT +--- +function gui.set_xanchor(node, anchor) end + +---The y-anchor specifies how the node is moved when the game is run in a different resolution. +---@param node node node to set y-anchor for +---@param anchor constant anchor constant +--- +---gui.ANCHOR_NONE +---gui.ANCHOR_TOP +---gui.ANCHOR_BOTTOM +--- +function gui.set_yanchor(node, anchor) end + +---Shows the on-display touch keyboard. +---The specified type of keyboard is displayed if it is available on +---the device. +---This function is only available on iOS and Android. . +---@param type constant keyboard type +--- +---gui.KEYBOARD_TYPE_DEFAULT +---gui.KEYBOARD_TYPE_EMAIL +---gui.KEYBOARD_TYPE_NUMBER_PAD +---gui.KEYBOARD_TYPE_PASSWORD +--- +---@param autoclose boolean if the keyboard should automatically close when clicking outside +function gui.show_keyboard(type, autoclose) end + +---Stops the particle fx for a gui node +---@param node node node to stop particle fx for +---@param options { clear:boolean|nil }|nil options when stopping the particle fx. Supported options: +--- +---boolean clear: instantly clear spawned particles +--- +function gui.stop_particlefx(node, options) end + + + +return gui \ No newline at end of file diff --git a/annotations/defold_annotations/html5.lua b/annotations/defold_annotations/html5.lua new file mode 100644 index 0000000..6b2c506 --- /dev/null +++ b/annotations/defold_annotations/html5.lua @@ -0,0 +1,37 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + HTML5 API documentation + + HTML5 platform specific functions. + The following functions are only available on HTML5 builds, the html5.* Lua namespace will not be available on other platforms. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.html5 +html5 = {} + +---Executes the supplied string as JavaScript inside the browser. +---A call to this function is blocking, the result is returned as-is, as a string. +---(Internally this will execute the string using the eval() JavaScript function.) +---@param code string Javascript code to run +---@return string result result as string +function html5.run(code) end + +---Set a JavaScript interaction listener callaback from lua that will be +---invoked when a user interacts with the web page by clicking, touching or typing. +---The callback can then call DOM restricted actions like requesting a pointer lock, +---or start playing sounds the first time the callback is invoked. +---@param callback fun(self)|nil The interaction callback. Pass an empty function or nil if you no longer wish to receive callbacks. +--- +---self +---object The calling script +--- +function html5.set_interaction_listener(callback) end + +return html5 \ No newline at end of file diff --git a/annotations/defold_annotations/http.lua b/annotations/defold_annotations/http.lua new file mode 100644 index 0000000..a44c8b4 --- /dev/null +++ b/annotations/defold_annotations/http.lua @@ -0,0 +1,49 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + HTTP API documentation + + Functions for performing HTTP and HTTPS requests. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.http +http = {} + +---Perform a HTTP/HTTPS request. +--- If no timeout value is passed, the configuration value "network.http_timeout" is used. If that is not set, the timeout value is 0 (which blocks indefinitely). +---@param url string target url +---@param method string HTTP/HTTPS method, e.g. "GET", "PUT", "POST" etc. +---@param callback fun(self, id, response) response callback function +--- +---self +---object The script instance +---id +---hash Internal message identifier. Do not use! +---response +---table The response data. Contains the fields: +--- +--- +---number status: the status of the response +---string response: the response data (if not saved on disc) +---table headers: all the returned headers +---string path: the stored path (if saved to disc) +---string error: if any unforeseen errors occurred (e.g. file I/O) +--- +---@param headers table|nil optional table with custom headers +---@param post_data string|nil optional data to send +---@param options table|nil optional table with request parameters. Supported entries: +--- +---number timeout: timeout in seconds +---string path: path on disc where to download the file. Only overwrites the path if status is 200. Path should be absolute +---boolean ignore_cache: don't return cached data if we get a 304. Not available in HTML5 build +---boolean chunked_transfer: use chunked transfer encoding for https requests larger than 16kb. Defaults to true. Not available in HTML5 build +--- +function http.request(url, method, callback, headers, post_data, options) end + +return http \ No newline at end of file diff --git a/annotations/defold_annotations/image.lua b/annotations/defold_annotations/image.lua new file mode 100644 index 0000000..caa4738 --- /dev/null +++ b/annotations/defold_annotations/image.lua @@ -0,0 +1,78 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Image API documentation + + Functions for creating image objects. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.image +image = {} + +---luminance image type +image.TYPE_LUMINANCE = nil + +---luminance image type +image.TYPE_LUMINANCE_ALPHA = nil + +---RGB image type +image.TYPE_RGB = nil + +---RGBA image type +image.TYPE_RGBA = nil + +---Load image (PNG or JPEG) from buffer. +---@param buffer string image data buffer +---@param options table|nil An optional table containing parameters for loading the image. Supported entries: +--- +---premultiply_alpha +---boolean True if alpha should be premultiplied into the color components. Defaults to false. +---flip_vertically +---boolean True if the image contents should be flipped vertically. Defaults to false. +--- +---@return { width:number, height:number, type:constant, buffer:string }|nil image object or nil if loading fails. The object is a table with the following fields: +--- +---number width: image width +---number height: image height +---constant type: image type +---image.TYPE_RGB +---image.TYPE_RGBA +---image.TYPE_LUMINANCE +---image.TYPE_LUMINANCE_ALPHA +--- +--- +---string buffer: the raw image data +--- +function image.load(buffer, options) end + +---Load image (PNG or JPEG) from a string buffer. +---@param buffer string image data buffer +---@param options table|nil An optional table containing parameters for loading the image. Supported entries: +--- +---premultiply_alpha +---boolean True if alpha should be premultiplied into the color components. Defaults to false. +---flip_vertically +---boolean True if the image contents should be flipped vertically. Defaults to false. +--- +---@return { width:number, height:number, type:constant, buffer:buffer_data }|nil image object or nil if loading fails. The object is a table with the following fields: +--- +---number width: image width +---number height: image height +---constant type: image type +---image.TYPE_RGB +---image.TYPE_RGBA +---image.TYPE_LUMINANCE +---image.TYPE_LUMINANCE_ALPHA +--- +--- +---buffer buffer: the script buffer that holds the decompressed image data. See buffer.create how to use the buffer. +--- +function image.load_buffer(buffer, options) end + +return image \ No newline at end of file diff --git a/annotations/defold_annotations/json.lua b/annotations/defold_annotations/json.lua new file mode 100644 index 0000000..f45e862 --- /dev/null +++ b/annotations/defold_annotations/json.lua @@ -0,0 +1,41 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + JSON API documentation + + Manipulation of JSON data strings. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.json +json = {} + +---Represents the null primitive from a json file +json.null = nil + +---Decode a string of JSON data into a Lua table. +---A Lua error is raised for syntax errors. +---@param json string json data +---@param options { decode_null_as_userdata:boolean|nil }|nil table with decode options +--- +---bool decode_null_as_userdata: wether to decode a JSON null value as json.null or nil (default is nil) +--- +---@return table data decoded json +function json.decode(json, options) end + +---Encode a lua table to a JSON string. +---A Lua error is raised for syntax errors. +---@param tbl table lua table to encode +---@param options { encode_empty_table_as_object:string }|nil table with encode options +--- +---string encode_empty_table_as_object: wether to encode an empty table as an JSON object or array (default is object) +--- +---@return string json encoded json +function json.encode(tbl, options) end + +return json \ No newline at end of file diff --git a/annotations/defold_annotations/label.lua b/annotations/defold_annotations/label.lua new file mode 100644 index 0000000..f41b7f7 --- /dev/null +++ b/annotations/defold_annotations/label.lua @@ -0,0 +1,28 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Label API documentation +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.label +label = {} + +---Gets the text from a label component +---@param url string|hash|url the label to get the text from +---@return string metrics the label text +function label.get_text(url) end + +---Sets the text of a label component +--- This method uses the message passing that means the value will be set after dispatch messages step. +---More information is available in the Application Lifecycle manual. +---@param url string|hash|url the label that should have a constant set +---@param text string the text +function label.set_text(url, text) end + +return label \ No newline at end of file diff --git a/annotations/defold_annotations/liveupdate.lua b/annotations/defold_annotations/liveupdate.lua new file mode 100644 index 0000000..94e717a --- /dev/null +++ b/annotations/defold_annotations/liveupdate.lua @@ -0,0 +1,155 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + LiveUpdate API documentation + + Functions and constants to access resources. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.liveupdate +liveupdate = {} + +---Mismatch between between expected bundled resources and actual bundled resources. The manifest expects a resource to be in the bundle, but it was not found in the bundle. This is typically the case when a non-excluded resource was modified between publishing the bundle and publishing the manifest. +liveupdate.LIVEUPDATE_BUNDLED_RESOURCE_MISMATCH = nil + +---Mismatch between running engine version and engine versions supported by manifest. +liveupdate.LIVEUPDATE_ENGINE_VERSION_MISMATCH = nil + +---Failed to parse manifest data buffer. The manifest was probably produced by a different engine version. +liveupdate.LIVEUPDATE_FORMAT_ERROR = nil + +---Argument was invalid +liveupdate.LIVEUPDATE_INVAL = nil + +---The handled resource is invalid. +liveupdate.LIVEUPDATE_INVALID_HEADER = nil + +---The header of the resource is invalid. +liveupdate.LIVEUPDATE_INVALID_RESOURCE = nil + +---I/O operation failed +liveupdate.LIVEUPDATE_IO_ERROR = nil + +---Memory wasn't allocated +liveupdate.LIVEUPDATE_MEM_ERROR = nil + +---LIVEUPDATE_OK +liveupdate.LIVEUPDATE_OK = nil + +---Mismatch between scheme used to load resources. Resources are loaded with a different scheme than from manifest, for example over HTTP or directly from file. This is typically the case when running the game directly from the editor instead of from a bundle. +liveupdate.LIVEUPDATE_SCHEME_MISMATCH = nil + +---Mismatch between manifest expected signature and actual signature. +liveupdate.LIVEUPDATE_SIGNATURE_MISMATCH = nil + +---Unspecified error +liveupdate.LIVEUPDATE_UNKNOWN = nil + +---Mismatch between manifest expected version and actual version. +liveupdate.LIVEUPDATE_VERSION_MISMATCH = nil + +---Adds a resource mount to the resource system. +---The mounts are persisted between sessions. +---After the mount succeeded, the resources are available to load. (i.e. no reboot required) +---@param name string Unique name of the mount +---@param uri string The uri of the mount, including the scheme. Currently supported schemes are 'zip' and 'archive'. +---@param priority integer Priority of mount. Larger priority takes prescedence +---@param callback function Callback after the asynchronous request completed +---@return number result The result of the request +function liveupdate.add_mount(name, uri, priority, callback) end + +---Return a reference to the Manifest that is currently loaded. +---@return number manifest_reference reference to the Manifest that is currently loaded +function liveupdate.get_current_manifest() end + +---Get an array of the current mounts +---This can be used to determine if a new mount is needed or not +---@return array mounts Array of mounts +function liveupdate.get_mounts() end + +---Is any liveupdate data mounted and currently in use? +---This can be used to determine if a new manifest or zip file should be downloaded. +---@return bool bool true if a liveupdate archive (any format) has been loaded +function liveupdate.is_using_liveupdate_data() end + +---Remove a mount the resource system. +---The remaining mounts are persisted between sessions. +---Removing a mount does not affect any loaded resources. +---@param name string Unique name of the mount +---@return number result The result of the call +function liveupdate.remove_mount(name) end + +---Stores a zip file and uses it for live update content. The contents of the +---zip file will be verified against the manifest to ensure file integrity. +---It is possible to opt out of the resource verification using an option passed +---to this function. +---The path is stored in the (internal) live update location. +---@param path string the path to the original file on disc +---@param callback fun(self, status) the callback function +---executed after the storage has completed +--- +---self +---object The current object. +---status +---constant the status of the store operation (See liveupdate.store_manifest) +--- +---@param options table|nil optional table with extra parameters. Supported entries: +--- +---boolean verify: if archive should be verified as well as stored (defaults to true) +--- +function liveupdate.store_archive(path, callback, options) end + +---Create a new manifest from a buffer. The created manifest is verified +---by ensuring that the manifest was signed using the bundled public/private +---key-pair during the bundle process and that the manifest supports the current +---running engine version. Once the manifest is verified it is stored on device. +---The next time the engine starts (or is rebooted) it will look for the stored +---manifest before loading resources. Storing a new manifest allows the +---developer to update the game, modify existing resources, or add new +---resources to the game through LiveUpdate. +---@param manifest_buffer string the binary data that represents the manifest +---@param callback fun(self, status) the callback function +---executed once the engine has attempted to store the manifest. +--- +---self +---object The current object. +---status +---constant the status of the store operation: +--- +--- +---liveupdate.LIVEUPDATE_OK +---liveupdate.LIVEUPDATE_INVALID_RESOURCE +---liveupdate.LIVEUPDATE_VERSION_MISMATCH +---liveupdate.LIVEUPDATE_ENGINE_VERSION_MISMATCH +---liveupdate.LIVEUPDATE_SIGNATURE_MISMATCH +---liveupdate.LIVEUPDATE_BUNDLED_RESOURCE_MISMATCH +---liveupdate.LIVEUPDATE_FORMAT_ERROR +--- +function liveupdate.store_manifest(manifest_buffer, callback) end + +---add a resource to the data archive and runtime index. The resource will be verified +---internally before being added to the data archive. +---@param manifest_reference number The manifest to check against. +---@param data string The resource data that should be stored. +---@param hexdigest string The expected hash for the resource, +---retrieved through collectionproxy.missing_resources. +---@param callback fun(self, hexdigest, status) The callback +---function that is executed once the engine has been attempted to store +---the resource. +--- +---self +---object The current object. +---hexdigest +---string The hexdigest of the resource. +---status +---boolean Whether or not the resource was successfully stored. +--- +function liveupdate.store_resource(manifest_reference, data, hexdigest, callback) end + +return liveupdate \ No newline at end of file diff --git a/annotations/defold_annotations/model.lua b/annotations/defold_annotations/model.lua new file mode 100644 index 0000000..66b8580 --- /dev/null +++ b/annotations/defold_annotations/model.lua @@ -0,0 +1,92 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Model API documentation +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.model +model = {} + +---Cancels all animation on a model component. +---@param url string|hash|url the model for which to cancel the animation +function model.cancel(url) end + +---Gets the id of the game object that corresponds to a model skeleton bone. +---The returned game object can be used for parenting and transform queries. +---This function has complexity O(n), where n is the number of bones in the model skeleton. +---Game objects corresponding to a model skeleton bone can not be individually deleted. +---@param url string|hash|url the model to query +---@param bone_id string|hash id of the corresponding bone +---@return hash id id of the game object +function model.get_go(url, bone_id) end + +---Get the enabled state of a mesh +---@param url string|hash|url the model +---@param mesh_id string|hash|url the id of the mesh +---@return boolean enabled true if the mesh is visible, false otherwise +function model.get_mesh_enabled(url, mesh_id) end + +---Plays an animation on a model component with specified playback +---mode and parameters. +---An optional completion callback function can be provided that will be called when +---the animation has completed playing. If no function is provided, +---a model_animation_done message is sent to the script that started the animation. +--- The callback is not called (or message sent) if the animation is +---cancelled with model.cancel. The callback is called (or message sent) only for +---animations that play with the following playback modes: +---go.PLAYBACK_ONCE_FORWARD +---go.PLAYBACK_ONCE_BACKWARD +---go.PLAYBACK_ONCE_PINGPONG +---@param url string|hash|url the model for which to play the animation +---@param anim_id string|hash id of the animation to play +---@param playback constant playback mode of the animation +--- +---go.PLAYBACK_ONCE_FORWARD +---go.PLAYBACK_ONCE_BACKWARD +---go.PLAYBACK_ONCE_PINGPONG +---go.PLAYBACK_LOOP_FORWARD +---go.PLAYBACK_LOOP_BACKWARD +---go.PLAYBACK_LOOP_PINGPONG +--- +---@param play_properties { blend_duration:number|nil, offset:number|nil, playback_rate:number|nil}|nil optional table with properties +---Play properties table: +--- +---blend_duration +---number Duration of a linear blend between the current and new animation. +---offset +---number The normalized initial value of the animation cursor when the animation starts playing. +---playback_rate +---number The rate with which the animation will be played. Must be positive. +--- +---@param complete_function fun(self, message_id, message, sender)|nil function to call when the animation has completed. +--- +---self +---object The current object. +---message_id +---hash The name of the completion message, "model_animation_done". +---message +---table Information about the completion: +--- +--- +---hash animation_id - the animation that was completed. +---constant playback - the playback mode for the animation. +--- +--- +---sender +---url The invoker of the callback: the model component. +--- +function model.play_anim(url, anim_id, playback, play_properties, complete_function) end + +---Enable or disable visibility of a mesh +---@param url string|hash|url the model +---@param mesh_id string|hash|url the id of the mesh +---@param enabled boolean true if the mesh should be visible, false if it should be hideen +function model.set_mesh_enabled(url, mesh_id, enabled) end + +return model \ No newline at end of file diff --git a/annotations/defold_annotations/msg.lua b/annotations/defold_annotations/msg.lua new file mode 100644 index 0000000..a1b9fb8 --- /dev/null +++ b/annotations/defold_annotations/msg.lua @@ -0,0 +1,54 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Messaging API documentation + + Functions for passing messages and constructing URL objects. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.msg +msg = {} + +---Post a message to a receiving URL. The most common case is to send messages +---to a component. If the component part of the receiver is omitted, the message +---is broadcast to all components in the game object. +---The following receiver shorthands are available: +---"." the current game object +---"#" the current component +--- There is a 2 kilobyte limit to the message parameter table size. +---@param receiver string|url|hash The receiver must be a string in URL-format, a URL object or a hashed string. +---@param message_id string|hash The id must be a string or a hashed string. +---@param message table|nil a lua table with message parameters to send. +function msg.post(receiver, message_id, message) end + +---creates a new URL from separate arguments +---@param socket string|hash|nil socket of the URL +---@param path string|hash|nil path of the URL +---@param fragment string|hash|nil fragment of the URL +---@return url url a new URL +function msg.url(socket, path, fragment) end + +---The format of the string must be [socket:][path][#fragment], which is similar to a HTTP URL. +---When addressing instances: +---socket is the name of a valid world (a collection) +---path is the id of the instance, which can either be relative the instance of the calling script or global +---fragment would be the id of the desired component +---In addition, the following shorthands are available: +---"." the current game object +---"#" the current component +---@param urlstring string string to create the url from +---@return url url a new URL +function msg.url(urlstring) end + +---This is equivalent to msg.url(nil) or msg.url("#"), which creates an url to the current +---script component. +---@return url url a new URL +function msg.url() end + +return msg \ No newline at end of file diff --git a/annotations/defold_annotations/particlefx.lua b/annotations/defold_annotations/particlefx.lua new file mode 100644 index 0000000..752ca90 --- /dev/null +++ b/annotations/defold_annotations/particlefx.lua @@ -0,0 +1,85 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Particle effects API documentation + + Functions for controlling particle effect component playback and + shader constants. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.particlefx +particlefx = {} + +---The emitter is not spawning any particles, but has particles that are still alive. +particlefx.EMITTER_STATE_POSTSPAWN = nil + +---The emitter will be in this state when it has been started but before spawning any particles. Normally the emitter is in this state for a short time, depending on if a start delay has been set for this emitter or not. +particlefx.EMITTER_STATE_PRESPAWN = nil + +---The emitter does not have any living particles and will not spawn any particles in this state. +particlefx.EMITTER_STATE_SLEEPING = nil + +---The emitter is spawning particles. +particlefx.EMITTER_STATE_SPAWNING = nil + +---Starts playing a particle FX component. +---Particle FX started this way need to be manually stopped through particlefx.stop(). +---Which particle FX to play is identified by the URL. +--- A particle FX will continue to emit particles even if the game object the particle FX component belonged to is deleted. You can call particlefx.stop() to stop it from emitting more particles. +---@param url string|hash|url the particle fx that should start playing. +---@param emitter_state_function fun(self, id, emitter, state)|nil optional callback function that will be called when an emitter attached to this particlefx changes state. +--- +---self +---object The current object +---id +---hash The id of the particle fx component +---emitter +---hash The id of the emitter +---state +---constant the new state of the emitter: +--- +--- +---particlefx.EMITTER_STATE_SLEEPING +---particlefx.EMITTER_STATE_PRESPAWN +---particlefx.EMITTER_STATE_SPAWNING +---particlefx.EMITTER_STATE_POSTSPAWN +--- +function particlefx.play(url, emitter_state_function) end + +---Resets a shader constant for a particle FX component emitter. +---The constant must be defined in the material assigned to the emitter. +---Resetting a constant through this function implies that the value defined in the material will be used. +---Which particle FX to reset a constant for is identified by the URL. +---@param url string|hash|url the particle FX that should have a constant reset +---@param emitter string|hash the id of the emitter +---@param constant string|hash the name of the constant +function particlefx.reset_constant(url, emitter, constant) end + +---Sets a shader constant for a particle FX component emitter. +---The constant must be defined in the material assigned to the emitter. +---Setting a constant through this function will override the value set for that constant in the material. +---The value will be overridden until particlefx.reset_constant is called. +---Which particle FX to set a constant for is identified by the URL. +---@param url string|hash|url the particle FX that should have a constant set +---@param emitter string|hash the id of the emitter +---@param constant string|hash the name of the constant +---@param value vector4 the value of the constant +function particlefx.set_constant(url, emitter, constant, value) end + +---Stops a particle FX component from playing. +---Stopping a particle FX does not remove already spawned particles. +---Which particle FX to stop is identified by the URL. +---@param url string|hash|url the particle fx that should stop playing +---@param options { clear:boolean|nil }|nil Options when stopping the particle fx. Supported options: +--- +---boolean clear: instantly clear spawned particles +--- +function particlefx.stop(url, options) end + +return particlefx \ No newline at end of file diff --git a/annotations/defold_annotations/physics.lua b/annotations/defold_annotations/physics.lua new file mode 100644 index 0000000..3fec59f --- /dev/null +++ b/annotations/defold_annotations/physics.lua @@ -0,0 +1,307 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Collision object physics API documentation +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.physics +physics = {} + +---The following properties are available when connecting a joint of JOINT_TYPE_FIXED type: +physics.JOINT_TYPE_FIXED = nil + +---The following properties are available when connecting a joint of JOINT_TYPE_HINGE type: +physics.JOINT_TYPE_HINGE = nil + +---The following properties are available when connecting a joint of JOINT_TYPE_SLIDER type: +physics.JOINT_TYPE_SLIDER = nil + +---The following properties are available when connecting a joint of JOINT_TYPE_SPRING type: +physics.JOINT_TYPE_SPRING = nil + +---The following properties are available when connecting a joint of JOINT_TYPE_WELD type: +physics.JOINT_TYPE_WELD = nil + +---The following properties are available when connecting a joint of JOINT_TYPE_WHEEL type: +physics.JOINT_TYPE_WHEEL = nil + +--- +physics.SHAPE_TYPE_BOX = nil + +--- +physics.SHAPE_TYPE_CAPSULE = nil + +--- +physics.SHAPE_TYPE_HULL = nil + +--- +physics.SHAPE_TYPE_SPHERE = nil + +---Create a physics joint between two collision object components. +---Note: Currently only supported in 2D physics. +---@param joint_type number the joint type +---@param collisionobject_a string|hash|url first collision object +---@param joint_id string|hash id of the joint +---@param position_a vector3 local position where to attach the joint on the first collision object +---@param collisionobject_b string|hash|url second collision object +---@param position_b vector3 local position where to attach the joint on the second collision object +---@param properties table|nil optional joint specific properties table +---See each joint type for possible properties field. The one field that is accepted for all joint types is: +---- boolean collide_connected: Set this flag to true if the attached bodies should collide. +function physics.create_joint(joint_type, collisionobject_a, joint_id, position_a, collisionobject_b, position_b, properties) end + +---Destroy an already physics joint. The joint has to be created before a +---destroy can be issued. +---Note: Currently only supported in 2D physics. +---@param collisionobject string|hash|url collision object where the joint exist +---@param joint_id string|hash id of the joint +function physics.destroy_joint(collisionobject, joint_id) end + +---Get the gravity in runtime. The gravity returned is not global, it will return +---the gravity for the collection that the function is called from. +---Note: For 2D physics the z component will always be zero. +---@return vector3 gravity gravity vector of collection +function physics.get_gravity() end + +---Returns the group name of a collision object as a hash. +---@param url string|hash|url the collision object to return the group of. +---@return hash group hash value of the group. +---local function check_is_enemy() +--- local group = physics.get_group("#collisionobject") +--- return group == hash("enemy") +---end +--- +function physics.get_group(url) end + +---Get a table for properties for a connected joint. The joint has to be created before +---properties can be retrieved. +---Note: Currently only supported in 2D physics. +---@param collisionobject string|hash|url collision object where the joint exist +---@param joint_id string|hash id of the joint +---@return { collide_connected:boolean|nil } properties properties table. See the joint types for what fields are available, the only field available for all types is: +--- +---boolean collide_connected: Set this flag to true if the attached bodies should collide. +--- +function physics.get_joint_properties(collisionobject, joint_id) end + +---Get the reaction force for a joint. The joint has to be created before +---the reaction force can be calculated. +---Note: Currently only supported in 2D physics. +---@param collisionobject string|hash|url collision object where the joint exist +---@param joint_id string|hash id of the joint +---@return vector3 force reaction force for the joint +function physics.get_joint_reaction_force(collisionobject, joint_id) end + +---Get the reaction torque for a joint. The joint has to be created before +---the reaction torque can be calculated. +---Note: Currently only supported in 2D physics. +---@param collisionobject string|hash|url collision object where the joint exist +---@param joint_id string|hash id of the joint +---@return float torque the reaction torque on bodyB in N*m. +function physics.get_joint_reaction_torque(collisionobject, joint_id) end + +---Returns true if the specified group is set in the mask of a collision +---object, false otherwise. +---@param url string|hash|url the collision object to check the mask of. +---@param group string the name of the group to check for. +---@return boolean maskbit boolean value of the maskbit. 'true' if present, 'false' otherwise. +---local function is_invincible() +--- -- check if the collisionobject would collide with the "bullet" group +--- local invincible = physics.get_maskbit("#collisionobject", "bullet") +--- return invincible +---end +--- +function physics.get_maskbit(url, group) end + +---Gets collision shape data from a collision object +---@param url string|hash|url the collision object. +---@param shape string|hash the name of the shape to get data for. +---@return { type:number|nil, diameter:number|nil, dimensions:vector3|nil, height:number|nil } table A table containing meta data about the physics shape +--- +---type +---number The shape type. Supported values: +--- +--- +---physics.SHAPE_TYPE_SPHERE +---physics.SHAPE_TYPE_BOX +---physics.SHAPE_TYPE_CAPSULE Only supported for 3D physics +---physics.SHAPE_TYPE_HULL +--- +---The returned table contains different fields depending on which type the shape is. +---If the shape is a sphere: +--- +---diameter +---number the diameter of the sphere shape +--- +---If the shape is a box: +--- +---dimensions +---vector3 a vmath.vector3 of the box dimensions +--- +---If the shape is a capsule: +--- +---diameter +---number the diameter of the capsule poles +---height +---number the height of the capsule +--- +---local function get_shape_meta() +--- local sphere = physics.get_shape("#collisionobject", "my_sphere_shape") +--- -- returns a table with sphere.diameter +--- return sphere +---end +--- +function physics.get_shape(url, shape) end + +---Ray casts are used to test for intersections against collision objects in the physics world. +---Collision objects of types kinematic, dynamic and static are tested against. Trigger objects +---do not intersect with ray casts. +---Which collision objects to hit is filtered by their collision groups and can be configured +---through groups. +---@param from vector3 the world position of the start of the ray +---@param to vector3 the world position of the end of the ray +---@param groups table a lua table containing the hashed groups for which to test collisions against +---@param options { all:boolean|nil }|nil a lua table containing options for the raycast. +--- +---all +---boolean Set to true to return all ray cast hits. If false, it will only return the closest hit. +--- +---@return physics.raycast_response[]|physics.raycast_response|nil result It returns a list. If missed it returns nil. See ray_cast_response for details on the returned values. +function physics.raycast(from, to, groups, options) end + +---Ray casts are used to test for intersections against collision objects in the physics world. +---Collision objects of types kinematic, dynamic and static are tested against. Trigger objects +---do not intersect with ray casts. +---Which collision objects to hit is filtered by their collision groups and can be configured +---through groups. +---The actual ray cast will be performed during the physics-update. +---If an object is hit, the result will be reported via a ray_cast_response message. +---If there is no object hit, the result will be reported via a ray_cast_missed message. +---@param from vector3 the world position of the start of the ray +---@param to vector3 the world position of the end of the ray +---@param groups table a lua table containing the hashed groups for which to test collisions against +---@param request_id number|nil a number between [0,-255]. It will be sent back in the response for identification, 0 by default +function physics.raycast_async(from, to, groups, request_id) end + +---Set the gravity in runtime. The gravity change is not global, it will only affect +---the collection that the function is called from. +---Note: For 2D physics the z component of the gravity vector will be ignored. +---@param gravity vector3 the new gravity vector +function physics.set_gravity(gravity) end + +---Updates the group property of a collision object to the specified +---string value. The group name should exist i.e. have been used in +---a collision object in the editor. +---@param url string|hash|url the collision object affected. +---@param group string the new group name to be assigned. +---local function change_collision_group() +--- physics.set_group("#collisionobject", "enemy") +---end +--- +function physics.set_group(url, group) end + +---Flips the collision shapes horizontally for a collision object +---@param url string|hash|url the collision object that should flip its shapes +---@param flip boolean true if the collision object should flip its shapes, false if not +function physics.set_hflip(url, flip) end + +---Updates the properties for an already connected joint. The joint has to be created before +---properties can be changed. +---Note: Currently only supported in 2D physics. +---@param collisionobject string|hash|url collision object where the joint exist +---@param joint_id string|hash id of the joint +---@param properties table joint specific properties table +---Note: The collide_connected field cannot be updated/changed after a connection has been made. +function physics.set_joint_properties(collisionobject, joint_id, properties) end + +---sets a physics world event listener. If a function is set, physics messages will no longer be sent. +---@param callback fun(self, event, data)|nil A callback that receives information about all the physics interactions in this physics world. +--- +---self +---object The calling script +---event +---constant The type of event. Can be one of these messages: +--- +--- +---contact_point_event +---collision_event +---trigger_event +---ray_cast_response +---ray_cast_missed +--- +--- +---data +---table The callback value data is a table that contains event-related data. See the documentation for details on the messages. +--- +function physics.set_listener(callback) end + +---Sets or clears the masking of a group (maskbit) in a collision object. +---@param url string|hash|url the collision object to change the mask of. +---@param group string the name of the group (maskbit) to modify in the mask. +---@param maskbit boolean boolean value of the new maskbit. 'true' to enable, 'false' to disable. +---local function make_invincible() +--- -- no longer collide with the "bullet" group +--- physics.set_maskbit("#collisionobject", "bullet", false) +---end +--- +function physics.set_maskbit(url, group, maskbit) end + +---Sets collision shape data for a collision object. Please note that updating data in 3D +---can be quite costly for box and capsules. Because of the physics engine, the cost +---comes from having to recreate the shape objects when certain shapes needs to be updated. +---@param url string|hash|url the collision object. +---@param shape string|hash the name of the shape to get data for. +---@param table { diameter:number|nil, dimensions:vector3|nil, height:number|nil } the shape data to update the shape with. +---See physics.get_shape for a detailed description of each field in the data table. +---local function set_shape_data() +--- -- set capsule shape data +--- local data = {} +--- data.type = physics.SHAPE_TYPE_CAPSULE +--- data.diameter = 10 +--- data.height = 20 +--- physics.set_shape("#collisionobject", "my_capsule_shape", data) +--- +--- -- set sphere shape data +--- data = {} +--- data.type = physics.SHAPE_TYPE_SPHERE +--- data.diameter = 10 +--- physics.set_shape("#collisionobject", "my_sphere_shape", data) +--- +--- -- set box shape data +--- data = {} +--- data.type = physics.SHAPE_TYPE_BOX +--- data.dimensions = vmath.vector3(10, 10, 5) +--- physics.set_shape("#collisionobject", "my_box_shape", data) +---end +--- +function physics.set_shape(url, shape, table) end + +---Flips the collision shapes vertically for a collision object +---@param url string|hash|url the collision object that should flip its shapes +---@param flip boolean true if the collision object should flip its shapes, false if not +function physics.set_vflip(url, flip) end + +---The function recalculates the density of each shape based on the total area of all shapes and the specified mass, then updates the mass of the body accordingly. +---Note: Currently only supported in 2D physics. +---@param collisionobject string|hash|url the collision object whose mass needs to be updated. +---@param mass number the new mass value to set for the collision object. +function physics.update_mass(collisionobject, mass) end + +---Collision objects tend to fall asleep when inactive for a small period of time for +---efficiency reasons. This function wakes them up. +---@param url string|hash|url the collision object to wake. +---function on_input(self, action_id, action) +--- if action_id == hash("test") and action.pressed then +--- physics.wakeup("#collisionobject") +--- end +---end +--- +function physics.wakeup(url) end + +return physics \ No newline at end of file diff --git a/annotations/defold_annotations/profiler.lua b/annotations/defold_annotations/profiler.lua new file mode 100644 index 0000000..ea988f3 --- /dev/null +++ b/annotations/defold_annotations/profiler.lua @@ -0,0 +1,126 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Profiler API documentation + + Functions for getting profiling data in runtime. + More detailed profiling and debugging information available in the manuals. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.profiler +profiler = {} + +---pause on current frame +profiler.MODE_PAUSE = nil + +---start recording +profiler.MODE_RECORD = nil + +---continously show latest frame +profiler.MODE_RUN = nil + +---pause at peak frame +profiler.MODE_SHOW_PEAK_FRAME = nil + +---show full profiler ui +profiler.VIEW_MODE_FULL = nil + +---show mimimal profiler ui +profiler.VIEW_MODE_MINIMIZED = nil + +---Creates and shows or hides and destroys the on-sceen profiler ui +---The profiler is a real-time tool that shows the numbers of milliseconds spent +---in each scope per frame as well as counters. The profiler is very useful for +---tracking down performance and resource problems. +---@param enabled boolean true to enable, false to disable +function profiler.enable_ui(enabled) end + +---Get the percent of CPU usage by the application, as reported by the OS. +--- This function is not available on HTML5. +---For some platforms ( Android, Linux and Windows), this information is only available +---by default in the debug version of the engine. It can be enabled in release version as well +---by checking track_cpu under profiler in the game.project file. +---(This means that the engine will sample the CPU usage in intervalls during execution even in release mode.) +---@return number percent of CPU used by the application +function profiler.get_cpu_usage() end + +---Get the amount of memory used (resident/working set) by the application in bytes, as reported by the OS. +--- This function is not available on HTML5. +---The values are gathered from internal OS functions which correspond to the following; +---OS +---Value +--- iOS MacOSAndroid Linux +---Resident memory +--- Windows +---Working set +--- HTML5 +--- Not available +---@return number bytes used by the application +function profiler.get_memory_usage() end + +---Send a text to the profiler +---@param text string the string to send to the profiler +function profiler.log_text(text) end + +---Get the number of recorded frames in the on-screen profiler ui recording buffer +---@return number frame_count the number of recorded frames, zero if on-screen profiler is disabled +function profiler.recorded_frame_count() end + +---Starts a profile scope. +---@param name string The name of the scope +function profiler.scope_begin(name) end + +---End the current profile scope. +function profiler.scope_end() end + +---Set the on-screen profile mode - run, pause, record or show peak frame +---@param mode constant the mode to set the ui profiler in +--- +---profiler.MODE_RUN This is default mode that continously shows the last frame +---profiler.MODE_PAUSE Pauses on the currently displayed frame +---profiler.MODE_SHOW_PEAK_FRAME Pauses on the currently displayed frame but shows a new frame if that frame is slower +---profiler.MODE_RECORD Records all incoming frames to the recording buffer +--- +---To stop recording, switch to a different mode such as MODE_PAUSE or MODE_RUN. +---You can also use the view_recorded_frame function to display a recorded frame. Doing so stops the recording as well. +---Every time you switch to recording mode the recording buffer is cleared. +---The recording buffer is also cleared when setting the MODE_SHOW_PEAK_FRAME mode. +function profiler.set_ui_mode(mode) end + +---Set the on-screen profile view mode - minimized or expanded +---@param mode constant the view mode to set the ui profiler in +--- +---profiler.VIEW_MODE_FULL The default mode which displays all the ui profiler details +---profiler.VIEW_MODE_MINIMIZED Minimized mode which only shows the top header (fps counters and ui profiler mode) +--- +function profiler.set_ui_view_mode(mode) end + +---Shows or hides the time the engine waits for vsync in the on-screen profiler +---Each frame the engine waits for vsync and depending on your vsync settings and how much time +---your game logic takes this time can dwarf the time in the game logic making it hard to +---see details in the on-screen profiler graph and lists. +---Also, by hiding this the FPS times in the header show the time spent each time excuding the +---time spent waiting for vsync. This shows you how long time your game is spending actively +---working each frame. +---This setting also effects the display of recorded frames but does not affect the actual +---recorded frames so it is possible to toggle this on and off when viewing recorded frames. +---By default the vsync wait times is displayed in the profiler. +---@param visible boolean true to include it in the display, false to hide it. +function profiler.set_ui_vsync_wait_visible(visible) end + +---Pauses and displays a frame from the recording buffer in the on-screen profiler ui +---The frame to show can either be an absolute frame or a relative frame to the current frame. +---@param frame_index table a table where you specify one of the following parameters: +--- +---distance The offset from the currently displayed frame (this is truncated between zero and the number of recorded frames) +---frame The frame index in the recording buffer (1 is first recorded frame) +--- +function profiler.view_recorded_frame(frame_index) end + +return profiler \ No newline at end of file diff --git a/annotations/defold_annotations/render.lua b/annotations/defold_annotations/render.lua new file mode 100644 index 0000000..6040de2 --- /dev/null +++ b/annotations/defold_annotations/render.lua @@ -0,0 +1,689 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Rendering API documentation + + Rendering functions, messages and constants. The "render" namespace is + accessible only from render scripts. + The rendering API was originally built on top of OpenGL ES 2.0, and it uses a subset of the + OpenGL computer graphics rendering API for rendering 2D and 3D computer + graphics. Our current target is OpenGLES 3.0 with fallbacks to 2.0 on some platforms. + It is possible to create materials and write shaders that + require features not in OpenGL ES 2.0, but those will not work cross platform. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.render +render = {} + +--- +render.BLEND_CONSTANT_ALPHA = nil + +--- +render.BLEND_CONSTANT_COLOR = nil + +--- +render.BLEND_DST_ALPHA = nil + +--- +render.BLEND_DST_COLOR = nil + +--- +render.BLEND_ONE = nil + +--- +render.BLEND_ONE_MINUS_CONSTANT_ALPHA = nil + +--- +render.BLEND_ONE_MINUS_CONSTANT_COLOR = nil + +--- +render.BLEND_ONE_MINUS_DST_ALPHA = nil + +--- +render.BLEND_ONE_MINUS_DST_COLOR = nil + +--- +render.BLEND_ONE_MINUS_SRC_ALPHA = nil + +--- +render.BLEND_ONE_MINUS_SRC_COLOR = nil + +--- +render.BLEND_SRC_ALPHA = nil + +--- +render.BLEND_SRC_ALPHA_SATURATE = nil + +--- +render.BLEND_SRC_COLOR = nil + +--- +render.BLEND_ZERO = nil + +--- +render.BUFFER_COLOR0_BIT = nil + +--- +render.BUFFER_COLOR1_BIT = nil + +--- +render.BUFFER_COLOR2_BIT = nil + +--- +render.BUFFER_COLOR3_BIT = nil + +--- +render.BUFFER_COLOR_BIT = nil + +--- +render.BUFFER_DEPTH_BIT = nil + +--- +render.BUFFER_STENCIL_BIT = nil + +--- +render.COMPARE_FUNC_ALWAYS = nil + +--- +render.COMPARE_FUNC_EQUAL = nil + +--- +render.COMPARE_FUNC_GEQUAL = nil + +--- +render.COMPARE_FUNC_GREATER = nil + +--- +render.COMPARE_FUNC_LEQUAL = nil + +--- +render.COMPARE_FUNC_LESS = nil + +--- +render.COMPARE_FUNC_NEVER = nil + +--- +render.COMPARE_FUNC_NOTEQUAL = nil + +--- +render.FACE_BACK = nil + +--- +render.FACE_FRONT = nil + +--- +render.FACE_FRONT_AND_BACK = nil + +--- +render.FILTER_LINEAR = nil + +--- +render.FILTER_NEAREST = nil + +--- +render.FORMAT_DEPTH = nil + +--- +render.FORMAT_LUMINANCE = nil + +---May be nil if the format isn't supported +render.FORMAT_R16F = nil + +---May be nil if the format isn't supported +render.FORMAT_R32F = nil + +---May be nil if the format isn't supported +render.FORMAT_RG16F = nil + +---May be nil if the format isn't supported +render.FORMAT_RG32F = nil + +--- +render.FORMAT_RGB = nil + +---May be nil if the format isn't supported +render.FORMAT_RGB16F = nil + +---May be nil if the format isn't supported +render.FORMAT_RGB32F = nil + +--- +render.FORMAT_RGBA = nil + +---May be nil if the format isn't supported +render.FORMAT_RGBA16F = nil + +---May be nil if the format isn't supported +render.FORMAT_RGBA32F = nil + +--- +render.FORMAT_STENCIL = nil + +--- +render.FRUSTUM_PLANES_ALL = nil + +--- +render.FRUSTUM_PLANES_SIDES = nil + +--- +render.RENDER_TARGET_DEFAULT = nil + +--- +render.STATE_BLEND = nil + +--- +render.STATE_CULL_FACE = nil + +--- +render.STATE_DEPTH_TEST = nil + +--- +render.STATE_POLYGON_OFFSET_FILL = nil + +--- +render.STATE_STENCIL_TEST = nil + +--- +render.STENCIL_OP_DECR = nil + +--- +render.STENCIL_OP_DECR_WRAP = nil + +--- +render.STENCIL_OP_INCR = nil + +--- +render.STENCIL_OP_INCR_WRAP = nil + +--- +render.STENCIL_OP_INVERT = nil + +--- +render.STENCIL_OP_KEEP = nil + +--- +render.STENCIL_OP_REPLACE = nil + +--- +render.STENCIL_OP_ZERO = nil + +--- +render.WRAP_CLAMP_TO_BORDER = nil + +--- +render.WRAP_CLAMP_TO_EDGE = nil + +--- +render.WRAP_MIRRORED_REPEAT = nil + +--- +render.WRAP_REPEAT = nil + +---Clear buffers in the currently enabled render target with specified value. If the render target has been created with multiple +---color attachments, all buffers will be cleared with the same value. +---@param buffers table table with keys specifying which buffers to clear and values set to clear values. Available keys are: +--- +---render.BUFFER_COLOR_BIT +---render.BUFFER_DEPTH_BIT +---render.BUFFER_STENCIL_BIT +--- +function render.clear(buffers) end + +---Constant buffers are used to set shader program variables and are optionally passed to the render.draw() function. +---The buffer's constant elements can be indexed like an ordinary Lua table, but you can't iterate over them with pairs() or ipairs(). +---@return constant_buffer buffer new constant buffer +function render.constant_buffer() end + +---Deletes a render target created by a render script. +---You cannot delete a render target resource. +---@param render_target render_target render target to delete +function render.delete_render_target(render_target) end + +---If a material is currently enabled, disable it. +---The name of the material must be specified in the ".render" resource set +---in the "game.project" setting. +function render.disable_material() end + +---Disables a render state. +---@param state constant state to disable +--- +---render.STATE_DEPTH_TEST +---render.STATE_STENCIL_TEST +---render.STATE_BLEND +---render.STATE_ALPHA_TEST ( not available on iOS and Android) +---render.STATE_CULL_FACE +---render.STATE_POLYGON_OFFSET_FILL +--- +function render.disable_state(state) end + +---Disables a texture that has previourly been enabled. +---@param binding number|string|hash texture binding, either by texture unit, string or hash that should be disabled +function render.disable_texture(binding) end + +---Draws all objects that match a specified predicate. An optional constant buffer can be +---provided to override the default constants. If no constants buffer is provided, a default +---system constants buffer is used containing constants as defined in materials and set through +---go.set (or particlefx.set_constant) on visual components. +---@param predicate render_predicate predicate to draw for +---@param options { frustum:matrix4|nil, frustum_planes:number|nil, constants:constant_buffer|nil }|nil optional table with properties: +--- +---frustum +---vmath.matrix4 A frustum matrix used to cull renderable items. (E.g. local frustum = proj * view). default=nil +---frustum_planes +---int Determines which sides of the frustum will be used. Default is render.FRUSTUM_PLANES_SIDES. +--- +--- +---render.FRUSTUM_PLANES_SIDES : The left, right, top and bottom sides of the frustum. +---render.FRUSTUM_PLANES_ALL : All 6 sides of the frustum. +--- +--- +---constants +---constant_buffer optional constants to use while rendering +--- +function render.draw(predicate, options) end + +---Draws all 3d debug graphics such as lines drawn with "draw_line" messages and physics visualization. +---@param options { frustum:matrix4|nil, frustum_planes:number|nil }|nil optional table with properties: +--- +---frustum +---vmath.matrix4 A frustum matrix used to cull renderable items. (E.g. local frustum = proj * view). May be nil. +---frustum_planes +---int Determines which sides of the frustum will be used. Default is render.FRUSTUM_PLANES_SIDES. +--- +--- +---render.FRUSTUM_PLANES_SIDES : The left, right, top and bottom sides of the frustum. +---render.FRUSTUM_PLANES_ALL : All sides of the frustum. +--- +function render.draw_debug3d(options) end + +---If another material was already enabled, it will be automatically disabled +---and the specified material is used instead. +---The name of the material must be specified in the ".render" resource set +---in the "game.project" setting. +---@param material_id string|hash material id to enable +function render.enable_material(material_id) end + +---Enables a particular render state. The state will be enabled until disabled. +---@param state constant state to enable +--- +---render.STATE_DEPTH_TEST +---render.STATE_STENCIL_TEST +---render.STATE_BLEND +---render.STATE_ALPHA_TEST ( not available on iOS and Android) +---render.STATE_CULL_FACE +---render.STATE_POLYGON_OFFSET_FILL +--- +function render.enable_state(state) end + +---Sets the specified texture handle for a render target attachment or a regular texture +---that should be used for rendering. The texture can be bound to either a texture unit +---or to a sampler name by a hash or a string. +---A texture can be bound to multiple units and sampler names at the same time, +---the actual binding will be applied to the shaders when a shader program is bound. +---When mixing binding using both units and sampler names, you might end up in situations +---where two different textures will be applied to the same bind location in the shader. +---In this case, the texture set to the named sampler will take precedence over the unit. +---Note that you can bind multiple sampler names to the same texture, in case you want to reuse +---the same texture for differnt use-cases. It is however recommended that you use the same name +---everywhere for the textures that should be shared across different materials. +---@param binding number|string|hash texture binding, either by texture unit, string or hash for the sampler name that the texture should be bound to +---@param handle_or_name resource_handle|string|hash render target or texture handle that should be bound, or a named resource in the "Render Resource" table in the currently assigned .render file +---@param buffer_type constant|nil optional buffer type from which to enable the texture. Note that this argument only applies to render targets. Defaults to render.BUFFER_COLOR_BIT. These values are supported: +--- +---render.BUFFER_COLOR_BIT +--- +---If The render target has been created as depth and/or stencil textures, these buffer types can be used: +--- +---render.BUFFER_DEPTH_BIT +---render.BUFFER_STENCIL_BIT +--- +---If the render target has been created with multiple color attachments, these buffer types can be used +---to enable those textures as well. Currently 4 color attachments are supported: +--- +---render.BUFFER_COLOR0_BIT +---render.BUFFER_COLOR1_BIT +---render.BUFFER_COLOR2_BIT +---render.BUFFER_COLOR3_BIT +--- +function render.enable_texture(binding, handle_or_name, buffer_type) end + +---Returns the logical window height that is set in the "game.project" settings. +---Note that the actual window pixel size can change, either by device constraints +---or user input. +---@return number height specified window height +function render.get_height() end + +---Returns the specified buffer height from a render target. +---@param render_target render_target render target from which to retrieve the buffer height +---@param buffer_type constant which type of buffer to retrieve the height from +--- +---render.BUFFER_COLOR_BIT +---render.BUFFER_DEPTH_BIT +---render.BUFFER_STENCIL_BIT +--- +---@return number height the height of the render target buffer texture +function render.get_render_target_height(render_target, buffer_type) end + +---Returns the specified buffer width from a render target. +---@param render_target render_target render target from which to retrieve the buffer width +---@param buffer_type constant which type of buffer to retrieve the width from +--- +---render.BUFFER_COLOR_BIT +---render.BUFFER_COLOR[x]_BIT (x: [0..3], if supported!) +---render.BUFFER_DEPTH_BIT +---render.BUFFER_STENCIL_BIT +--- +---@return number width the width of the render target buffer texture +function render.get_render_target_width(render_target, buffer_type) end + +---Returns the logical window width that is set in the "game.project" settings. +---Note that the actual window pixel size can change, either by device constraints +---or user input. +---@return number width specified window width (number) +function render.get_width() end + +---Returns the actual physical window height. +---Note that this value might differ from the logical height that is set in the +---"game.project" settings. +---@return number height actual window height +function render.get_window_height() end + +---Returns the actual physical window width. +---Note that this value might differ from the logical width that is set in the +---"game.project" settings. +---@return number width actual window width +function render.get_window_width() end + +---This function returns a new render predicate for objects with materials matching +---the provided material tags. The provided tags are combined into a bit mask +---for the predicate. If multiple tags are provided, the predicate matches materials +---with all tags ANDed together. +---The current limit to the number of tags that can be defined is 64. +---@param tags (string|hash)[] table of tags that the predicate should match. The tags can be of either hash or string type +---@return render_predicate predicate new predicate +function render.predicate(tags) end + +---Creates a new render target according to the supplied +---specification table. +---The table should contain keys specifying which buffers should be created +---with what parameters. Each buffer key should have a table value consisting +---of parameters. The following parameter keys are available: +---Key +---Values +---format +---render.FORMAT_LUMINANCErender.FORMAT_RGBrender.FORMAT_RGBArender.FORMAT_DEPTHrender.FORMAT_STENCILrender.FORMAT_RGBA32Frender.FORMAT_RGBA16F +---width +---number +---height +---number +---min_filter (optional) +---render.FILTER_LINEARrender.FILTER_NEAREST +---mag_filter (optional) +---render.FILTER_LINEARrender.FILTER_NEAREST +---u_wrap (optional) +---render.WRAP_CLAMP_TO_BORDERrender.WRAP_CLAMP_TO_EDGErender.WRAP_MIRRORED_REPEATrender.WRAP_REPEAT +---v_wrap (optional) +---render.WRAP_CLAMP_TO_BORDERrender.WRAP_CLAMP_TO_EDGErender.WRAP_MIRRORED_REPEATrender.WRAP_REPEAT +---flags (optional) +---render.TEXTURE_BIT (only applicable to depth and stencil buffers) +---The render target can be created to support multiple color attachments. Each attachment can have different format settings and texture filters, +---but attachments must be added in sequence, meaning you cannot create a render target at slot 0 and 3. +---Instead it has to be created with all four buffer types ranging from [0..3] (as denoted by render.BUFFER_COLORX_BIT where 'X' is the attachment you want to create). +---It is not guaranteed that the device running the script can support creating render targets with multiple color attachments. To check if the device can support multiple attachments, +---you can check if the render table contains any of the BUFFER_COLOR1_BIT, BUFFER_COLOR2_BIT or BUFFER_COLOR3_BIT constants: +---function init(self) +--- if render.BUFFER_COLOR1_BIT == nil then +--- -- this devices does not support multiple color attachments +--- end +---end +---@param name string render target name +---@param parameters table table of buffer parameters, see the description for available keys and values +---@return render_target render_target new render target +function render.render_target(name, parameters) end + +---Specifies the arithmetic used when computing pixel values that are written to the frame +---buffer. In RGBA mode, pixels can be drawn using a function that blends the source RGBA +---pixel values with the destination pixel values already in the frame buffer. +---Blending is initially disabled. +---source_factor specifies which method is used to scale the source color components. +---destination_factor specifies which method is used to scale the destination color +---components. +---Source color components are referred to as (Rs,Gs,Bs,As). +---Destination color components are referred to as (Rd,Gd,Bd,Ad). +---The color specified by setting the blendcolor is referred to as (Rc,Gc,Bc,Ac). +---The source scale factor is referred to as (sR,sG,sB,sA). +---The destination scale factor is referred to as (dR,dG,dB,dA). +---The color values have integer values between 0 and (kR,kG,kB,kA), where kc = 2mc - 1 and mc is the number of bitplanes for that color. I.e for 8 bit color depth, color values are between 0 and 255. +---Available factor constants and corresponding scale factors: +---Factor constant +---Scale factor (fR,fG,fB,fA) +---render.BLEND_ZERO +---(0,0,0,0) +---render.BLEND_ONE +---(1,1,1,1) +---render.BLEND_SRC_COLOR +---(Rs/kR,Gs/kG,Bs/kB,As/kA) +---render.BLEND_ONE_MINUS_SRC_COLOR +---(1,1,1,1) - (Rs/kR,Gs/kG,Bs/kB,As/kA) +---render.BLEND_DST_COLOR +---(Rd/kR,Gd/kG,Bd/kB,Ad/kA) +---render.BLEND_ONE_MINUS_DST_COLOR +---(1,1,1,1) - (Rd/kR,Gd/kG,Bd/kB,Ad/kA) +---render.BLEND_SRC_ALPHA +---(As/kA,As/kA,As/kA,As/kA) +---render.BLEND_ONE_MINUS_SRC_ALPHA +---(1,1,1,1) - (As/kA,As/kA,As/kA,As/kA) +---render.BLEND_DST_ALPHA +---(Ad/kA,Ad/kA,Ad/kA,Ad/kA) +---render.BLEND_ONE_MINUS_DST_ALPHA +---(1,1,1,1) - (Ad/kA,Ad/kA,Ad/kA,Ad/kA) +---render.BLEND_CONSTANT_COLOR +---(Rc,Gc,Bc,Ac) +---render.BLEND_ONE_MINUS_CONSTANT_COLOR +---(1,1,1,1) - (Rc,Gc,Bc,Ac) +---render.BLEND_CONSTANT_ALPHA +---(Ac,Ac,Ac,Ac) +---render.BLEND_ONE_MINUS_CONSTANT_ALPHA +---(1,1,1,1) - (Ac,Ac,Ac,Ac) +---render.BLEND_SRC_ALPHA_SATURATE +---(i,i,i,1) where i = min(As, kA - Ad) /kA +---The blended RGBA values of a pixel comes from the following equations: +---Rd = min(kR, Rs * sR + Rd * dR) +---Gd = min(kG, Gs * sG + Gd * dG) +---Bd = min(kB, Bs * sB + Bd * dB) +---Ad = min(kA, As * sA + Ad * dA) +---Blend function (render.BLEND_SRC_ALPHA, render.BLEND_ONE_MINUS_SRC_ALPHA) is useful for +---drawing with transparency when the drawn objects are sorted from farthest to nearest. +---It is also useful for drawing antialiased points and lines in arbitrary order. +---@param source_factor constant source factor +---@param destination_factor constant destination factor +function render.set_blend_func(source_factor, destination_factor) end + +---Sets the current render camera to be used for rendering. If a render camera +---has been set by the render script, the renderer will be using its projection and view matrix +---during rendering. If a projection and/or view matrix has been set by the render script, +---they will not be used until the current render camera has been reset by calling render.set_camera(). +---If the 'use_frustum' flag in the options table has been set to true, the renderer will automatically use the +---camera frustum for frustum culling regardless of what frustum is being passed into the render.draw() function. +---Note that the frustum plane option in render.draw can still be used together with the camera. +---@param camera url|resource_handle|nil camera id to use, or nil to reset +---@param options { use_frustum:boolean|nil }|nil optional table with properties: +--- +---use_frustum +---boolean If true, the renderer will use the cameras view-projection matrix for frustum culling (default: false) +--- +function render.set_camera(camera, options) end + +---Specifies whether the individual color components in the frame buffer is enabled for writing (true) or disabled (false). For example, if blue is false, nothing is written to the blue component of any pixel in any of the color buffers, regardless of the drawing operation attempted. Note that writing are either enabled or disabled for entire color components, not the individual bits of a component. +---The component masks are all initially true. +---@param red boolean red mask +---@param green boolean green mask +---@param blue boolean blue mask +---@param alpha boolean alpha mask +function render.set_color_mask(red, green, blue, alpha) end + +---Specifies whether front- or back-facing polygons can be culled +---when polygon culling is enabled. Polygon culling is initially disabled. +---If mode is render.FACE_FRONT_AND_BACK, no polygons are drawn, but other +---primitives such as points and lines are drawn. The initial value for +---face_type is render.FACE_BACK. +---@param face_type constant face type +--- +---render.FACE_FRONT +---render.FACE_BACK +---render.FACE_FRONT_AND_BACK +--- +function render.set_cull_face(face_type) end + +---Specifies the function that should be used to compare each incoming pixel +---depth value with the value present in the depth buffer. +---The comparison is performed only if depth testing is enabled and specifies +---the conditions under which a pixel will be drawn. +---Function constants: +---render.COMPARE_FUNC_NEVER (never passes) +---render.COMPARE_FUNC_LESS (passes if the incoming depth value is less than the stored value) +---render.COMPARE_FUNC_LEQUAL (passes if the incoming depth value is less than or equal to the stored value) +---render.COMPARE_FUNC_GREATER (passes if the incoming depth value is greater than the stored value) +---render.COMPARE_FUNC_GEQUAL (passes if the incoming depth value is greater than or equal to the stored value) +---render.COMPARE_FUNC_EQUAL (passes if the incoming depth value is equal to the stored value) +---render.COMPARE_FUNC_NOTEQUAL (passes if the incoming depth value is not equal to the stored value) +---render.COMPARE_FUNC_ALWAYS (always passes) +---The depth function is initially set to render.COMPARE_FUNC_LESS. +---@param func constant depth test function, see the description for available values +function render.set_depth_func(func) end + +---Specifies whether the depth buffer is enabled for writing. The supplied mask governs +---if depth buffer writing is enabled (true) or disabled (false). +---The mask is initially true. +---@param depth boolean depth mask +function render.set_depth_mask(depth) end + +---Sets the scale and units used to calculate depth values. +---If render.STATE_POLYGON_OFFSET_FILL is enabled, each fragment's depth value +---is offset from its interpolated value (depending on the depth value of the +---appropriate vertices). Polygon offset can be used when drawing decals, rendering +---hidden-line images etc. +---factor specifies a scale factor that is used to create a variable depth +---offset for each polygon. The initial value is 0. +---units is multiplied by an implementation-specific value to create a +---constant depth offset. The initial value is 0. +---The value of the offset is computed as factor × DZ + r × units +---DZ is a measurement of the depth slope of the polygon which is the change in z (depth) +---values divided by the change in either x or y coordinates, as you traverse a polygon. +---The depth values are in window coordinates, clamped to the range [0, 1]. +---r is the smallest value that is guaranteed to produce a resolvable difference. +---It's value is an implementation-specific constant. +---The offset is added before the depth test is performed and before the +---value is written into the depth buffer. +---@param factor number polygon offset factor +---@param units number polygon offset units +function render.set_polygon_offset(factor, units) end + +---Sets the projection matrix to use when rendering. +---@param matrix matrix4 projection matrix +function render.set_projection(matrix) end + +---Sets a render target. Subsequent draw operations will be to the +---render target until it is replaced by a subsequent call to set_render_target. +---This function supports render targets created by a render script, or a render target resource. +---@param render_target render_target render target to set. render.RENDER_TARGET_DEFAULT to set the default render target +---@param options { transient:number[]|nil }|nil optional table with behaviour parameters +--- +---transient +---table Transient frame buffer types are only valid while the render target is active, i.e becomes undefined when a new target is set by a subsequent call to set_render_target. +--- Default is all non-transient. Be aware that some hardware uses a combined depth stencil buffer and when this is the case both are considered non-transient if exclusively selected! +--- A buffer type defined that doesn't exist in the render target is silently ignored. +--- +--- +---render.BUFFER_COLOR_BIT +---render.BUFFER_DEPTH_BIT +---render.BUFFER_STENCIL_BIT +--- +function render.set_render_target(render_target, options) end + +---Sets the render target size for a render target created from +---either a render script, or from a render target resource. +---@param render_target render_target render target to set size for +---@param width number new render target width +---@param height number new render target height +function render.set_render_target_size(render_target, width, height) end + +---Stenciling is similar to depth-buffering as it enables and disables drawing on a +---per-pixel basis. First, GL drawing primitives are drawn into the stencil planes. +---Second, geometry and images are rendered but using the stencil planes to mask out +---where to draw. +---The stencil test discards a pixel based on the outcome of a comparison between the +---reference value ref and the corresponding value in the stencil buffer. +---func specifies the comparison function. See the table below for values. +---The initial value is render.COMPARE_FUNC_ALWAYS. +---ref specifies the reference value for the stencil test. The value is clamped to +---the range [0, 2n-1], where n is the number of bitplanes in the stencil buffer. +---The initial value is 0. +---mask is ANDed with both the reference value and the stored stencil value when the test +---is done. The initial value is all 1's. +---Function constant: +---render.COMPARE_FUNC_NEVER (never passes) +---render.COMPARE_FUNC_LESS (passes if (ref & mask) < (stencil & mask)) +---render.COMPARE_FUNC_LEQUAL (passes if (ref & mask) <= (stencil & mask)) +---render.COMPARE_FUNC_GREATER (passes if (ref & mask) > (stencil & mask)) +---render.COMPARE_FUNC_GEQUAL (passes if (ref & mask) >= (stencil & mask)) +---render.COMPARE_FUNC_EQUAL (passes if (ref & mask) = (stencil & mask)) +---render.COMPARE_FUNC_NOTEQUAL (passes if (ref & mask) != (stencil & mask)) +---render.COMPARE_FUNC_ALWAYS (always passes) +---@param func constant stencil test function, see the description for available values +---@param ref number reference value for the stencil test +---@param mask number mask that is ANDed with both the reference value and the stored stencil value when the test is done +function render.set_stencil_func(func, ref, mask) end + +---The stencil mask controls the writing of individual bits in the stencil buffer. +---The least significant n bits of the parameter mask, where n is the number of +---bits in the stencil buffer, specify the mask. +---Where a 1 bit appears in the mask, the corresponding +---bit in the stencil buffer can be written. Where a 0 bit appears in the mask, +---the corresponding bit in the stencil buffer is never written. +---The mask is initially all 1's. +---@param mask number stencil mask +function render.set_stencil_mask(mask) end + +---The stencil test discards a pixel based on the outcome of a comparison between the +---reference value ref and the corresponding value in the stencil buffer. +---To control the test, call render.set_stencil_func. +---This function takes three arguments that control what happens to the stored stencil +---value while stenciling is enabled. If the stencil test fails, no change is made to the +---pixel's color or depth buffers, and sfail specifies what happens to the stencil buffer +---contents. +---Operator constants: +---render.STENCIL_OP_KEEP (keeps the current value) +---render.STENCIL_OP_ZERO (sets the stencil buffer value to 0) +---render.STENCIL_OP_REPLACE (sets the stencil buffer value to ref, as specified by render.set_stencil_func) +---render.STENCIL_OP_INCR (increments the stencil buffer value and clamp to the maximum representable unsigned value) +---render.STENCIL_OP_INCR_WRAP (increments the stencil buffer value and wrap to zero when incrementing the maximum representable unsigned value) +---render.STENCIL_OP_DECR (decrements the current stencil buffer value and clamp to 0) +---render.STENCIL_OP_DECR_WRAP (decrements the current stencil buffer value and wrap to the maximum representable unsigned value when decrementing zero) +---render.STENCIL_OP_INVERT (bitwise inverts the current stencil buffer value) +---dppass and dpfail specify the stencil buffer actions depending on whether subsequent +---depth buffer tests succeed (dppass) or fail (dpfail). +---The initial value for all operators is render.STENCIL_OP_KEEP. +---@param sfail constant action to take when the stencil test fails +---@param dpfail constant the stencil action when the stencil test passes +---@param dppass constant the stencil action when both the stencil test and the depth test pass, or when the stencil test passes and either there is no depth buffer or depth testing is not enabled +function render.set_stencil_op(sfail, dpfail, dppass) end + +---Sets the view matrix to use when rendering. +---@param matrix matrix4 view matrix to set +function render.set_view(matrix) end + +---Set the render viewport to the specified rectangle. +---@param x number left corner +---@param y number bottom corner +---@param width number viewport width +---@param height number viewport height +function render.set_viewport(x, y, width, height) end + +return render \ No newline at end of file diff --git a/annotations/defold_annotations/resource.lua b/annotations/defold_annotations/resource.lua new file mode 100644 index 0000000..9732207 --- /dev/null +++ b/annotations/defold_annotations/resource.lua @@ -0,0 +1,760 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Resource API documentation + + Functions and constants to access resources. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.resource +resource = {} + +---BASIS_UASTC compression type +resource.COMPRESSION_TYPE_BASIS_UASTC = nil + +---COMPRESSION_TYPE_DEFAULT compression type +resource.COMPRESSION_TYPE_DEFAULT = nil + +---luminance type texture format +resource.TEXTURE_FORMAT_LUMINANCE = nil + +---R16F type texture format +resource.TEXTURE_FORMAT_R16F = nil + +---R32F type texture format +resource.TEXTURE_FORMAT_R32F = nil + +---RG16F type texture format +resource.TEXTURE_FORMAT_RG16F = nil + +---RG32F type texture format +resource.TEXTURE_FORMAT_RG32F = nil + +---RGB type texture format +resource.TEXTURE_FORMAT_RGB = nil + +---RGB16F type texture format +resource.TEXTURE_FORMAT_RGB16F = nil + +---RGB32F type texture format +resource.TEXTURE_FORMAT_RGB32F = nil + +---RGBA type texture format +resource.TEXTURE_FORMAT_RGBA = nil + +---RGBA16F type texture format +resource.TEXTURE_FORMAT_RGBA16F = nil + +---RGBA32F type texture format +resource.TEXTURE_FORMAT_RGBA32F = nil + +---RGBA_ASTC_4x4 type texture format +resource.TEXTURE_FORMAT_RGBA_ASTC_4x4 = nil + +---RGBA_BC3 type texture format +resource.TEXTURE_FORMAT_RGBA_BC3 = nil + +---RGBA_BC7 type texture format +resource.TEXTURE_FORMAT_RGBA_BC7 = nil + +---RGBA_ETC2 type texture format +resource.TEXTURE_FORMAT_RGBA_ETC2 = nil + +---RGBA_PVRTC_2BPPV1 type texture format +resource.TEXTURE_FORMAT_RGBA_PVRTC_2BPPV1 = nil + +---RGBA_PVRTC_4BPPV1 type texture format +resource.TEXTURE_FORMAT_RGBA_PVRTC_4BPPV1 = nil + +---RGB_BC1 type texture format +resource.TEXTURE_FORMAT_RGB_BC1 = nil + +---RGB_ETC1 type texture format +resource.TEXTURE_FORMAT_RGB_ETC1 = nil + +---RGB_PVRTC_2BPPV1 type texture format +resource.TEXTURE_FORMAT_RGB_PVRTC_2BPPV1 = nil + +---RGB_PVRTC_4BPPV1 type texture format +resource.TEXTURE_FORMAT_RGB_PVRTC_4BPPV1 = nil + +---RG_BC5 type texture format +resource.TEXTURE_FORMAT_RG_BC5 = nil + +---R_BC4 type texture format +resource.TEXTURE_FORMAT_R_BC4 = nil + +---2D texture type +resource.TEXTURE_TYPE_2D = nil + +---2D Array texture type +resource.TEXTURE_TYPE_2D_ARRAY = nil + +---Cube map texture type +resource.TEXTURE_TYPE_CUBE_MAP = nil + +---Constructor-like function with two purposes: +---Load the specified resource as part of loading the script +---Return a hash to the run-time version of the resource +--- This function can only be called within go.property function calls. +---@param path string|nil optional resource path string to the resource +---@return hash path a path hash to the binary version of the resource +function resource.atlas(path) end + +---Constructor-like function with two purposes: +---Load the specified resource as part of loading the script +---Return a hash to the run-time version of the resource +--- This function can only be called within go.property function calls. +---@param path string|nil optional resource path string to the resource +---@return hash path a path hash to the binary version of the resource +function resource.buffer(path) end + +---This function creates a new atlas resource that can be used in the same way as any atlas created during build time. +---The path used for creating the atlas must be unique, trying to create a resource at a path that is already +---registered will trigger an error. If the intention is to instead modify an existing atlas, use the resource.set_atlas +---function. Also note that the path to the new atlas resource must have a '.texturesetc' extension, +---meaning "/path/my_atlas" is not a valid path but "/path/my_atlas.texturesetc" is. +---When creating the atlas, at least one geometry and one animation is required, and an error will be +---raised if these requirements are not met. A reference to the resource will be held by the collection +---that created the resource and will automatically be released when that collection is destroyed. +---Note that releasing a resource essentially means decreasing the reference count of that resource, +---and not necessarily that it will be deleted. +---@param path string The path to the resource. +---@param table resource.atlas A table containing info about how to create the atlas. Supported entries: +--- +--- +--- +---texture +---string | hash the path to the texture resource, e.g "/main/my_texture.texturec" +--- +--- +--- +--- +---animations +---table a list of the animations in the atlas. Supports the following fields: +--- +--- +--- +--- +---id +---string the id of the animation, used in e.g sprite.play_animation +--- +--- +--- +--- +---width +---integer the width of the animation +--- +--- +--- +--- +---height +---integer the height of the animation +--- +--- +--- +--- +---frame_start +---integer index to the first geometry of the animation. Indices are lua based and must be in the range of 1 .. in atlas. +--- +--- +--- +--- +---frame_end +---integer index to the last geometry of the animation (non-inclusive). Indices are lua based and must be in the range of 1 .. in atlas. +--- +--- +--- +--- +---playback +---constant optional playback mode of the animation, the default value is go.PLAYBACK_ONCE_FORWARD +--- +--- +--- +--- +---fps +---integer optional fps of the animation, the default value is 30 +--- +--- +--- +--- +---flip_vertical +---boolean optional flip the animation vertically, the default value is false +--- +--- +--- +--- +---flip_horizontal +---boolean optional flip the animation horizontally, the default value is false +--- +--- +--- +--- +---geometries +---table A list of the geometries that should map to the texture data. Supports the following fields: +--- +--- +--- +--- +---id +---string The name of the geometry. Used when matching animations between multiple atlases +--- +--- +--- +--- +---vertices +---table a list of the vertices in texture space of the geometry in the form {px0, py0, px1, py1, ..., pxn, pyn} +--- +--- +--- +--- +---uvs +---table a list of the uv coordinates in texture space of the geometry in the form of {u0, v0, u1, v1, ..., un, vn} +--- +--- +--- +--- +---indices +---table a list of the indices of the geometry in the form {i0, i1, i2, ..., in}. Each tripe in the list represents a triangle. +--- +--- +--- +---@return hash path Returns the atlas resource path +function resource.create_atlas(path, table) end + +---This function creates a new buffer resource that can be used in the same way as any buffer created during build time. +---The function requires a valid buffer created from either buffer.create or another pre-existing buffer resource. +---By default, the new resource will take ownership of the buffer lua reference, meaning the buffer will not automatically be removed +---when the lua reference to the buffer is garbage collected. This behaviour can be overruled by specifying 'transfer_ownership = false' +---in the argument table. If the new buffer resource is created from a buffer object that is created by another resource, +---the buffer object will be copied and the new resource will effectively own a copy of the buffer instead. +---Note that the path to the new resource must have the '.bufferc' extension, "/path/my_buffer" is not a valid path but "/path/my_buffer.bufferc" is. +---The path must also be unique, attempting to create a buffer with the same name as an existing resource will raise an error. +---@param path string The path to the resource. +---@param table { buffer:buffer_data, transfer_ownership:boolean|nil }|nil A table containing info about how to create the buffer. Supported entries: +--- +--- +--- +---buffer +---buffer the buffer to bind to this resource +--- +--- +--- +--- +---transfer_ownership +---boolean optional flag to determine wether or not the resource should take over ownership of the buffer object (default true) +--- +--- +--- +---@return hash path Returns the buffer resource path +function resource.create_buffer(path, table) end + +---Creates a new texture resource that can be used in the same way as any texture created during build time. +---The path used for creating the texture must be unique, trying to create a resource at a path that is already +---registered will trigger an error. If the intention is to instead modify an existing texture, use the resource.set_texture +---function. Also note that the path to the new texture resource must have a '.texturec' extension, +---meaning "/path/my_texture" is not a valid path but "/path/my_texture.texturec" is. +---If the texture is created without a buffer, the pixel data will be blank. +---@param path string The path to the resource. +---@param table { type:number, width:number, height:number, format:number, max_mipmaps:number|nil, compression_type:number|nil} A table containing info about how to create the texture. Supported entries: +--- +---type +---number The texture type. Supported values: +--- +--- +---resource.TEXTURE_TYPE_2D +---resource.TEXTURE_TYPE_CUBE_MAP +--- +--- +---width +---number The width of the texture (in pixels). Must be larger than 0. +---height +---number The width of the texture (in pixels). Must be larger than 0. +---format +---number The texture format, note that some of these formats might not be supported by the running device. Supported values: +--- +--- +---resource.TEXTURE_FORMAT_LUMINANCE +---resource.TEXTURE_FORMAT_RGB +---resource.TEXTURE_FORMAT_RGBA +--- +---These constants might not be available on the device: +--- +---resource.TEXTURE_FORMAT_RGB_PVRTC_2BPPV1 +---resource.TEXTURE_FORMAT_RGB_PVRTC_4BPPV1 +---resource.TEXTURE_FORMAT_RGBA_PVRTC_2BPPV1 +---resource.TEXTURE_FORMAT_RGBA_PVRTC_4BPPV1 +---resource.TEXTURE_FORMAT_RGB_ETC1 +---resource.TEXTURE_FORMAT_RGBA_ETC2 +---resource.TEXTURE_FORMAT_RGBA_ASTC_4x4 +---resource.TEXTURE_FORMAT_RGB_BC1 +---resource.TEXTURE_FORMAT_RGBA_BC3 +---resource.TEXTURE_FORMAT_R_BC4 +---resource.TEXTURE_FORMAT_RG_BC5 +---resource.TEXTURE_FORMAT_RGBA_BC7 +---resource.TEXTURE_FORMAT_RGB16F +---resource.TEXTURE_FORMAT_RGB32F +---resource.TEXTURE_FORMAT_RGBA16F +---resource.TEXTURE_FORMAT_RGBA32F +---resource.TEXTURE_FORMAT_R16F +---resource.TEXTURE_FORMAT_RG16F +---resource.TEXTURE_FORMAT_R32F +---resource.TEXTURE_FORMAT_RG32F +--- +---You can test if the device supports these values by checking if a specific enum is nil or not: +---if resource.TEXTURE_FORMAT_RGBA16F ~= nil then +--- -- it is safe to use this format +---end +--- +--- +--- +---max_mipmaps +---number optional max number of mipmaps. Defaults to zero, i.e no mipmap support +---compression_type +---number optional specify the compression type for the data in the buffer object that holds the texture data. Will only be used when a compressed buffer has been passed into the function. +---Creating an empty texture with no buffer data is not supported as a core feature. Defaults to resource.COMPRESSION_TYPE_DEFAULT, i.e no compression. Supported values: +--- +--- +---COMPRESSION_TYPE_DEFAULT +---COMPRESSION_TYPE_BASIS_UASTC +--- +---@param buffer buffer_data optional buffer of precreated pixel data +---@return hash path The path to the resource. +function resource.create_texture(path, table, buffer) end + +---Creates a new texture resource that can be used in the same way as any texture created during build time. +---The path used for creating the texture must be unique, trying to create a resource at a path that is already +---registered will trigger an error. If the intention is to instead modify an existing texture, use the resource.set_texture +---function. Also note that the path to the new texture resource must have a '.texturec' extension, +---meaning "/path/my_texture" is not a valid path but "/path/my_texture.texturec" is. +---If the texture is created without a buffer, the pixel data will be blank. +---The difference between the async version and resource.create_texture is that the texture data will be uploaded +---in a graphics worker thread. The function will return a resource immediately that contains a 1x1 blank texture which can be used +---immediately after the function call. When the new texture has been uploaded, the initial blank texture will be deleted and replaced with the +---new texture. Be careful when using the initial texture handle handle as it will not be valid after the upload has finished. +---@param path string The path to the resource. +---@param table { type:number, width:number, height:number, format:number, max_mipmaps:number|nil, compression_type:number|nil} +---A table containing info about how to create the texture. Supported entries: +---type +---number The texture type. Supported values: +--- +--- +---resource.TEXTURE_TYPE_2D +---resource.TEXTURE_TYPE_CUBE_MAP +--- +--- +---width +---number The width of the texture (in pixels). Must be larger than 0. +---height +---number The width of the texture (in pixels). Must be larger than 0. +---format +---number The texture format, note that some of these formats might not be supported by the running device. Supported values: +--- +--- +---resource.TEXTURE_FORMAT_LUMINANCE +---resource.TEXTURE_FORMAT_RGB +---resource.TEXTURE_FORMAT_RGBA +--- +---These constants might not be available on the device: +--- +---resource.TEXTURE_FORMAT_RGB_PVRTC_2BPPV1 +---resource.TEXTURE_FORMAT_RGB_PVRTC_4BPPV1 +---resource.TEXTURE_FORMAT_RGBA_PVRTC_2BPPV1 +---resource.TEXTURE_FORMAT_RGBA_PVRTC_4BPPV1 +---resource.TEXTURE_FORMAT_RGB_ETC1 +---resource.TEXTURE_FORMAT_RGBA_ETC2 +---resource.TEXTURE_FORMAT_RGBA_ASTC_4x4 +---resource.TEXTURE_FORMAT_RGB_BC1 +---resource.TEXTURE_FORMAT_RGBA_BC3 +---resource.TEXTURE_FORMAT_R_BC4 +---resource.TEXTURE_FORMAT_RG_BC5 +---resource.TEXTURE_FORMAT_RGBA_BC7 +---resource.TEXTURE_FORMAT_RGB16F +---resource.TEXTURE_FORMAT_RGB32F +---resource.TEXTURE_FORMAT_RGBA16F +---resource.TEXTURE_FORMAT_RGBA32F +---resource.TEXTURE_FORMAT_R16F +---resource.TEXTURE_FORMAT_RG16F +---resource.TEXTURE_FORMAT_R32F +---resource.TEXTURE_FORMAT_RG32F +--- +---You can test if the device supports these values by checking if a specific enum is nil or not: +---if resource.TEXTURE_FORMAT_RGBA16F ~= nil then +--- -- it is safe to use this format +---end +--- +--- +--- +---max_mipmaps +---number optional max number of mipmaps. Defaults to zero, i.e no mipmap support +---compression_type +---number optional specify the compression type for the data in the buffer object that holds the texture data. Will only be used when a compressed buffer has been passed into the function. +---Creating an empty texture with no buffer data is not supported as a core feature. Defaults to resource.COMPRESSION_TYPE_DEFAULT, i.e no compression. Supported values: +--- +--- +---COMPRESSION_TYPE_DEFAULT +---COMPRESSION_TYPE_BASIS_UASTC +--- +---@param buffer buffer_data optional buffer of precreated pixel data +---@return hash path The path to the resource. +---@return resource_handle request_id The request id for the async request. +function resource.create_texture_async(path, table, buffer) end + +---Constructor-like function with two purposes: +---Load the specified resource as part of loading the script +---Return a hash to the run-time version of the resource +--- This function can only be called within go.property function calls. +---@param path string|nil optional resource path string to the resource +---@return hash path a path hash to the binary version of the resource +function resource.font(path) end + +---Returns the atlas data for an atlas +---@param path hash|string The path to the atlas resource +---@return resource.atlas data A table with the following entries: +--- +---texture +---geometries +---animations +--- +---See resource.set_atlas for a detailed description of each field +function resource.get_atlas(path) end + +---gets the buffer from a resource +---@param path hash|string The path to the resource +---@return buffer_data buffer The resource buffer +function resource.get_buffer(path) end + +---Gets render target info from a render target resource path or a render target handle +---@param path hash|string|resource_handle The path to the resource or a render target handle +---@return { handle:resource_handle, attachments:{ handle:resource_handle, width:number, height:number, depth:number, mipmaps:number, type:number, buffer_type:number }[] } table A table containing info about the render target: +--- +---handle +---handle the opaque handle to the texture resource +---'attachments' +---table a table of attachments, where each attachment contains the following entries: +---handle +---handle the opaque handle to the texture resource +---width +---integer width of the texture +---height +---integer height of the texture +---depth +---integer depth of the texture (i.e 1 for a 2D texture and 6 for a cube map) +---mipmaps +---integer number of mipmaps of the texture +---type +---number The texture type. Supported values: +--- +--- +---resource.TEXTURE_TYPE_2D +---resource.TEXTURE_TYPE_CUBE_MAP +---resource.TEXTURE_TYPE_2D_ARRAY +--- +--- +---buffer_type +---number The attachment buffer type. Supported values: +--- +--- +---resource.BUFFER_TYPE_COLOR0 +---resource.BUFFER_TYPE_COLOR1 +---resource.BUFFER_TYPE_COLOR2 +---resource.BUFFER_TYPE_COLOR3 +---resource.BUFFER_TYPE_DEPTH +---resource.BUFFER_TYPE_STENCIL +--- +function resource.get_render_target_info(path) end + +---Gets the text metrics from a font +---@param url hash the font to get the (unscaled) metrics from +---@param text string text to measure +---@param options { width:number|nil, leading:number|nil, tracking:number|nil, line_break:boolean|nil}|nil A table containing parameters for the text. Supported entries: +--- +---width +---integer The width of the text field. Not used if line_break is false. +---leading +---number The leading (default 1.0) +---tracking +---number The tracking (default 0.0) +---line_break +---boolean If the calculation should consider line breaks (default false) +--- +---@return { width:number, height:number, max_ascent:number, max_descent:number } metrics a table with the following fields: +--- +---width +---height +---max_ascent +---max_descent +--- +function resource.get_text_metrics(url, text, options) end + +---Gets texture info from a texture resource path or a texture handle +---@param path hash|string|resource_handle The path to the resource or a texture handle +---@return { handle:resource_handle, width:number, height:number, depth:number, mipmaps:number, type:number } table A table containing info about the texture: +--- +---handle +---handle the opaque handle to the texture resource +---width +---integer width of the texture +---height +---integer height of the texture +---depth +---integer depth of the texture (i.e 1 for a 2D texture and 6 for a cube map) +---mipmaps +---integer number of mipmaps of the texture +---type +---number The texture type. Supported values: +--- +--- +---resource.TEXTURE_TYPE_2D +---resource.TEXTURE_TYPE_CUBE_MAP +---resource.TEXTURE_TYPE_2D_ARRAY +--- +function resource.get_texture_info(path) end + +---Loads the resource data for a specific resource. +---@param path string The path to the resource +---@return buffer_data buffer Returns the buffer stored on disc +function resource.load(path) end + +---Constructor-like function with two purposes: +---Load the specified resource as part of loading the script +---Return a hash to the run-time version of the resource +--- This function can only be called within go.property function calls. +---@param path string|nil optional resource path string to the resource +---@return hash path a path hash to the binary version of the resource +function resource.material(path) end + +---Release a resource. +--- This is a potentially dangerous operation, releasing resources currently being used can cause unexpected behaviour. +---@param path hash|string The path to the resource. +function resource.release(path) end + +---Sets the resource data for a specific resource +---@param path string|hash The path to the resource +---@param buffer buffer_data The buffer of precreated data, suitable for the intended resource type +function resource.set(path, buffer) end + +---Sets the data for a specific atlas resource. Setting new atlas data is specified by passing in +---a texture path for the backing texture of the atlas, a list of geometries and a list of animations +---that map to the entries in the geometry list. The geometry entries are represented by three lists: +---vertices, uvs and indices that together represent triangles that are used in other parts of the +---engine to produce render objects from. +---Vertex and uv coordinates for the geometries are expected to be +---in pixel coordinates where 0,0 is the top left corner of the texture. +---There is no automatic padding or margin support when setting custom data, +---which could potentially cause filtering artifacts if used with a material sampler that has linear filtering. +---If that is an issue, you need to calculate padding and margins manually before passing in the geometry data to +---this function. +---@param path hash|string The path to the atlas resource +---@param table resource.atlas A table containing info about the atlas. Supported entries: +--- +--- +--- +---texture +---string | hash the path to the texture resource, e.g "/main/my_texture.texturec" +--- +--- +--- +--- +---animations +---table a list of the animations in the atlas. Supports the following fields: +--- +--- +--- +--- +---id +---string the id of the animation, used in e.g sprite.play_animation +--- +--- +--- +--- +---width +---integer the width of the animation +--- +--- +--- +--- +---height +---integer the height of the animation +--- +--- +--- +--- +---frame_start +---integer index to the first geometry of the animation. Indices are lua based and must be in the range of 1 .. in atlas. +--- +--- +--- +--- +---frame_end +---integer index to the last geometry of the animation (non-inclusive). Indices are lua based and must be in the range of 1 .. in atlas. +--- +--- +--- +--- +---playback +---constant optional playback mode of the animation, the default value is go.PLAYBACK_ONCE_FORWARD +--- +--- +--- +--- +---fps +---integer optional fps of the animation, the default value is 30 +--- +--- +--- +--- +---flip_vertical +---boolean optional flip the animation vertically, the default value is false +--- +--- +--- +--- +---flip_horizontal +---boolean optional flip the animation horizontally, the default value is false +--- +--- +--- +--- +---geometries +---table A list of the geometries that should map to the texture data. Supports the following fields: +--- +--- +--- +--- +---vertices +---table a list of the vertices in texture space of the geometry in the form {px0, py0, px1, py1, ..., pxn, pyn} +--- +--- +--- +--- +---uvs +---table a list of the uv coordinates in texture space of the geometry in the form of {u0, v0, u1, v1, ..., un, vn} +--- +--- +--- +--- +---indices +---table a list of the indices of the geometry in the form {i0, i1, i2, ..., in}. Each tripe in the list represents a triangle. +--- +--- +--- +function resource.set_atlas(path, table) end + +---Sets the buffer of a resource. By default, setting the resource buffer will either copy the data from the incoming buffer object +---to the buffer stored in the destination resource, or make a new buffer object if the sizes between the source buffer and the destination buffer +---stored in the resource differs. In some cases, e.g performance reasons, it might be beneficial to just set the buffer object on the resource without copying or cloning. +---To achieve this, set the transfer_ownership flag to true in the argument table. Transferring ownership from a lua buffer to a resource with this function +---works exactly the same as resource.create_buffer: the destination resource will take ownership of the buffer held by the lua reference, i.e the buffer will not automatically be removed +---when the lua reference to the buffer is garbage collected. +---Note: When setting a buffer with transfer_ownership = true, the currently bound buffer in the resource will be destroyed. +---@param path hash|string The path to the resource +---@param buffer buffer_data The resource buffer +---@param table { transfer_ownership: boolean|nil }|nil A table containing info about how to set the buffer. Supported entries: +--- +--- +--- +---transfer_ownership +---boolean optional flag to determine wether or not the resource should take over ownership of the buffer object (default false) +--- +--- +--- +function resource.set_buffer(path, buffer, table) end + +---Update internal sound resource (wavc/oggc) with new data +---@param path hash|string The path to the resource +---@param buffer string A lua string containing the binary sound data +function resource.set_sound(path, buffer) end + +---Sets the pixel data for a specific texture. +---@param path hash|string The path to the resource +---@param table { type:number, width:number, height:number, format:number, x:number|nil, y:number|nil, mipmap:number|nil, compression_type:number|nil} A table containing info about the texture. Supported entries: +--- +---type +---number The texture type. Supported values: +--- +--- +---resource.TEXTURE_TYPE_2D +---resource.TEXTURE_TYPE_CUBE_MAP +--- +--- +---width +---number The width of the texture (in pixels) +---height +---number The width of the texture (in pixels) +---format +---number The texture format, note that some of these formats are platform specific. Supported values: +--- +--- +---resource.TEXTURE_FORMAT_LUMINANCE +---resource.TEXTURE_FORMAT_RGB +---resource.TEXTURE_FORMAT_RGBA +--- +---These constants might not be available on the device: +---- resource.TEXTURE_FORMAT_RGB_PVRTC_2BPPV1 +---- resource.TEXTURE_FORMAT_RGB_PVRTC_4BPPV1 +---- resource.TEXTURE_FORMAT_RGBA_PVRTC_2BPPV1 +---- resource.TEXTURE_FORMAT_RGBA_PVRTC_4BPPV1 +---- resource.TEXTURE_FORMAT_RGB_ETC1 +---- resource.TEXTURE_FORMAT_RGBA_ETC2 +---- resource.TEXTURE_FORMAT_RGBA_ASTC_4x4 +---- resource.TEXTURE_FORMAT_RGB_BC1 +---- resource.TEXTURE_FORMAT_RGBA_BC3 +---- resource.TEXTURE_FORMAT_R_BC4 +---- resource.TEXTURE_FORMAT_RG_BC5 +---- resource.TEXTURE_FORMAT_RGBA_BC7 +---- resource.TEXTURE_FORMAT_RGB16F +---- resource.TEXTURE_FORMAT_RGB32F +---- resource.TEXTURE_FORMAT_RGBA16F +---- resource.TEXTURE_FORMAT_RGBA32F +---- resource.TEXTURE_FORMAT_R16F +---- resource.TEXTURE_FORMAT_RG16F +---- resource.TEXTURE_FORMAT_R32F +---- resource.TEXTURE_FORMAT_RG32F +---You can test if the device supports these values by checking if a specific enum is nil or not: +---if resource.TEXTURE_FORMAT_RGBA16F ~= nil then +--- -- it is safe to use this format +---end +--- +--- +--- +---x +---number optional x offset of the texture (in pixels) +---y +---number optional y offset of the texture (in pixels) +---mipmap +---number optional mipmap to upload the data to +---compression_type +---number optional specify the compression type for the data in the buffer object that holds the texture data. Defaults to resource.COMPRESSION_TYPE_DEFAULT, i.e no compression. Supported values: +--- +--- +---COMPRESSION_TYPE_DEFAULT +---COMPRESSION_TYPE_BASIS_UASTC +--- +---@param buffer buffer_data The buffer of precreated pixel data +--- To update a cube map texture you need to pass in six times the amount of data via the buffer, since a cube map has six sides! +function resource.set_texture(path, table, buffer) end + +---Constructor-like function with two purposes: +---Load the specified resource as part of loading the script +---Return a hash to the run-time version of the resource +--- This function can only be called within go.property function calls. +---@param path string|nil optional resource path string to the resource +---@return hash path a path hash to the binary version of the resource +function resource.texture(path) end + +---Constructor-like function with two purposes: +---Load the specified resource as part of loading the script +---Return a hash to the run-time version of the resource +--- This function can only be called within go.property function calls. +---@param path string|nil optional resource path string to the resource +---@return hash path a path hash to the binary version of the resource +function resource.tile_source(path) end + +return resource \ No newline at end of file diff --git a/annotations/defold_annotations/socket.lua b/annotations/defold_annotations/socket.lua new file mode 100644 index 0000000..6eae421 --- /dev/null +++ b/annotations/defold_annotations/socket.lua @@ -0,0 +1,173 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + LuaSocket API documentation + + LuaSocket is a Lua extension library that provides + support for the TCP and UDP transport layers. Defold provides the "socket" namespace in + runtime, which contain the core C functionality. Additional LuaSocket support modules for + SMTP, HTTP, FTP etc are not part of the core included, but can be easily added to a project + and used. + Note the included helper module "socket.lua" in "builtins/scripts/socket.lua". Require this + module to add some additional functions and shortcuts to the namespace: + require "builtins.scripts.socket" + LuaSocket is Copyright © 2004-2007 Diego Nehab. All rights reserved. + LuaSocket is free software, released under the MIT license (same license as the Lua core). +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.socket +socket = {} + +---This constant contains the maximum number of sockets that the select function can handle. +socket._SETSIZE = nil + +---This constant has a string describing the current LuaSocket version. +socket._VERSION = nil + +---This function is a shortcut that creates and returns a TCP client object connected to a remote +---address at a given port. Optionally, the user can also specify the local address and port to +---bind (locaddr and locport), or restrict the socket family to "inet" or "inet6". +---Without specifying family to connect, whether a tcp or tcp6 connection is created depends on +---your system configuration. +---@param address string the address to connect to. +---@param port number the port to connect to. +---@param locaddr string|nil optional local address to bind to. +---@param locport number|nil optional local port to bind to. +---@param family string|nil optional socket family to use, "inet" or "inet6". +---@return socket_client|nil tcp_client a new IPv6 TCP client object, or nil in case of error. +---@return string|nil error the error message, or nil if no error occurred. +function socket.connect(address, port, locaddr, locport, family) end + +---This function converts a host name to IPv4 or IPv6 address. +---The supplied address can be an IPv4 or IPv6 address or host name. +---The function returns a table with all information returned by the resolver: +---{ +--- [1] = { +--- family = family-name-1, +--- addr = address-1 +--- }, +--- ... +--- [n] = { +--- family = family-name-n, +--- addr = address-n +--- } +---} +---Here, family contains the string "inet" for IPv4 addresses, and "inet6" for IPv6 addresses. +---In case of error, the function returns nil followed by an error message. +---@param address string a hostname or an IPv4 or IPv6 address. +---@return table|nil resolved a table with all information returned by the resolver, or if an error occurs, nil. +---@return string|nil error the error message, or nil if no error occurred. +function socket.dns.getaddrinfo(address) end + +---Returns the standard host name for the machine as a string. +---@return string hostname the host name for the machine. +function socket.dns.gethostname() end + +---This function converts an address to host name. +---The supplied address can be an IPv4 or IPv6 address or host name. +---The function returns a table with all information returned by the resolver: +---{ +--- [1] = host-name-1, +--- ... +--- [n] = host-name-n, +---} +---@param address string a hostname or an IPv4 or IPv6 address. +---@return table|nil resolved a table with all information returned by the resolver, or if an error occurs, nil. +---@return string|nil error the error message, or nil if no error occurred. +function socket.dns.getnameinfo(address) end + +---This function converts from an IPv4 address to host name. +---The address can be an IPv4 address or a host name. +---@param address string an IPv4 address or host name. +---@return string|nil hostname the canonic host name of the given address, or nil in case of an error. +---@return table|string resolved a table with all information returned by the resolver, or if an error occurs, the error message string. +function socket.dns.tohostname(address) end + +---This function converts a host name to IPv4 address. +---The address can be an IP address or a host name. +---@param address string a hostname or an IP address. +---@return string|nil ip_address the first IP address found for the hostname, or nil in case of an error. +---@return table|string resolved a table with all information returned by the resolver, or if an error occurs, the error message string. +function socket.dns.toip(address) end + +---Returns the time in seconds, relative to the system epoch (Unix epoch time since January 1, 1970 (UTC) or Windows file time since January 1, 1601 (UTC)). +---You should use the values returned by this function for relative measurements only. +---@return number seconds the number of seconds elapsed. +function socket.gettime() end + +---This function creates and returns a clean try function that allows for cleanup before the exception is raised. +---The finalizer function will be called in protected mode (see protect). +---@param finalizer function a function that will be called before the try throws the exception. +---@return function try the customized try function. +function socket.newtry(finalizer) end + +---Converts a function that throws exceptions into a safe function. This function only catches exceptions thrown by try functions. It does not catch normal Lua errors. +--- Beware that if your function performs some illegal operation that raises an error, the protected function will catch the error and return it as a string. This is because try functions uses errors as the mechanism to throw exceptions. +---@param func function a function that calls a try function (or assert, or error) to throw exceptions. +---@return fun(function) safe_func an equivalent function that instead of throwing exceptions, returns nil followed by an error message. +function socket.protect(func) end + +---The function returns a list with the sockets ready for reading, a list with the sockets ready for writing and an error message. The error message is "timeout" if a timeout condition was met and nil otherwise. The returned tables are doubly keyed both by integers and also by the sockets themselves, to simplify the test if a specific socket has changed status. +---Recvt and sendt parameters can be empty tables or nil. Non-socket values (or values with non-numeric indices) in these arrays will be silently ignored. +---The returned tables are doubly keyed both by integers and also by the sockets themselves, to simplify the test if a specific socket has changed status. +--- This function can monitor a limited number of sockets, as defined by the constant socket._SETSIZE. This number may be as high as 1024 or as low as 64 by default, depending on the system. It is usually possible to change this at compile time. Invoking select with a larger number of sockets will raise an error. +--- A known bug in WinSock causes select to fail on non-blocking TCP sockets. The function may return a socket as writable even though the socket is not ready for sending. +--- Calling select with a server socket in the receive parameter before a call to accept does not guarantee accept will return immediately. Use the settimeout method or accept might block forever. +--- If you close a socket and pass it to select, it will be ignored. +---(Using select with non-socket objects: Any object that implements getfd and dirty can be used with select, allowing objects from other libraries to be used within a socket.select driven loop.) +---@param recvt table array with the sockets to test for characters available for reading. +---@param sendt table array with sockets that are watched to see if it is OK to immediately write on them. +---@param timeout number|nil the maximum amount of time (in seconds) to wait for a change in status. Nil, negative or omitted timeout value allows the function to block indefinitely. +---@return table sockets_r a list with the sockets ready for reading. +---@return table sockets_w a list with the sockets ready for writing. +---@return string|nil error an error message. "timeout" if a timeout condition was met, otherwise nil. +function socket.select(recvt, sendt, timeout) end + +---This function drops a number of arguments and returns the remaining. +---It is useful to avoid creation of dummy variables: +---D is the number of arguments to drop. Ret1 to retN are the arguments. +---The function returns retD+1 to retN. +---@param d number the number of arguments to drop. +---@param ret1 any|nil argument 1. +---@param ret2 any|nil argument 2. +---@param retN any|nil argument N. +---@return any|nil retD+1 argument D+1. +---@return any|nil retD+2 argument D+2. +---@return any|nil retN argument N. +function socket.skip(d, ret1, ret2, retN) end + +---Freezes the program execution during a given amount of time. +---@param time number the number of seconds to sleep for. +function socket.sleep(time) end + +---Creates and returns an IPv4 TCP master object. A master object can be transformed into a server object with the method listen (after a call to bind) or into a client object with the method connect. The only other method supported by a master object is the close method. +---@return socket_master|nil tcp_master a new IPv4 TCP master object, or nil in case of error. +---@return string|nil error the error message, or nil if no error occurred. +function socket.tcp() end + +---Creates and returns an IPv6 TCP master object. A master object can be transformed into a server object with the method listen (after a call to bind) or into a client object with the method connect. The only other method supported by a master object is the close method. +---Note: The TCP object returned will have the option "ipv6-v6only" set to true. +---@return socket_master|nil tcp_master a new IPv6 TCP master object, or nil in case of error. +---@return string|nil error the error message, or nil if no error occurred. +function socket.tcp6() end + +---Creates and returns an unconnected IPv4 UDP object. Unconnected objects support the sendto, receive, receivefrom, getoption, getsockname, setoption, settimeout, setpeername, setsockname, and close methods. The setpeername method is used to connect the object. +---@return socket_unconnected|nil udp_unconnected a new unconnected IPv4 UDP object, or nil in case of error. +---@return string|nil error the error message, or nil if no error occurred. +function socket.udp() end + +---Creates and returns an unconnected IPv6 UDP object. Unconnected objects support the sendto, receive, receivefrom, getoption, getsockname, setoption, settimeout, setpeername, setsockname, and close methods. The setpeername method is used to connect the object. +---Note: The UDP object returned will have the option "ipv6-v6only" set to true. +---@return socket_unconnected|nil udp_unconnected a new unconnected IPv6 UDP object, or nil in case of error. +---@return string|nil error the error message, or nil if no error occurred. +function socket.udp6() end + + + +return socket \ No newline at end of file diff --git a/annotations/defold_annotations/sound.lua b/annotations/defold_annotations/sound.lua new file mode 100644 index 0000000..d25c055 --- /dev/null +++ b/annotations/defold_annotations/sound.lua @@ -0,0 +1,160 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Sound API documentation +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.sound +sound = {} + +---Get mixer group gain +--- Note that gain is in linear scale, between 0 and 1. +---To get the dB value from the gain, use the formula 20 * log(gain). +---Inversely, to find the linear value from a dB value, use the formula +---10db/20. +---@param group string|hash group name +---@return number gain gain in linear scale +function sound.get_group_gain(group) end + +---Get a mixer group name as a string. +--- This function is to be used for debugging and +---development tooling only. The function does a reverse hash lookup, which does not +---return a proper string value when the game is built in release mode. +---@param group string|hash group name +---@return string name group name +function sound.get_group_name(group) end + +---Get a table of all mixer group names (hashes). +---@return hash[] groups table of mixer group names +function sound.get_groups() end + +---Get peak value from mixer group. +--- Note that gain is in linear scale, between 0 and 1. +---To get the dB value from the gain, use the formula 20 * log(gain). +---Inversely, to find the linear value from a dB value, use the formula +---10db/20. +---Also note that the returned value might be an approximation and in particular +---the effective window might be larger than specified. +---@param group string|hash group name +---@param window number window length in seconds +---@return number peak_l peak value for left channel +---@return number peak_r peak value for right channel +function sound.get_peak(group, window) end + +---Get RMS (Root Mean Square) value from mixer group. This value is the +---square root of the mean (average) value of the squared function of +---the instantaneous values. +---For instance: for a sinewave signal with a peak gain of -1.94 dB (0.8 linear), +---the RMS is 0.8 × 1/sqrt(2) which is about 0.566. +--- Note the returned value might be an approximation and in particular +---the effective window might be larger than specified. +---@param group string|hash group name +---@param window number window length in seconds +---@return number rms_l RMS value for left channel +---@return number rms_r RMS value for right channel +function sound.get_rms(group, window) end + +---Checks if background music is playing, e.g. from iTunes. +--- On non mobile platforms, +---this function always return false. +--- On Android you can only get a correct reading +---of this state if your game is not playing any sounds itself. This is a limitation +---in the Android SDK. If your game is playing any sounds, even with a gain of zero, this +---function will return false. +---The best time to call this function is: +---In the init function of your main collection script before any sounds are triggered +---In a window listener callback when the window.WINDOW_EVENT_FOCUS_GAINED event is received +---Both those times will give you a correct reading of the state even when your application is +---swapped out and in while playing sounds and it works equally well on Android and iOS. +---@return boolean playing true if music is playing, otherwise false. +function sound.is_music_playing() end + +---Checks if a phone call is active. If there is an active phone call all +---other sounds will be muted until the phone call is finished. +--- On non mobile platforms, +---this function always return false. +---@return boolean call_active true if there is an active phone call, false otherwise. +function sound.is_phone_call_active() end + +---Pause all active voices +---@param url string|hash|url the sound that should pause +---@param pause bool true if the sound should pause +function sound.pause(url, pause) end + +---Make the sound component play its sound. Multiple voices are supported. The limit is set to 32 voices per sound component. +--- Note that gain is in linear scale, between 0 and 1. +---To get the dB value from the gain, use the formula 20 * log(gain). +---Inversely, to find the linear value from a dB value, use the formula +---10db/20. +--- A sound will continue to play even if the game object the sound component belonged to is deleted. You can call sound.stop() to stop the sound. +---@param url string|hash|url the sound that should play +---@param play_properties { delay:number|nil, gain:number|nil, pan:number|nil, speed:number|nil }|nil +---optional table with properties: +---delay +---number delay in seconds before the sound starts playing, default is 0. +---gain +---number sound gain between 0 and 1, default is 1. The final gain of the sound will be a combination of this gain, the group gain and the master gain. +---pan +---number sound pan between -1 and 1, default is 0. The final pan of the sound will be an addition of this pan and the sound pan. +---speed +---number sound speed where 1.0 is normal speed, 0.5 is half speed and 2.0 is double speed. The final speed of the sound will be a multiplication of this speed and the sound speed. +--- +---@param complete_function fun(self, message_id, message, sender)|nil function to call when the sound has finished playing or stopped manually via sound.stop. +--- +---self +---object The current object. +---message_id +---hash The name of the completion message, which can be either "sound_done" if the sound has finished playing, or "sound_stopped" if it was stopped manually. +---message +---table Information about the completion: +--- +--- +---number play_id - the sequential play identifier that was given by the sound.play function. +--- +--- +---sender +---url The invoker of the callback: the sound component. +--- +---@return number play_id The identifier for the sound voice +function sound.play(url, play_properties, complete_function) end + +---Set gain on all active playing voices of a sound. +--- Note that gain is in linear scale, between 0 and 1. +---To get the dB value from the gain, use the formula 20 * log(gain). +---Inversely, to find the linear value from a dB value, use the formula +---10db/20. +---@param url string|hash|url the sound to set the gain of +---@param gain number|nil sound gain between 0 and 1. The final gain of the sound will be a combination of this gain, the group gain and the master gain. +function sound.set_gain(url, gain) end + +---Set mixer group gain +--- Note that gain is in linear scale, between 0 and 1. +---To get the dB value from the gain, use the formula 20 * log(gain). +---Inversely, to find the linear value from a dB value, use the formula +---10db/20. +---@param group string|hash group name +---@param gain number gain in linear scale +function sound.set_group_gain(group, gain) end + +---Set panning on all active playing voices of a sound. +---The valid range is from -1.0 to 1.0, representing -45 degrees left, to +45 degrees right. +---@param url string|hash|url the sound to set the panning value to +---@param pan number|nil sound panning between -1.0 and 1.0 +function sound.set_pan(url, pan) end + +---Stop playing all active voices or just one voice if play_id provided +---@param url string|hash|url the sound component that should stop +---@param stop_properties { play_id:number }|nil +---optional table with properties: +---play_id +---number the sequential play identifier that should be stopped (was given by the sound.play() function) +--- +function sound.stop(url, stop_properties) end + +return sound \ No newline at end of file diff --git a/annotations/defold_annotations/sprite.lua b/annotations/defold_annotations/sprite.lua new file mode 100644 index 0000000..f7b5aa0 --- /dev/null +++ b/annotations/defold_annotations/sprite.lua @@ -0,0 +1,62 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Sprite API documentation +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.sprite +sprite = {} + +---Play an animation on a sprite component from its tile set +---An optional completion callback function can be provided that will be called when +---the animation has completed playing. If no function is provided, +---a animation_done message is sent to the script that started the animation. +---@param url string|hash|url the sprite that should play the animation +---@param id string|hash hashed id of the animation to play +---@param complete_function fun(self, message_id, message, sender)|nil function to call when the animation has completed. +--- +---self +---object The current object. +---message_id +---hash The name of the completion message, "animation_done". +---message +---table Information about the completion: +--- +--- +---number current_tile - the current tile of the sprite. +---hash id - id of the animation that was completed. +--- +--- +---sender +---url The invoker of the callback: the sprite component. +--- +---@param play_properties table|nil optional table with properties: +--- +---offset +---number the normalized initial value of the animation cursor when the animation starts playing. +---playback_rate +---number the rate with which the animation will be played. Must be positive. +--- +function sprite.play_flipbook(url, id, complete_function, play_properties) end + +---Sets horizontal flipping of the provided sprite's animations. +---The sprite is identified by its URL. +---If the currently playing animation is flipped by default, flipping it again will make it appear like the original texture. +---@param url string|hash|url the sprite that should flip its animations +---@param flip boolean true if the sprite should flip its animations, false if not +function sprite.set_hflip(url, flip) end + +---Sets vertical flipping of the provided sprite's animations. +---The sprite is identified by its URL. +---If the currently playing animation is flipped by default, flipping it again will make it appear like the original texture. +---@param url string|hash|url the sprite that should flip its animations +---@param flip boolean true if the sprite should flip its animations, false if not +function sprite.set_vflip(url, flip) end + +return sprite \ No newline at end of file diff --git a/annotations/defold_annotations/sys.lua b/annotations/defold_annotations/sys.lua new file mode 100644 index 0000000..313cf4e --- /dev/null +++ b/annotations/defold_annotations/sys.lua @@ -0,0 +1,314 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + System API documentation + + Functions and messages for using system resources, controlling the engine, + error handling and debugging. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.sys +sys = {} + +---network connected through other, non cellular, connection +sys.NETWORK_CONNECTED = nil + +---network connected through mobile cellular +sys.NETWORK_CONNECTED_CELLULAR = nil + +---no network connection found +sys.NETWORK_DISCONNECTED = nil + +---an asyncronous request is unable to read the resource +sys.REQUEST_STATUS_ERROR_IO_ERROR = nil + +---an asyncronous request is unable to locate the resource +sys.REQUEST_STATUS_ERROR_NOT_FOUND = nil + +---an asyncronous request has finished successfully +sys.REQUEST_STATUS_FINISHED = nil + +---deserializes buffer into a lua table +---@param buffer string buffer to deserialize from +---@return table table lua table with deserialized data +function sys.deserialize(buffer) end + +---Check if a path exists +---Good for checking if a file exists before loading a large file +---@param path string path to check +---@return bool result true if the path exists, false otherwise +function sys.exists(path) end + +---Terminates the game application and reports the specified code to the OS. +---@param code number exit code to report to the OS, 0 means clean exit +function sys.exit(code) end + +---Returns a table with application information for the requested app. +--- On iOS, the app_string is an url scheme for the app that is queried. Your +---game needs to list the schemes that are queried in an LSApplicationQueriesSchemes array +---in a custom "Info.plist". +--- On Android, the app_string is the package identifier for the app. +---@param app_string string platform specific string with application package or query, see above for details. +---@return { installed:boolean } app_info table with application information in the following fields: +--- +---installed +---boolean true if the application is installed, false otherwise. +--- +function sys.get_application_info(app_string) end + +---The path from which the application is run. +---@return string path path to application executable +function sys.get_application_path() end + +---Get integer config value from the game.project configuration file with optional default value +---@param key string key to get value for. The syntax is SECTION.KEY +---@param default_value integer|nil (optional) default value to return if the value does not exist +---@return integer value config value as an integer. default_value if the config key does not exist. 0 if no default value was supplied. +function sys.get_config_int(key, default_value) end + +---Get number config value from the game.project configuration file with optional default value +---@param key string key to get value for. The syntax is SECTION.KEY +---@param default_value number|nil (optional) default value to return if the value does not exist +---@return number value config value as an number. default_value if the config key does not exist. 0 if no default value was supplied. +function sys.get_config_number(key, default_value) end + +---Get string config value from the game.project configuration file with optional default value +---@param key string key to get value for. The syntax is SECTION.KEY +---@param default_value string|nil (optional) default value to return if the value does not exist +---@return string value config value as a string. default_value if the config key does not exist. nil if no default value was supplied. +function sys.get_config_string(key, default_value) end + +--- Returns the current network connectivity status +---on mobile platforms. +---On desktop, this function always return sys.NETWORK_CONNECTED. +---@return constant status network connectivity status: +--- +---sys.NETWORK_DISCONNECTED (no network connection is found) +---sys.NETWORK_CONNECTED_CELLULAR (connected through mobile cellular) +---sys.NETWORK_CONNECTED (otherwise, Wifi) +--- +function sys.get_connectivity() end + +---Returns a table with engine information. +---@return { version:string, version_sha1:string, is_debug:boolean } engine_info table with engine information in the following fields: +--- +---version +---string The current Defold engine version, i.e. "1.2.96" +---version_sha1 +---string The SHA1 for the current engine build, i.e. "0060183cce2e29dbd09c85ece83cbb72068ee050" +---is_debug +---boolean If the engine is a debug or release version +--- +function sys.get_engine_info() end + +---Create a path to the host device for unit testing +---Useful for saving logs etc during development +---@param filename string file to read from +---@return string host_path the path prefixed with the proper host mount +function sys.get_host_path(filename) end + +---Returns an array of tables with information on network interfaces. +---@return { name:string, address:string|nil, mac:string|nil, up:boolean, running:boolean } ifaddrs an array of tables. Each table entry contain the following fields: +--- +---name +---string Interface name +---address +---string IP address. might be nil if not available. +---mac +---string Hardware MAC address. might be nil if not available. +---up +---boolean true if the interface is up (available to transmit and receive data), false otherwise. +---running +---boolean true if the interface is running, false otherwise. +--- +function sys.get_ifaddrs() end + +---The save-file path is operating system specific and is typically located under the user's home directory. +---@param application_id string user defined id of the application, which helps define the location of the save-file +---@param file_name string file-name to get path for +---@return string path path to save-file +function sys.get_save_file(application_id, file_name) end + +---Returns a table with system information. +---@param options { ignore_secure:boolean|nil }|nil optional options table +---- ignore_secure boolean this flag ignores values might be secured by OS e.g. device_ident +---@return { device_model:string|nil, manufacturer:string|nil, system_name:string, system_version:string, api_version:string, language:string, device_language:string, territory:string, gmt_offset:number, device_ident:string|nil, user_agent:string|nil } sys_info table with system information in the following fields: +--- +---device_model +---string Only available on iOS and Android. +---manufacturer +---string Only available on iOS and Android. +---system_name +---string The system name: "Darwin", "Linux", "Windows", "HTML5", "Android" or "iPhone OS" +---system_version +---string The system OS version. +---api_version +---string The API version on the system. +---language +---string Two character ISO-639 format, i.e. "en". +---device_language +---string Two character ISO-639 format (i.e. "sr") and, if applicable, followed by a dash (-) and an ISO 15924 script code (i.e. "sr-Cyrl" or "sr-Latn"). Reflects the device preferred language. +---territory +---string Two character ISO-3166 format, i.e. "US". +---gmt_offset +---number The current offset from GMT (Greenwich Mean Time), in minutes. +---device_ident +---string This value secured by OS. "identifierForVendor" on iOS. "android_id" on Android. On Android, you need to add READ_PHONE_STATE permission to be able to get this data. We don't use this permission in Defold. +---user_agent +---string The HTTP user agent, i.e. "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_3) AppleWebKit/602.4.8 (KHTML, like Gecko) Version/10.0.3 Safari/602.4.8" +--- +function sys.get_sys_info(options) end + +---If the file exists, it must have been created by sys.save to be loaded. +---@param filename string file to read from +---@return table loaded lua table, which is empty if the file could not be found +function sys.load(filename) end + +---The sys.load_buffer function will first try to load the resource +---from any of the mounted resource locations and return the data if +---any matching entries found. If not, the path will be tried +---as is from the primary disk on the device. +---In order for the engine to include custom resources in the build process, you need +---to specify them in the "custom_resources" key in your "game.project" settings file. +---You can specify single resource files or directories. If a directory is included +---in the resource list, all files and directories in that directory is recursively +---included: +---For example "main/data/,assets/level_data.json". +---@param path string the path to load the buffer from +---@return buffer_data buffer the buffer with data +function sys.load_buffer(path) end + +---The sys.load_buffer function will first try to load the resource +---from any of the mounted resource locations and return the data if +---any matching entries found. If not, the path will be tried +---as is from the primary disk on the device. +---In order for the engine to include custom resources in the build process, you need +---to specify them in the "custom_resources" key in your "game.project" settings file. +---You can specify single resource files or directories. If a directory is included +---in the resource list, all files and directories in that directory is recursively +---included: +---For example "main/data/,assets/level_data.json". +---Note that issuing multiple requests of the same resource will yield +---individual buffers per request. There is no implic caching of the buffers +---based on request path. +---@param path string the path to load the buffer from +---@param status_callback fun(self, request_id, result) A status callback that will be invoked when a request has been handled, or an error occured. The result is a table containing: +--- +---status +---number The status of the request, supported values are: +--- +--- +---resource.REQUEST_STATUS_FINISHED +---resource.REQUEST_STATUS_ERROR_IO_ERROR +---resource.REQUEST_STATUS_ERROR_NOT_FOUND +--- +--- +---buffer +---buffer If the request was successfull, this will contain the request payload in a buffer object, and nil otherwise. Make sure to check the status before doing anything with the buffer value! +--- +---@return resource_handle handle a handle to the request +function sys.load_buffer_async(path, status_callback) end + +---Loads a custom resource. Specify the full filename of the resource that you want +---to load. When loaded, the file data is returned as a string. +---If loading fails, the function returns nil plus the error message. +---In order for the engine to include custom resources in the build process, you need +---to specify them in the "custom_resources" key in your "game.project" settings file. +---You can specify single resource files or directories. If a directory is included +---in the resource list, all files and directories in that directory is recursively +---included: +---For example "main/data/,assets/level_data.json". +---@param filename string resource to load, full path +---@return string|nil data loaded data, or nil if the resource could not be loaded +---@return string|nil error the error message, or nil if no error occurred +function sys.load_resource(filename) end + +---Open URL in default application, typically a browser +---@param url string url to open +---@param attributes { target:string|nil, name:string|nil }|nil table with attributes +---target +---- string : Optional. Specifies the target attribute or the name of the window. The following values are supported: +---- _self - (default value) URL replaces the current page. +---- _blank - URL is loaded into a new window, or tab. +---- _parent - URL is loaded into the parent frame. +---- _top - URL replaces any framesets that may be loaded. +---- name - The name of the window (Note: the name does not specify the title of the new window). +---@return boolean success a boolean indicating if the url could be opened or not +function sys.open_url(url, attributes) end + +---Reboots the game engine with a specified set of arguments. +---Arguments will be translated into command line arguments. Calling reboot +---function is equivalent to starting the engine with the same arguments. +---On startup the engine reads configuration from "game.project" in the +---project root. +---@param arg1 string|nil argument 1 +---@param arg2 string|nil argument 2 +---@param arg3 string|nil argument 3 +---@param arg4 string|nil argument 4 +---@param arg5 string|nil argument 5 +---@param arg6 string|nil argument 6 +function sys.reboot(arg1, arg2, arg3, arg4, arg5, arg6) end + +---The table can later be loaded by sys.load. +---Use sys.get_save_file to obtain a valid location for the file. +---Internally, this function uses a workspace buffer sized output file sized 512kb. +---This size reflects the output file size which must not exceed this limit. +---Additionally, the total number of rows that any one table may contain is limited to 65536 +---(i.e. a 16 bit range). When tables are used to represent arrays, the values of +---keys are permitted to fall within a 32 bit range, supporting sparse arrays, however +---the limit on the total number of rows remains in effect. +---@param filename string file to write to +---@param table table lua table to save +---@return boolean success a boolean indicating if the table could be saved or not +function sys.save(filename, table) end + +---The buffer can later deserialized by sys.deserialize. +---This method has all the same limitations as sys.save. +---@param table table lua table to serialize +---@return string buffer serialized data buffer +function sys.serialize(table) end + +---Sets the host that is used to check for network connectivity against. +---@param host string hostname to check against +function sys.set_connectivity_host(host) end + +---Set the Lua error handler function. +---The error handler is a function which is called whenever a lua runtime error occurs. +---@param error_handler fun(source, message, traceback) the function to be called on error +--- +---source +---string The runtime context of the error. Currently, this is always "lua". +---message +---string The source file, line number and error message. +---traceback +---string The stack traceback. +--- +function sys.set_error_handler(error_handler) end + +---Set game update-frequency (frame cap). This option is equivalent to display.update_frequency in +---the "game.project" settings but set in run-time. If Vsync checked in "game.project", the rate will +---be clamped to a swap interval that matches any detected main monitor refresh rate. If Vsync is +---unchecked the engine will try to respect the rate in software using timers. There is no +---guarantee that the frame cap will be achieved depending on platform specifics and hardware settings. +---@param frequency number target frequency. 60 for 60 fps +function sys.set_update_frequency(frequency) end + +---Set the vsync swap interval. The interval with which to swap the front and back buffers +---in sync with vertical blanks (v-blank), the hardware event where the screen image is updated +---with data from the front buffer. A value of 1 swaps the buffers at every v-blank, a value of +---2 swaps the buffers every other v-blank and so on. A value of 0 disables waiting for v-blank +---before swapping the buffers. Default value is 1. +---When setting the swap interval to 0 and having vsync disabled in +---"game.project", the engine will try to respect the set frame cap value from +---"game.project" in software instead. +---This setting may be overridden by driver settings. +---@param swap_interval number target swap interval. +function sys.set_vsync_swap_interval(swap_interval) end + +return sys \ No newline at end of file diff --git a/annotations/defold_annotations/tilemap.lua b/annotations/defold_annotations/tilemap.lua new file mode 100644 index 0000000..cff05cd --- /dev/null +++ b/annotations/defold_annotations/tilemap.lua @@ -0,0 +1,90 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Tilemap API documentation + + Functions and messages used to manipulate tile map components. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.tilemap +tilemap = {} + +---flip tile horizontally +tilemap.H_FLIP = nil + +---rotate tile 180 degrees clockwise +tilemap.ROTATE_180 = nil + +---rotate tile 270 degrees clockwise +tilemap.ROTATE_270 = nil + +---rotate tile 90 degrees clockwise +tilemap.ROTATE_90 = nil + +---flip tile vertically +tilemap.V_FLIP = nil + +---Get the bounds for a tile map. This function returns multiple values: +---The lower left corner index x and y coordinates (1-indexed), +---the tile map width and the tile map height. +---The resulting values take all tile map layers into account, meaning that +---the bounds are calculated as if all layers were collapsed into one. +---@param url string|hash|url the tile map +---@return number x x coordinate of the bottom left corner +---@return number y y coordinate of the bottom left corner +---@return number w number of columns (width) in the tile map +---@return number h number of rows (height) in the tile map +function tilemap.get_bounds(url) end + +---Get the tile set at the specified position in the tilemap. +---The position is identified by the tile index starting at origin +---with index 1, 1. (see tilemap.set_tile()) +---Which tile map and layer to query is identified by the URL and the +---layer name parameters. +---@param url string|hash|url the tile map +---@param layer string|hash name of the layer for the tile +---@param x number x-coordinate of the tile +---@param y number y-coordinate of the tile +---@return number tile index of the tile +function tilemap.get_tile(url, layer, x, y) end + +---Replace a tile in a tile map with a new tile. +---The coordinates of the tiles are indexed so that the "first" tile just +---above and to the right of origin has coordinates 1,1. +---Tiles to the left of and below origin are indexed 0, -1, -2 and so forth. +---+-------+-------+------+------+ +---| 0,3 | 1,3 | 2,3 | 3,3 | +---+-------+-------+------+------+ +---| 0,2 | 1,2 | 2,2 | 3,2 | +---+-------+-------+------+------+ +---| 0,1 | 1,1 | 2,1 | 3,1 | +---+-------O-------+------+------+ +---| 0,0 | 1,0 | 2,0 | 3,0 | +---+-------+-------+------+------+ +---The coordinates must be within the bounds of the tile map as it were created. +---That is, it is not possible to extend the size of a tile map by setting tiles outside the edges. +---To clear a tile, set the tile to number 0. Which tile map and layer to manipulate is identified by the URL and the layer name parameters. +---Transform bitmask is arithmetic sum of one or both FLIP constants (tilemap.H_FLIP, tilemap.V_FLIP) and/or one of ROTATION constants +---(tilemap.ROTATE_90, tilemap.ROTATE_180, tilemap.ROTATE_270). +---Flip always applies before rotation (clockwise). +---@param url string|hash|url the tile map +---@param layer string|hash name of the layer for the tile +---@param x number x-coordinate of the tile +---@param y number y-coordinate of the tile +---@param tile number index of new tile to set. 0 resets the cell +---@param transform_bitmask number|nil optional flip and/or rotation should be applied to the tile +function tilemap.set_tile(url, layer, x, y, tile, transform_bitmask) end + +---Sets the visibility of the tilemap layer +---@param url string|hash|url the tile map +---@param layer string|hash name of the layer for the tile +---@param visible boolean should the layer be visible +function tilemap.set_visible(url, layer, visible) end + +return tilemap \ No newline at end of file diff --git a/annotations/defold_annotations/timer.lua b/annotations/defold_annotations/timer.lua new file mode 100644 index 0000000..d752ffe --- /dev/null +++ b/annotations/defold_annotations/timer.lua @@ -0,0 +1,68 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Timer API documentation + + Timers allow you to set a delay and a callback to be called when the timer completes. + The timers created with this API are updated with the collection timer where they + are created. If you pause or speed up the collection (using set_time_step) it will + also affect the new timer. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.timer +timer = {} + +---Indicates an invalid timer handle +timer.INVALID_TIMER_HANDLE = nil + +---You may cancel a timer from inside a timer callback. +---Cancelling a timer that is already executed or cancelled is safe. +---@param handle hash the timer handle returned by timer.delay() +---@return boolean true if the timer was active, false if the timer is already cancelled / complete +function timer.cancel(handle) end + +---Adds a timer and returns a unique handle. +---You may create more timers from inside a timer callback. +---Using a delay of 0 will result in a timer that triggers at the next frame just before +---script update functions. +---If you want a timer that triggers on each frame, set delay to 0.0f and repeat to true. +---Timers created within a script will automatically die when the script is deleted. +---@param delay number time interval in seconds +---@param repeating boolean true = repeat timer until cancel, false = one-shot timer +---@param callback fun(self, handle, time_elapsed) timer callback function +--- +---self +---object The current object +---handle +---number The handle of the timer +---time_elapsed +---number The elapsed time - on first trigger it is time since timer.delay call, otherwise time since last trigger +--- +---@return hash handle identifier for the create timer, returns timer.INVALID_TIMER_HANDLE if the timer can not be created +function timer.delay(delay, repeating, callback) end + +---Get information about timer. +---@param handle hash the timer handle returned by timer.delay() +---@return { time_remaining:number, delay:number, repeating:boolean }|nil data table or nil if timer is cancelled/completed. table with data in the following fields: +--- +---time_remaining +---number Time remaining until the next time a timer.delay() fires. +---delay +---number Time interval. +---repeating +---boolean true = repeat timer until cancel, false = one-shot timer. +--- +function timer.get_info(handle) end + +---Manual triggering a callback for a timer. +---@param handle hash the timer handle returned by timer.delay() +---@return boolean true if the timer was active, false if the timer is already cancelled / complete +function timer.trigger(handle) end + +return timer \ No newline at end of file diff --git a/annotations/defold_annotations/types.lua b/annotations/defold_annotations/types.lua new file mode 100644 index 0000000..f3a8f27 --- /dev/null +++ b/annotations/defold_annotations/types.lua @@ -0,0 +1,140 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Known classes and aliases used in the Defold API +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class matrix4 +---@field c0 vector4 +---@field c1 vector4 +---@field c2 vector4 +---@field c3 vector4 +---@field m00 number +---@field m01 number +---@field m02 number +---@field m03 number +---@field m10 number +---@field m11 number +---@field m12 number +---@field m13 number +---@field m20 number +---@field m21 number +---@field m22 number +---@field m23 number +---@field m30 number +---@field m31 number +---@field m32 number +---@field m33 number + +---@class on_input.action +---@field dx number|nil The change in x value of a pointer device, if present. +---@field dy number|nil The change in y value of a pointer device, if present. +---@field gamepad integer|nil The change in screen space y value of a pointer device, if present. +---@field pressed boolean|nil If the input was pressed this frame. This is not present for mouse movement. +---@field released boolean|nil If the input was released this frame. This is not present for mouse movement. +---@field repeated boolean|nil If the input was repeated this frame. This is similar to how a key on a keyboard is repeated when you hold it down. This is not present for mouse movement. +---@field screen_dx number|nil The change in screen space x value of a pointer device, if present. +---@field screen_dy number|nil The index of the gamepad device that provided the input. +---@field screen_x number|nil The screen space x value of a pointer device, if present. +---@field screen_y number|nil The screen space y value of a pointer device, if present. +---@field touch [on_input.touch]|nil List of touch input, one element per finger, if present. +---@field value number|nil The amount of input given by the user. This is usually 1 for buttons and 0-1 for analogue inputs. This is not present for mouse movement. +---@field x number|nil The x value of a pointer device, if present. +---@field y number|nil The y value of a pointer device, if present. + +---@class on_input.touch +---@field acc_x number|nil Accelerometer x value (if present). +---@field acc_y number|nil Accelerometer y value (if present). +---@field acc_z number|nil Accelerometer z value (if present). +---@field dx number The change in x value. +---@field dy number The change in y value. +---@field id number A number identifying the touch input during its duration. +---@field pressed boolean True if the finger was pressed this frame. +---@field released boolean True if the finger was released this frame. +---@field tap_count integer Number of taps, one for single, two for double-tap, etc +---@field x number The x touch location. +---@field y number The y touch location. + +---@class physics.raycast_response +---@field fraction number The fraction of the hit measured along the ray, where 0 is the start of the ray and 1 is the end +---@field group hash The collision group of the hit collision object as a hashed name +---@field id hash The instance id of the hit collision object +---@field normal vector3 The normal of the surface of the collision object where it was hit +---@field position vector3 The world position of the hit +---@field request_id number The id supplied when the ray cast was requested + +---@class resource.animation +---@field flip_horizontal boolean|nil Optional flip the animation horizontally, the default value is false +---@field flip_vertical boolean|nil Optional flip the animation vertically, the default value is false +---@field fps integer|nil Optional fps of the animation, the default value is 30 +---@field frame_end integer Index to the last geometry of the animation (non-inclusive). Indices are lua based and must be in the range of 1 .. in atlas. +---@field frame_start integer Index to the first geometry of the animation. Indices are lua based and must be in the range of 1 .. in atlas. +---@field height integer The height of the animation +---@field id string The id of the animation, used in e.g sprite.play_animation +---@field playback constant|nil Optional playback mode of the animation, the default value is go.PLAYBACK_ONCE_FORWARD +---@field width integer The width of the animation + +---@class resource.atlas +---@field animations resource.animation[] A list of the animations in the atlas +---@field geometries resource.geometry[] A list of the geometries that should map to the texture data +---@field texture string|hash The path to the texture resource, e.g "/main/my_texture.texturec" + +---@class resource.geometry +---@field id string The name of the geometry. Used when matching animations between multiple atlases +---@field indices number[] A list of the indices of the geometry in the form { i0, i1, i2, ..., in }. Each tripe in the list represents a triangle. +---@field uvs number[] A list of the uv coordinates in texture space of the geometry in the form of { u0, v0, u1, v1, ..., un, vn } +---@field vertices number[] A list of the vertices in texture space of the geometry in the form { px0, py0, px1, py1, ..., pxn, pyn } + +---@class socket.dns +socket.dns = {} + +---@class url +---@field fragment hash +---@field path hash +---@field socket hash + +---@class vector3 +---@field x number +---@field y number +---@field z number +---@operator add(vector3): vector3 +---@operator mul(number): vector3 +---@operator sub(vector3): vector3 +---@operator unm: vector3 + +---@class vector4 +---@field w number +---@field x number +---@field y number +---@field z number +---@operator add(vector4): vector4 +---@operator mul(number): vector4 +---@operator sub(vector4): vector4 +---@operator unm: vector4 + +---@alias array table +---@alias b2Body userdata +---@alias b2BodyType number +---@alias b2World userdata +---@alias bool boolean +---@alias buffer_data userdata +---@alias buffer_stream userdata +---@alias constant userdata +---@alias constant_buffer userdata +---@alias float number +---@alias hash userdata +---@alias node userdata +---@alias quaternion vector4 +---@alias render_predicate userdata +---@alias render_target userdata +---@alias resource_data userdata +---@alias resource_handle number|userdata +---@alias socket_client userdata +---@alias socket_master userdata +---@alias socket_unconnected userdata \ No newline at end of file diff --git a/annotations/defold_annotations/vmath.lua b/annotations/defold_annotations/vmath.lua new file mode 100644 index 0000000..078caf1 --- /dev/null +++ b/annotations/defold_annotations/vmath.lua @@ -0,0 +1,404 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Vector math API documentation + + Functions for mathematical operations on vectors, matrices and quaternions. + The vector types (vmath.vector3 and vmath.vector4) supports addition and subtraction + with vectors of the same type. Vectors can be negated and multiplied (scaled) or divided by numbers. + The quaternion type (vmath.quat) supports multiplication with other quaternions. + The matrix type (vmath.matrix4) can be multiplied with numbers, other matrices + and vmath.vector4 values. + All types performs equality comparison by each component value. + The following components are available for the various types: + vector3 + x, y and z. Example: v.y + vector4 + x, y, z, and w. Example: v.w + quaternion + x, y, z, and w. Example: q.w + matrix4 + m00 to m33 where the first number is the row (starting from 0) and the second + number is the column. Columns can be accessed with c0 to c3, returning a vector4. + Example: m.m21 which is equal to m.c1.z + vector + indexed by number 1 to the vector length. Example: v[3] +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.vmath +vmath = {} + +---Calculates the conjugate of a quaternion. The result is a +---quaternion with the same magnitudes but with the sign of +---the imaginary (vector) parts changed: +---q* = [w, -v] +---@param q1 quaternion quaternion of which to calculate the conjugate +---@return quaternion q the conjugate +function vmath.conj(q1) end + +---Given two linearly independent vectors P and Q, the cross product, +---P × Q, is a vector that is perpendicular to both P and Q and +---therefore normal to the plane containing them. +---If the two vectors have the same direction (or have the exact +---opposite direction from one another, i.e. are not linearly independent) +---or if either one has zero length, then their cross product is zero. +---@param v1 vector3 first vector +---@param v2 vector3 second vector +---@return vector3 v a new vector representing the cross product +function vmath.cross(v1, v2) end + +---The returned value is a scalar defined as: +---P ⋅ Q = |P| |Q| cos θ +---where θ is the angle between the vectors P and Q. +---If the dot product is positive then the angle between the vectors is below 90 degrees. +---If the dot product is zero the vectors are perpendicular (at right-angles to each other). +---If the dot product is negative then the angle between the vectors is more than 90 degrees. +---@param v1 vector3|vector4 first vector +---@param v2 vector3|vector4 second vector +---@return number n dot product +function vmath.dot(v1, v2) end + +---The resulting matrix is the inverse of the supplied matrix. +--- For ortho-normal matrices, e.g. regular object transformation, +---use vmath.ortho_inv() instead. +---The specialized inverse for ortho-normalized matrices is much faster +---than the general inverse. +---@param m1 matrix4 matrix to invert +---@return matrix4 m inverse of the supplied matrix +function vmath.inv(m1) end + +---Returns the length of the supplied vector or quaternion. +---If you are comparing the lengths of vectors or quaternions, you should compare +---the length squared instead as it is slightly more efficient to calculate +---(it eliminates a square root calculation). +---@param v vector3|vector4|quaternion value of which to calculate the length +---@return number n length +function vmath.length(v) end + +---Returns the squared length of the supplied vector or quaternion. +---@param v vector3|vector4|quaternion value of which to calculate the squared length +---@return number n squared length +function vmath.length_sqr(v) end + +---Linearly interpolate between two quaternions. Linear +---interpolation of rotations are only useful for small +---rotations. For interpolations of arbitrary rotations, +---vmath.slerp yields much better results. +--- The function does not clamp t between 0 and 1. +---@param t number interpolation parameter, 0-1 +---@param q1 quaternion quaternion to lerp from +---@param q2 quaternion quaternion to lerp to +---@return quaternion q the lerped quaternion +function vmath.lerp(t, q1, q2) end + +---Linearly interpolate between two vectors. The function +---treats the vectors as positions and interpolates between +---the positions in a straight line. Lerp is useful to describe +---transitions from one place to another over time. +--- The function does not clamp t between 0 and 1. +---@param t number interpolation parameter, 0-1 +---@param v1 vector3|vector4 vector to lerp from +---@param v2 vector3|vector4 vector to lerp to +---@return vector3|vector4 v the lerped vector +function vmath.lerp(t, v1, v2) end + +---Linearly interpolate between two values. Lerp is useful +---to describe transitions from one value to another over time. +--- The function does not clamp t between 0 and 1. +---@param t number interpolation parameter, 0-1 +---@param n1 number number to lerp from +---@param n2 number number to lerp to +---@return number n the lerped number +function vmath.lerp(t, n1, n2) end + +---The resulting identity matrix describes a transform with +---no translation or rotation. +---@return matrix4 m identity matrix +function vmath.matrix4() end + +---Creates a new matrix with all components set to the +---corresponding values from the supplied matrix. I.e. +---the function creates a copy of the given matrix. +---@param m1 matrix4 existing matrix +---@return matrix4 m matrix which is a copy of the specified matrix +function vmath.matrix4(m1) end + +---The resulting matrix describes a rotation around the axis by the specified angle. +---@param v vector3 axis +---@param angle number angle in radians +---@return matrix4 m matrix represented by axis and angle +function vmath.matrix4_axis_angle(v, angle) end + +---The resulting matrix describes the same rotation as the quaternion, but does not have any translation (also like the quaternion). +---@param q quaternion quaternion to create matrix from +---@return matrix4 m matrix represented by quaternion +function vmath.matrix4_from_quat(q) end + +---Constructs a frustum matrix from the given values. The left, right, +---top and bottom coordinates of the view cone are expressed as distances +---from the center of the near clipping plane. The near and far coordinates +---are expressed as distances from the tip of the view frustum cone. +---@param left number coordinate for left clipping plane +---@param right number coordinate for right clipping plane +---@param bottom number coordinate for bottom clipping plane +---@param top number coordinate for top clipping plane +---@param near number coordinate for near clipping plane +---@param far number coordinate for far clipping plane +---@return matrix4 m matrix representing the frustum +function vmath.matrix4_frustum(left, right, bottom, top, near, far) end + +---The resulting matrix is created from the supplied look-at parameters. +---This is useful for constructing a view matrix for a camera or +---rendering in general. +---@param eye vector3 eye position +---@param look_at vector3 look-at position +---@param up vector3 up vector +---@return matrix4 m look-at matrix +function vmath.matrix4_look_at(eye, look_at, up) end + +---Creates an orthographic projection matrix. +---This is useful to construct a projection matrix for a camera or rendering in general. +---@param left number coordinate for left clipping plane +---@param right number coordinate for right clipping plane +---@param bottom number coordinate for bottom clipping plane +---@param top number coordinate for top clipping plane +---@param near number coordinate for near clipping plane +---@param far number coordinate for far clipping plane +---@return matrix4 m orthographic projection matrix +function vmath.matrix4_orthographic(left, right, bottom, top, near, far) end + +---Creates a perspective projection matrix. +---This is useful to construct a projection matrix for a camera or rendering in general. +---@param fov number angle of the full vertical field of view in radians +---@param aspect number aspect ratio +---@param near number coordinate for near clipping plane +---@param far number coordinate for far clipping plane +---@return matrix4 m perspective projection matrix +function vmath.matrix4_perspective(fov, aspect, near, far) end + +---The resulting matrix describes a rotation around the x-axis +---by the specified angle. +---@param angle number angle in radians around x-axis +---@return matrix4 m matrix from rotation around x-axis +function vmath.matrix4_rotation_x(angle) end + +---The resulting matrix describes a rotation around the y-axis +---by the specified angle. +---@param angle number angle in radians around y-axis +---@return matrix4 m matrix from rotation around y-axis +function vmath.matrix4_rotation_y(angle) end + +---The resulting matrix describes a rotation around the z-axis +---by the specified angle. +---@param angle number angle in radians around z-axis +---@return matrix4 m matrix from rotation around z-axis +function vmath.matrix4_rotation_z(angle) end + +---The resulting matrix describes a translation of a point +---in euclidean space. +---@param position vector3|vector4 position vector to create matrix from +---@return matrix4 m matrix from the supplied position vector +function vmath.matrix4_translation(position) end + +---Performs an element wise multiplication between two vectors of the same type +---The returned value is a vector defined as (e.g. for a vector3): +---v = vmath.mul_per_elem(a, b) = vmath.vector3(a.x * b.x, a.y * b.y, a.z * b.z) +---@param v1 vector3|vector4 first vector +---@param v2 vector3|vector4 second vector +---@return vector3|vector4 v multiplied vector +function vmath.mul_per_elem(v1, v2) end + +---Normalizes a vector, i.e. returns a new vector with the same +---direction as the input vector, but with length 1. +--- The length of the vector must be above 0, otherwise a +---division-by-zero will occur. +---@param v1 vector3|vector4|quaternion vector to normalize +---@return vector3|vector4|quaternion v new normalized vector +function vmath.normalize(v1) end + +---The resulting matrix is the inverse of the supplied matrix. +---The supplied matrix has to be an ortho-normal matrix, e.g. +---describe a regular object transformation. +--- For matrices that are not ortho-normal +---use the general inverse vmath.inv() instead. +---@param m1 matrix4 ortho-normalized matrix to invert +---@return matrix4 m inverse of the supplied matrix +function vmath.ortho_inv(m1) end + +---Calculates the extent the projection of the first vector onto the second. +---The returned value is a scalar p defined as: +---p = |P| cos θ / |Q| +---where θ is the angle between the vectors P and Q. +---@param v1 vector3 vector to be projected on the second +---@param v2 vector3 vector onto which the first will be projected, must not have zero length +---@return number n the projected extent of the first vector onto the second +function vmath.project(v1, v2) end + +---Creates a new identity quaternion. The identity +---quaternion is equal to: +---vmath.quat(0, 0, 0, 1) +---@return quaternion q new identity quaternion +function vmath.quat() end + +---Creates a new quaternion with the components set +---according to the supplied parameter values. +---@param x number x coordinate +---@param y number y coordinate +---@param z number z coordinate +---@param w number w coordinate +---@return quaternion q new quaternion +function vmath.quat(x, y, z, w) end + +---Creates a new quaternion with all components set to the +---corresponding values from the supplied quaternion. I.e. +---This function creates a copy of the given quaternion. +---@param q1 quaternion existing quaternion +---@return quaternion q new quaternion +function vmath.quat(q1) end + +---The resulting quaternion describes a rotation of angle +---radians around the axis described by the unit vector v. +---@param v vector3 axis +---@param angle number angle +---@return quaternion q quaternion representing the axis-angle rotation +function vmath.quat_axis_angle(v, angle) end + +---The resulting quaternion describes the rotation from the +---identity quaternion (no rotation) to the coordinate system +---as described by the given x, y and z base unit vectors. +---@param x vector3 x base vector +---@param y vector3 y base vector +---@param z vector3 z base vector +---@return quaternion q quaternion representing the rotation of the specified base vectors +function vmath.quat_basis(x, y, z) end + +---The resulting quaternion describes the rotation that, +---if applied to the first vector, would rotate the first +---vector to the second. The two vectors must be unit +---vectors (of length 1). +--- The result is undefined if the two vectors point in opposite directions +---@param v1 vector3 first unit vector, before rotation +---@param v2 vector3 second unit vector, after rotation +---@return quaternion q quaternion representing the rotation from first to second vector +function vmath.quat_from_to(v1, v2) end + +---The resulting quaternion describes a rotation of angle +---radians around the x-axis. +---@param angle number angle in radians around x-axis +---@return quaternion q quaternion representing the rotation around the x-axis +function vmath.quat_rotation_x(angle) end + +---The resulting quaternion describes a rotation of angle +---radians around the y-axis. +---@param angle number angle in radians around y-axis +---@return quaternion q quaternion representing the rotation around the y-axis +function vmath.quat_rotation_y(angle) end + +---The resulting quaternion describes a rotation of angle +---radians around the z-axis. +---@param angle number angle in radians around z-axis +---@return quaternion q quaternion representing the rotation around the z-axis +function vmath.quat_rotation_z(angle) end + +---Returns a new vector from the supplied vector that is +---rotated by the rotation described by the supplied +---quaternion. +---@param q quaternion quaternion +---@param v1 vector3 vector to rotate +---@return vector3 v the rotated vector +function vmath.rotate(q, v1) end + +---Slerp travels the torque-minimal path maintaining constant +---velocity, which means it travels along the straightest path along +---the rounded surface of a sphere. Slerp is useful for interpolation +---of rotations. +---Slerp travels the torque-minimal path, which means it travels +---along the straightest path the rounded surface of a sphere. +--- The function does not clamp t between 0 and 1. +---@param t number interpolation parameter, 0-1 +---@param q1 quaternion quaternion to slerp from +---@param q2 quaternion quaternion to slerp to +---@return quaternion q the slerped quaternion +function vmath.slerp(t, q1, q2) end + +---Spherically interpolates between two vectors. The difference to +---lerp is that slerp treats the vectors as directions instead of +---positions in space. +---The direction of the returned vector is interpolated by the angle +---and the magnitude is interpolated between the magnitudes of the +---from and to vectors. +--- Slerp is computationally more expensive than lerp. +---The function does not clamp t between 0 and 1. +---@param t number interpolation parameter, 0-1 +---@param v1 vector3|vector4 vector to slerp from +---@param v2 vector3|vector4 vector to slerp to +---@return vector3|vector4 v the slerped vector +function vmath.slerp(t, v1, v2) end + +---Creates a vector of arbitrary size. The vector is initialized +---with numeric values from a table. +--- The table values are converted to floating point +---values. If a value cannot be converted, a 0 is stored in that +---value position in the vector. +---@param t table table of numbers +---@return vector4|vector3 v new vector +function vmath.vector(t) end + +---Creates a new vector with all components set to the +---corresponding values from the supplied vector. I.e. +---This function creates a copy of the given vector. +---@param v1 vector3 existing vector +---@return vector3 v new vector +function vmath.vector3(v1) end + +---Creates a new vector with the components set to the +---supplied values. +---@param x number x coordinate +---@param y number y coordinate +---@param z number z coordinate +---@return vector3 v new vector +function vmath.vector3(x, y, z) end + +---Creates a new zero vector with all components set to 0. +---@return vector3 v new zero vector +function vmath.vector3() end + +---Creates a new vector with all components set to the +---supplied scalar value. +---@param n number scalar value to splat +---@return vector3 v new vector +function vmath.vector3(n) end + +---Creates a new vector with the components set to the +---supplied values. +---@param x number x coordinate +---@param y number y coordinate +---@param z number z coordinate +---@param w number w coordinate +---@return vector4 v new vector +function vmath.vector4(x, y, z, w) end + +---Creates a new vector with all components set to the +---supplied scalar value. +---@param n number scalar value to splat +---@return vector4 v new vector +function vmath.vector4(n) end + +---Creates a new zero vector with all components set to 0. +---@return vector4 v new zero vector +function vmath.vector4() end + +---Creates a new vector with all components set to the +---corresponding values from the supplied vector. I.e. +---This function creates a copy of the given vector. +---@param v1 vector4 existing vector +---@return vector4 v new vector +function vmath.vector4(v1) end + +return vmath \ No newline at end of file diff --git a/annotations/defold_annotations/window.lua b/annotations/defold_annotations/window.lua new file mode 100644 index 0000000..c2d9109 --- /dev/null +++ b/annotations/defold_annotations/window.lua @@ -0,0 +1,110 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Window API documentation + + Functions and constants to access the window, window event listeners + and screen dimming. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.window +window = {} + +---Dimming mode is used to control whether or not a mobile device should dim the screen after a period without user interaction. +window.DIMMING_OFF = nil + +---Dimming mode is used to control whether or not a mobile device should dim the screen after a period without user interaction. +window.DIMMING_ON = nil + +---Dimming mode is used to control whether or not a mobile device should dim the screen after a period without user interaction. +---This mode indicates that the dim mode can't be determined, or that the platform doesn't support dimming. +window.DIMMING_UNKNOWN = nil + +--- This event is sent to a window event listener when the game window or app screen is +---restored after being iconified. +window.WINDOW_EVENT_DEICONIFIED = nil + +---This event is sent to a window event listener when the game window or app screen has +---gained focus. +---This event is also sent at game startup and the engine gives focus to the game. +window.WINDOW_EVENT_FOCUS_GAINED = nil + +---This event is sent to a window event listener when the game window or app screen has lost focus. +window.WINDOW_EVENT_FOCUS_LOST = nil + +--- This event is sent to a window event listener when the game window or app screen is +---iconified (reduced to an application icon in a toolbar, application tray or similar). +window.WINDOW_EVENT_ICONFIED = nil + +---This event is sent to a window event listener when the game window or app screen is resized. +---The new size is passed along in the data field to the event listener. +window.WINDOW_EVENT_RESIZED = nil + +--- Returns the current dimming mode set on a mobile device. +---The dimming mode specifies whether or not a mobile device should dim the screen after a period without user interaction. +---On platforms that does not support dimming, window.DIMMING_UNKNOWN is always returned. +---@return constant mode The mode for screen dimming +--- +---window.DIMMING_UNKNOWN +---window.DIMMING_ON +---window.DIMMING_OFF +--- +function window.get_dim_mode() end + +---This returns the current lock state of the mouse cursor +---@return boolean state The lock state +function window.get_mouse_lock() end + +---This returns the current window size (width and height). +---@return number width The window width +---@return number height The window height +function window.get_size() end + +--- Sets the dimming mode on a mobile device. +---The dimming mode specifies whether or not a mobile device should dim the screen after a period without user interaction. The dimming mode will only affect the mobile device while the game is in focus on the device, but not when the game is running in the background. +---This function has no effect on platforms that does not support dimming. +---@param mode constant The mode for screen dimming +--- +---window.DIMMING_ON +---window.DIMMING_OFF +--- +function window.set_dim_mode(mode) end + +---Sets a window event listener. +---@param callback fun(self, event, data)|nil A callback which receives info about window events. Pass an empty function or nil if you no longer wish to receive callbacks. +--- +---self +---object The calling script +---event +---constant The type of event. Can be one of these: +--- +--- +---window.WINDOW_EVENT_FOCUS_LOST +---window.WINDOW_EVENT_FOCUS_GAINED +---window.WINDOW_EVENT_RESIZED +---window.WINDOW_EVENT_ICONIFIED +---window.WINDOW_EVENT_DEICONIFIED +--- +--- +---data +---table The callback value data is a table which currently holds these values +--- +--- +---number width: The width of a resize event. nil otherwise. +---number height: The height of a resize event. nil otherwise. +--- +function window.set_listener(callback) end + +---Set the locking state for current mouse cursor on a PC platform. +---This function locks or unlocks the mouse cursor to the center point of the window. While the cursor is locked, +---mouse position updates will still be sent to the scripts as usual. +---@param flag boolean The lock state for the mouse cursor +function window.set_mouse_lock(flag) end + +return window \ No newline at end of file diff --git a/annotations/defold_annotations/zlib.lua b/annotations/defold_annotations/zlib.lua new file mode 100644 index 0000000..5d297aa --- /dev/null +++ b/annotations/defold_annotations/zlib.lua @@ -0,0 +1,28 @@ +--[[ + Generated with github.com/astrochili/defold-annotations + Defold 1.8.1 + + Zlib compression API documentation + + Functions for compression and decompression of string buffers. +--]] + +---@diagnostic disable: lowercase-global +---@diagnostic disable: missing-return +---@diagnostic disable: duplicate-doc-param +---@diagnostic disable: duplicate-set-field + +---@class defold_api.zlib +zlib = {} + +---A lua error is raised is on error +---@param buf string buffer to deflate +---@return string buf deflated buffer +function zlib.deflate(buf) end + +---A lua error is raised is on error +---@param buf string buffer to inflate +---@return string buf inflated buffer +function zlib.inflate(buf) end + +return zlib \ No newline at end of file diff --git a/docs/panthera_adapter.md b/docs/panthera_adapter.md index 175bf41..284851b 100644 --- a/docs/panthera_adapter.md +++ b/docs/panthera_adapter.md @@ -6,9 +6,9 @@ In Panthera Runtime for Defold, an adapter is a crucial component that bridges P An adapter takes care of several key tasks: -- **Node Retrieval**: Finds the specific game or GUI node in Defold that an animation should be applied to. - **Property Animation**: Applies animations to properties of nodes, such as position, rotation, or scale, using Defold's animation system. - **Event Handling**: Triggers custom actions defined in Panthera animations, like playing a sound or changing a scene. +- **Easing Functions**: Maps Panthera easing functions to Defold's easing types for smooth transitions. #### Example Adapter @@ -16,10 +16,6 @@ Here’s a simple adapter example for Defold GUI: ```lua local M = { - get_node = function(node_id) - -- Retrieves a Defold node by its ID. - return gui.get_node(node_id) - end, get_easing = function(easing_name) -- Returns a Defold easing type. This example always returns LINEAR easing. -- You might want to map Panthera easing names to Defold's easing constants. diff --git a/example/default.render_script b/example/default.render_script index b61a16a..c3df877 100644 --- a/example/default.render_script +++ b/example/default.render_script @@ -3,10 +3,10 @@ -- Copyright 2009-2014 Ragnar Svensson, Christian Murray -- Licensed under the Defold License version 1.0 (the "License"); you may not use -- this file except in compliance with the License. --- +-- -- You may obtain a copy of the License, together with FAQs at -- https://www.defold.com/license --- +-- -- Unless required by applicable law or agreed to in writing, software distributed -- under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR -- CONDITIONS OF ANY KIND, either express or implied. See the License for the diff --git a/example/example.gui_script b/example/example.gui_script index 45b0eac..149894e 100644 --- a/example/example.gui_script +++ b/example/example.gui_script @@ -10,7 +10,7 @@ local logger = log.get_logger("example") ---@field animation_control_zone node ---@field progress_fill node ---@field progress_size vector3 ----@field text_animation_id string +---@field text_animation_id node ---@field is_dragging boolean diff --git a/panthera/adapters/adapter_go.lua b/panthera/adapters/adapter_go.lua index 6c6d707..ba52295 100644 --- a/panthera/adapters/adapter_go.lua +++ b/panthera/adapters/adapter_go.lua @@ -92,6 +92,41 @@ local function split(inputstr, sep) end +---@param collection_name string|nil +---@param objects table|nil +---@return function(node_id: string): hash|url +local function create_get_node_function(collection_name, objects) + return function(node_id) + if collection_name then + node_id = collection_name .. "/" .. node_id + end + + -- Acquire component id + local split_index = string.find(node_id, "#") + if split_index then + local object_id = string.sub(node_id, 1, split_index - 1) + local fragment_id = string.sub(node_id, split_index + 1) + + local object_path = hash("/" .. object_id) + if objects then + object_path = objects[object_path] --[[@as hash]] + end + + local object_url = msg.url(object_path) + object_url.fragment = hash(fragment_id) + + return object_url + end + + local object_path = hash("/" .. node_id) + if objects then + object_path = objects[object_path] --[[@as hash]] + end + return object_path + end +end + + ---@param node node ---@param property_id string ---@param value any @@ -126,6 +161,7 @@ local function get_trigger_property_id(node, property_id) end if defold_property_id == "texture" then local texture_name = go.get(node, "animation") + pprint(texture_name) local splitted = split(texture_name, "/") return splitted[#splitted] end @@ -213,66 +249,14 @@ local function tween_animation_key(node, property_id, easing, duration, end_valu end ----@param node_id string @If node_id contains "#", split it and get full url ----@return hash|url -local function get_node(node_id) - if string.find(node_id, "#") then - local object_id = string.sub(node_id, 1, string.find(node_id, "#") - 1) - local fragment_id = string.sub(node_id, string.find(node_id, "#") + 1) - - local object_url = msg.url(hash("/" .. object_id)) - object_url.fragment = fragment_id - - return object_url - end - - return hash("/" .. node_id) -end - - ----@param collection_name string|nil ----@param objects table|nil ----@return function(node_id: string): hash|url -local function get_node_function(collection_name, objects) - return function(node_id) - if collection_name then - node_id = collection_name .. "/" .. node_id - end - - local split_index = string.find(node_id, "#") - if split_index then - local object_id = string.sub(node_id, 1, split_index - 1) - local fragment_id = string.sub(node_id, split_index + 1) - - local object_path = hash("/" .. object_id) - if objects then - object_path = objects[object_path] - end - - local object_url = msg.url(object_path) - object_url.fragment = fragment_id - - return object_url - end - - local object_path = hash("/" .. node_id) - if objects then - object_path = objects[object_path] - end - return object_path - end -end - - local M = { - get_node = get_node, - get_node_function = get_node_function, get_easing = get_easing, set_node_property = set_node_property, get_node_property = get_node_property, tween_animation_key = tween_animation_key, stop_tween = stop_tween, trigger_animation_key = trigger_animation_key, + create_get_node_function = create_get_node_function, } diff --git a/panthera/adapters/adapter_gui.lua b/panthera/adapters/adapter_gui.lua index 216bf75..d16771b 100644 --- a/panthera/adapters/adapter_gui.lua +++ b/panthera/adapters/adapter_gui.lua @@ -262,9 +262,9 @@ local DEFOLD_TRIGGER_SETTER = { ---@param template string|nil @GUI template path to load nodes from. Pass nil if no template is used ----@param nodes table|nil @Table with nodes from gui.clone_tree() function. Pass nil if no nodes are used +---@param nodes table|nil @Table with nodes from gui.clone_tree() function. Pass nil if no nodes are used ---@return fun(node_id: string): node -local function get_node_function(template, nodes) +local function create_get_node_function(template, nodes) return function(node_id) if template then node_id = template .. "/" .. node_id @@ -405,14 +405,13 @@ end local M = { - get_node = gui.get_node, - get_node_function = get_node_function, get_easing = get_easing, stop_tween = stop_tween, set_node_property = set_node_property, get_node_property = get_node_property, tween_animation_key = tween_animation_key, trigger_animation_key = trigger_animation_key, + create_get_node_function = create_get_node_function, } diff --git a/panthera/panthera.lua b/panthera/panthera.lua index deaee19..1ebc420 100644 --- a/panthera/panthera.lua +++ b/panthera/panthera.lua @@ -19,7 +19,7 @@ end ---@param objects table|nil @Table with game objects from collectionfactory. Pass nil if no objects are used ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message function M.create_go(animation_path, collection_name, objects) - local get_node = adapter_go.get_node_function(collection_name, objects) + local get_node = adapter_go.create_get_node_function(collection_name, objects) return M.create(animation_path, adapter_go, get_node) end @@ -27,10 +27,10 @@ end ---Load animation from JSON file and create it with Panthera GUI adapter ---@param animation_path string ---@param template string|nil @The GUI template id to load nodes from. Pass nil if no template is used ----@param nodes table|nil @Table with nodes from gui.clone_tree() function. Pass nil if no nodes are used +---@param nodes table|nil @Table with nodes from gui.clone_tree() function. Pass nil if no nodes are used ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message function M.create_gui(animation_path, template, nodes) - local get_node = adapter_gui.get_node_function(template, nodes) + local get_node = adapter_gui.create_get_node_function(template, nodes) return M.create(animation_path, adapter_gui, get_node) end @@ -38,7 +38,7 @@ end ---Load animation from JSON file ---@param animation_path string ---@param adapter panthera.adapter ----@param get_node (fun(node_id: string): node)|nil @Function to get node by node_id. Default is defined in adapter +---@param get_node (fun(node_id: string): node) @Function to get node by node_id. Default is defined in adapter ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message function M.create(animation_path, adapter, get_node) local animation_data, error_reason = panthera_internal.load(animation_path, false) @@ -59,7 +59,7 @@ function M.create(animation_path, adapter, get_node) adapter = adapter, animation_keys_index = 1, animation_path = animation_path, - get_node = get_node or adapter.get_node, + get_node = get_node, } return animation_state diff --git a/resources/test_go.json b/resources/test_go.json index 5f57304..2bbe33a 100644 --- a/resources/test_go.json +++ b/resources/test_go.json @@ -1 +1 @@ -{"data":{"animations":[{"animation_id":"default","animation_keys":[{"duration":1,"easing":"outsine","end_value":1.4,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_x","start_value":1},{"duration":1,"easing":"outsine","end_value":1.4,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_y","start_value":1},{"duration":2,"easing":"outsine","end_value":0.189,"key_type":"tween","node_id":"panthera#label","property_id":"color_b","start_value":1},{"duration":2,"easing":"outsine","end_value":0.189,"key_type":"tween","node_id":"panthera#label","property_id":"color_g","start_value":1},{"duration":2,"easing":"outsine","end_value":0.816,"key_type":"tween","node_id":"panthera#label","property_id":"color_r","start_value":1},{"data":"Hey!","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Text","start_time":0.5},{"data":"Text is","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Hey!","start_time":1},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_x","start_time":1,"start_value":1.4},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_y","start_time":1,"start_value":1.4},{"data":"CHANING","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Text is","start_time":2},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_b","start_time":2,"start_value":0.189},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_g","start_time":2,"start_value":0.189},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_r","start_time":2,"start_value":0.816}],"duration":3}],"metadata":{"fps":60,"gizmo_steps":{"time":0.1},"settings":{"font_size":40}},"nodes":[{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"inherit_alpha":true,"node_id":"panthera","node_index":1,"node_type":"box","pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":1,"size_y":1},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"fill_angle":360,"inherit_alpha":true,"node_id":"panthera#sprite","node_index":2,"node_type":"box","outer_bounds":"ellipse","parent":"panthera","perimeter_vertices":10,"pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"auto","size_x":128,"size_y":128,"text_leading":1,"texture":"example/panthera","visible":true},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"fill_angle":360,"inherit_alpha":true,"node_id":"panthera#label","node_index":3,"node_type":"text","outer_bounds":"ellipse","parent":"panthera","perimeter_vertices":10,"pivot":"pivot_center","position_y":70,"scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":128,"size_y":32,"text":"Text","text_leading":1,"visible":true}]},"format":"json","type":"animation_editor","version":1} \ No newline at end of file +{"data":{"animations":[{"animation_id":"default","animation_keys":[{"duration":1,"easing":"outsine","end_value":1.4,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_x","start_value":1},{"duration":1,"easing":"outsine","end_value":1.4,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_y","start_value":1},{"duration":2,"easing":"outsine","end_value":0.189,"key_type":"tween","node_id":"panthera#label","property_id":"color_b","start_value":1},{"duration":2,"easing":"outsine","end_value":0.189,"key_type":"tween","node_id":"panthera#label","property_id":"color_g","start_value":1},{"duration":2,"easing":"outsine","end_value":0.816,"key_type":"tween","node_id":"panthera#label","property_id":"color_r","start_value":1},{"data":"Hey!","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Text","start_time":0.5},{"data":"Text is","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Hey!","start_time":1},{"data":"example/ui_circle","easing":"linear","key_type":"trigger","node_id":"panthera#sprite","property_id":"texture","start_data":"example/panthera","start_time":1},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_x","start_time":1,"start_value":1.4},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#sprite","property_id":"scale_y","start_time":1,"start_value":1.4},{"data":"CHANING","easing":"linear","key_type":"trigger","node_id":"panthera#label","property_id":"text","start_data":"Text is","start_time":2},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_b","start_time":2,"start_value":0.189},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_g","start_time":2,"start_value":0.189},{"duration":1,"easing":"outsine","end_value":1,"key_type":"tween","node_id":"panthera#label","property_id":"color_r","start_time":2,"start_value":0.816}],"duration":3}],"metadata":{"fps":60,"gizmo_steps":{"time":0.1},"settings":{"font_size":40}},"nodes":[{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"inherit_alpha":true,"node_id":"panthera","node_index":1,"node_type":"box","pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":1,"size_y":1},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"fill_angle":360,"inherit_alpha":true,"node_id":"panthera#sprite","node_index":2,"node_type":"box","outer_bounds":"ellipse","parent":"panthera","perimeter_vertices":10,"pivot":"pivot_center","scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"auto","size_x":128,"size_y":128,"text_leading":1,"texture":"example/panthera","visible":true},{"blend_mode":"alpha","clipping_mode":"none","clipping_visible":true,"color_a":1,"color_b":1,"color_g":1,"color_r":1,"enabled":true,"fill_angle":360,"inherit_alpha":true,"node_id":"panthera#label","node_index":3,"node_type":"text","outer_bounds":"ellipse","parent":"panthera","perimeter_vertices":10,"pivot":"pivot_center","position_y":70,"scale_x":1,"scale_y":1,"scale_z":1,"size_mode":"manual","size_x":128,"size_y":32,"text":"Text","text_leading":1,"visible":true}]},"format":"json","type":"animation_editor","version":1} \ No newline at end of file From cb0c146562856ca4877e0c133ad69e1ca70cc5d7 Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 20 Jul 2024 18:20:15 +0300 Subject: [PATCH 06/17] Update examples --- README.md | 8 +- .../go/example_go_template_nodes.collection | 95 ++++++++++++++++--- .../go/example_go_template_nodes.script | 11 ++- 3 files changed, 97 insertions(+), 17 deletions(-) diff --git a/README.md b/README.md index c4783cb..c8a729c 100644 --- a/README.md +++ b/README.md @@ -226,7 +226,13 @@ local go_animation = panthera.create_go(PATH) -- Run over collection on current scene local go_animation = panthera.create_go(PATH, "collection_name") --- Run over objects from collection +-- Run over object from spawned factory +-- You should create a table with mapping object to created instance. +-- Instead "/pantera" use object id from animation +local object = factory.create("#factory") +local go_animation = panthera.create_go(PATH, nil, { [hash("/panthera")] = object }) + +-- Run over objects from spawned collection local objects = collectionfactory.create("#collectionfactory") local go_animation = panthera.create_go(PATH, nil, objects) diff --git a/example/example_go_gui_templates/go/example_go_template_nodes.collection b/example/example_go_gui_templates/go/example_go_template_nodes.collection index c170439..4a67e36 100644 --- a/example/example_go_gui_templates/go/example_go_template_nodes.collection +++ b/example/example_go_gui_templates/go/example_go_template_nodes.collection @@ -3,7 +3,7 @@ collection_instances { id: "test_collection" collection: "/example/example_go_gui_templates/go/test_collection.collection" position { - x: 640.0 + x: 480.0 y: 480.0 z: 0.0 } @@ -23,8 +23,8 @@ collection_instances { id: "test_inner_collection" collection: "/example/example_go_gui_templates/go/test_inner_collection.collection" position { - x: 320.0 - y: 160.0 + x: 840.0 + y: 475.0 z: 0.0 } rotation { @@ -135,7 +135,7 @@ embedded_instances { "material: \\\"/builtins/fonts/label-df.material\\\"\\n" "\"\n" " position {\n" - " x: -160.0\n" + " x: -360.0\n" " y: 280.0\n" " z: 0.0\n" " }\n" @@ -183,7 +183,7 @@ embedded_instances { "material: \\\"/builtins/fonts/label-df.material\\\"\\n" "\"\n" " position {\n" - " x: 160.0\n" + " x: 0.0\n" " y: 280.0\n" " z: 0.0\n" " }\n" @@ -231,7 +231,55 @@ embedded_instances { "material: \\\"/builtins/fonts/label-df.material\\\"\\n" "\"\n" " position {\n" - " x: -160.0\n" + " x: 360.0\n" + " y: 275.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"label_collection_cloned\"\n" + " type: \"label\"\n" + " data: \"size {\\n" + " x: 128.0\\n" + " y: 32.0\\n" + " z: 0.0\\n" + " w: 0.0\\n" + "}\\n" + "color {\\n" + " x: 1.0\\n" + " y: 1.0\\n" + " z: 1.0\\n" + " w: 1.0\\n" + "}\\n" + "outline {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "shadow {\\n" + " x: 0.0\\n" + " y: 0.0\\n" + " z: 0.0\\n" + " w: 1.0\\n" + "}\\n" + "leading: 1.0\\n" + "tracking: 0.0\\n" + "pivot: PIVOT_CENTER\\n" + "blend_mode: BLEND_MODE_ALPHA\\n" + "line_break: true\\n" + "text: \\\"Spawned Collection\\\"\\n" + "font: \\\"/example/assets/troika.font\\\"\\n" + "material: \\\"/builtins/fonts/label-df.material\\\"\\n" + "\"\n" + " position {\n" + " x: 0.0\n" " y: -40.0\n" " z: 0.0\n" " }\n" @@ -248,7 +296,7 @@ embedded_instances { " }\n" "}\n" "embedded_components {\n" - " id: \"label_collection_cloned\"\n" + " id: \"label_collection_nested_cloned\"\n" " type: \"label\"\n" " data: \"size {\\n" " x: 128.0\\n" @@ -279,12 +327,12 @@ embedded_instances { "pivot: PIVOT_CENTER\\n" "blend_mode: BLEND_MODE_ALPHA\\n" "line_break: true\\n" - "text: \\\"Spawned Collection\\\"\\n" + "text: \\\"Spawned Nested\\\"\\n" "font: \\\"/example/assets/troika.font\\\"\\n" "material: \\\"/builtins/fonts/label-df.material\\\"\\n" "\"\n" " position {\n" - " x: 160.0\n" + " x: 360.0\n" " y: -40.0\n" " z: 0.0\n" " }\n" @@ -301,10 +349,29 @@ embedded_instances { " }\n" "}\n" "embedded_components {\n" - " id: \"label_collection_nested_cloned\"\n" + " id: \"factory\"\n" + " type: \"factory\"\n" + " data: \"prototype: \\\"/example/example_go_gui_templates/go/test_go.go\\\"\\n" + "load_dynamically: false\\n" + "dynamic_prototype: false\\n" + "\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + "}\n" + "embedded_components {\n" + " id: \"label_game_object_factory\"\n" " type: \"label\"\n" " data: \"size {\\n" - " x: 128.0\\n" + " x: 240.0\\n" " y: 32.0\\n" " z: 0.0\\n" " w: 0.0\\n" @@ -332,12 +399,12 @@ embedded_instances { "pivot: PIVOT_CENTER\\n" "blend_mode: BLEND_MODE_ALPHA\\n" "line_break: true\\n" - "text: \\\"Spawned Nested\\\"\\n" + "text: \\\"Spawner Game Object\\\"\\n" "font: \\\"/example/assets/troika.font\\\"\\n" "material: \\\"/builtins/fonts/label-df.material\\\"\\n" "\"\n" " position {\n" - " x: 380.0\n" + " x: -360.0\n" " y: -40.0\n" " z: 0.0\n" " }\n" @@ -446,7 +513,7 @@ embedded_instances { "}\n" "" position { - x: -160.0 + x: -360.0 y: 160.0 z: 0.0 } diff --git a/example/example_go_gui_templates/go/example_go_template_nodes.script b/example/example_go_gui_templates/go/example_go_template_nodes.script index 9d326ec..f90ecac 100644 --- a/example/example_go_gui_templates/go/example_go_template_nodes.script +++ b/example/example_go_gui_templates/go/example_go_template_nodes.script @@ -20,11 +20,18 @@ function init(self) panthera.play(go_animation, "default", { is_loop = true }) + -- Run Panthera over Game Object from factory + local object = factory.create("#factory") + go.set_position(vmath.vector3(120, 160, 0), object) + local go_animation = panthera.create_go(PATH, nil, { [hash("/panthera")] = object }) + panthera.play(go_animation, "default", { is_loop = true }) + + -- Run Panthera over collection from collectionfactory -- We create a collection from collectionfactory and use this objects to run Panthera -- The paths to the objects inside this collection are just paths without any collection names local objects = collectionfactory.create("#collectionfactory") - go.set_position(vmath.vector3(640, 160, 0), objects["/panthera"]) + go.set_position(vmath.vector3(480, 160, 0), objects["/panthera"]) local go_animation = panthera.create_go(PATH, nil, objects) panthera.play(go_animation, "default", { is_loop = true }) @@ -33,7 +40,7 @@ function init(self) -- But here when we create a collection from collectionfactory, inside created objects we have a collection -- So add a collection name and created objects local objects = collectionfactory.create("#collectionfactory_inner") - go.set_position(vmath.vector3(860, 160, 0), objects["/test_collection/panthera"]) + go.set_position(vmath.vector3(840, 160, 0), objects["/test_collection/panthera"]) local go_animation = panthera.create_go(PATH, "test_collection", objects) panthera.play(go_animation, "default", { is_loop = true }) end \ No newline at end of file From faaa643c96c328bc8fe8e29a36687bc66cce0d3b Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 20 Jul 2024 18:36:22 +0300 Subject: [PATCH 07/17] Update README --- README.md | 29 +++++++++++------------------ game.project | 2 +- 2 files changed, 12 insertions(+), 19 deletions(-) diff --git a/README.md b/README.md index c8a729c..166f669 100644 --- a/README.md +++ b/README.md @@ -89,8 +89,8 @@ end) ### Quick API Reference ```lua -panthera.create_gui(animation_path, [get_node]) -panthera.create_go(animation_path, [get_node]) +panthera.create_gui(animation_path, [template], [nodes]) +panthera.create_go(animation_path, [collection_name], [objects]) panthera.create(animation_path, adapter, [get_node]) panthera.clone_state(animation_state) panthera.play(animation_state, animation_id, [options]) @@ -176,22 +176,19 @@ panthera.create_gui(animation_path, [template], [nodes]) ```lua local PATH = "/animations/my_gui_animation.json" --- Run over gui on current scene +-- Create over gui on current scene local gui_animation = panthera.create_gui(PATH) --- Run over GUI template on current scene +-- Create over GUI template on current scene local gui_animation = panthera.create_gui(PATH, "template_name") --- Run over cloned GUI nodes +-- Create over cloned GUI nodes local nodes = gui.clone_tree(gui.get_node("root")) local gui_animation = panthera.create_gui(PATH, nil, nodes) --- Create animation over cloned GUI template +-- Create over cloned GUI template local nodes = gui.clone_tree(gui.get_node("template_name/root")) local gui_animation = panthera.create_gui(PATH, "template_name", nodes) - --- Using Druid: -local gui_animation = panthera.create_gui(PATH, self:get_template(), self:get_nodes()) ``` **panthera.create_go** @@ -213,30 +210,26 @@ panthera.create_go(animation_path, collection_name, objects) - **Usage Example:** -```lua -local go_animation = panthera.create_go("/animations/my_animation.json") -``` - ```lua local PATH = "/animations/my_animation.json" --- Run over objects on current scene +-- Create over objects on current scene local go_animation = panthera.create_go(PATH) --- Run over collection on current scene +-- Create over collection on current scene local go_animation = panthera.create_go(PATH, "collection_name") --- Run over object from spawned factory +-- Create over object from spawned factory -- You should create a table with mapping object to created instance. -- Instead "/pantera" use object id from animation local object = factory.create("#factory") local go_animation = panthera.create_go(PATH, nil, { [hash("/panthera")] = object }) --- Run over objects from spawned collection +-- Create over objects from spawned collection local objects = collectionfactory.create("#collectionfactory") local go_animation = panthera.create_go(PATH, nil, objects) --- Run over objects from collection inside spawned collection +-- Create over objects from collection inside spawned collection local objects = collectionfactory.create("#collectionfactory") local go_animation = panthera.create_go(PATH, "collection_name", objects) ``` diff --git a/game.project b/game.project index 321e138..aa7ed59 100644 --- a/game.project +++ b/game.project @@ -1,5 +1,5 @@ [bootstrap] -main_collection = /example/example_go_gui_templates/go/example_go_template_nodes.collectionc +main_collection = /example/example.collectionc render = /example/default.renderc [script] From 3713269910d38c713a59a3bf0aa678a4844d4a2b Mon Sep 17 00:00:00 2001 From: Insality Date: Sun, 21 Jul 2024 14:46:16 +0300 Subject: [PATCH 08/17] Update README --- README.md | 16 ++++++++-------- docs/panthera_adapter.md | 4 +++- 2 files changed, 11 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index 166f669..d0969b0 100644 --- a/README.md +++ b/README.md @@ -12,7 +12,7 @@ - **Seamless Animation Integration**: Import and use Panthera 2.0 animations directly in Defold. - **Full Animation Support**: Supports all animation features provided by Panthera 2.0, including events, animation blending, nested animations and more. -- **Flexible Usage**: Compatible with both game objects and GUI nodes in Defold, allowing for versatile application across different game elements. +- **Flexible Usage**: Compatible with both Game Objects and GUI nodes in Defold, allowing for versatile application across different game elements. - **Animation Cursor**: Provides a way to control animation manually, allowing for precise control over playback and synchronization with game events. - **Hot Reloading**: Reload animations on the fly during development, enabling rapid iteration and testing of animation assets. @@ -176,7 +176,7 @@ panthera.create_gui(animation_path, [template], [nodes]) ```lua local PATH = "/animations/my_gui_animation.json" --- Create over gui on current scene +-- Create over GUI on current scene local gui_animation = panthera.create_gui(PATH) -- Create over GUI template on current scene @@ -198,7 +198,7 @@ Load and create a game object (GO) animation state from a JSON file. The Panthera uses `sys.load_resource` to load the animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. ```lua -panthera.create_go(animation_path, collection_name, objects) +panthera.create_go(animation_path, [collection_name], [objects]) ``` - **Parameters:** @@ -219,17 +219,17 @@ local go_animation = panthera.create_go(PATH) -- Create over collection on current scene local go_animation = panthera.create_go(PATH, "collection_name") --- Create over object from spawned factory +-- Create over Game Object from spawned factory -- You should create a table with mapping object to created instance. -- Instead "/pantera" use object id from animation local object = factory.create("#factory") local go_animation = panthera.create_go(PATH, nil, { [hash("/panthera")] = object }) --- Create over objects from spawned collection +-- Create over objects from spawned collectionfactory local objects = collectionfactory.create("#collectionfactory") local go_animation = panthera.create_go(PATH, nil, objects) --- Create over objects from collection inside spawned collection +-- Create over objects from collectionfactory inside spawned collection local objects = collectionfactory.create("#collectionfactory") local go_animation = panthera.create_go(PATH, "collection_name", objects) ``` @@ -241,13 +241,13 @@ Load an animation from a JSON file and create an animation state using a specifi The Panthera uses `sys.load_resource` to load the animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. ```lua -panthera.create(animation_path, adapter, [get_node]) +panthera.create(animation_path, adapter, get_node) ``` - **Parameters:** - `animation_path`: The path to the animation JSON file. - `adapter`: An adapter object that specifies how Panthera Runtime interacts with Engine. - - `get_node` (optional): A custom function to resolve nodes by their ID. This function is used by the adapter to retrieve Defold nodes for animation. If not provided, the adapter uses its default method from adapter implementation. + - `get_node`: A custom function to resolve nodes by their ID. This function is used by the adapter to retrieve Defold nodes for animation. - **Returns:** An animation state object. This object contains the loaded animation data and state necessary for playback. Returns `nil` and an error message if the animation cannot be loaded. diff --git a/docs/panthera_adapter.md b/docs/panthera_adapter.md index 284851b..124115f 100644 --- a/docs/panthera_adapter.md +++ b/docs/panthera_adapter.md @@ -51,7 +51,9 @@ To use your custom adapter with Panthera Runtime, simply pass it when creating a ```lua local my_custom_adapter = require("path.to.my_custom_adapter") -local animation = panthera.create("/path/to/animation.json", my_custom_adapter) +local animation = panthera.create("/path/to/animation.json", my_custom_adapter, function(node_id) + return gui.get_node(node_id) +end) ``` This flexibility allows Panthera Runtime to work seamlessly with any part of Defold, ensuring that you can bring any animation from Panthera 2.0 into your game with precision and ease. From 2b3f6c2d0808fbd7611f9274d38ce94606aecb2a Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 27 Jul 2024 13:44:09 +0300 Subject: [PATCH 09/17] Add supports for animation data instead of path. Move API Reference to separate page --- API_REFERENCE.md | 410 +++++++++++++++++++++++++++++++++ README.md | 396 +------------------------------ docs_editor/README.md | 8 +- panthera/annotations.lua | 6 + panthera/panthera.lua | 25 +- panthera/panthera_internal.lua | 60 +++-- 6 files changed, 482 insertions(+), 423 deletions(-) create mode 100644 API_REFERENCE.md diff --git a/API_REFERENCE.md b/API_REFERENCE.md new file mode 100644 index 0000000..e8f4f57 --- /dev/null +++ b/API_REFERENCE.md @@ -0,0 +1,410 @@ +# API Reference + +## Setup and Initialization + +To utilize Panthera Runtime in your Defold project for playing **Panthera 2.0** animations, start by importing the Panthera Runtime module: + +```lua +local panthera = require("panthera.panthera") +``` + +## Animation Functions + +**panthera.create_gui** +--- +Load and create a GUI animation state from a JSON file or Lua table. + +The Panthera uses `sys.load_resource` to load the JSON animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. + +```lua +panthera.create_gui(animation_path_or_table, [template], [nodes]) +``` + +- **Parameters:** + - `animation_path_or_table`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_gui_animation.json`. + - `template` (optional): The GUI template id to load nodes from. Pass nil if no template is used. + - `nodes` (optional): Table with nodes from `gui.clone_tree()` function. Pass nil if nodes are not cloned. + +- **Returns:** An animation state object or `nil` if the animation cannot be loaded. + +- **Usage Example:** + +```lua +local PATH = "/animations/my_gui_animation.json" + +-- Create over GUI on current scene +local gui_animation = panthera.create_gui(PATH) + +-- Create over GUI template on current scene +local gui_animation = panthera.create_gui(PATH, "template_name") + +-- Create over cloned GUI nodes +local nodes = gui.clone_tree(gui.get_node("root")) +local gui_animation = panthera.create_gui(PATH, nil, nodes) + +-- Create over cloned GUI template +local nodes = gui.clone_tree(gui.get_node("template_name/root")) +local gui_animation = panthera.create_gui(PATH, "template_name", nodes) +``` + +```lua +-- Using Lua table with animation data +local animation_data = require("animations.my_animation_data") +local gui_animation = panthera.create_gui(animation_data) +``` + + +**panthera.create_go** +--- +Load and create a game object (GO) animation state from a JSON file or Lua table. + +The Panthera uses `sys.load_resource` to load the JSON animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. + +```lua +panthera.create_go(animation_path_or_table, [collection_name], [objects]) +``` + +- **Parameters:** + - `animation_path_or_table`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_animation.json`. + - `collection_name` (optional): The name of the collection to load objects from. Pass `nil` if no collection is used. + - `objects` (optional): Table with object ids from collectionfactory.create() function. Pass `nil` if objects are not created. + +- **Returns:** An animation state object or `nil` if the animation cannot be loaded. + +- **Usage Example:** + +```lua +local PATH = "/animations/my_animation.json" + +-- Create over objects on current scene +local go_animation = panthera.create_go(PATH) + +-- Create over collection on current scene +local go_animation = panthera.create_go(PATH, "collection_name") + +-- Create over Game Object from spawned factory +-- You should create a table with mapping object to created instance. +-- Instead "/pantera" use object id from animation +local object = factory.create("#factory") +local go_animation = panthera.create_go(PATH, nil, { [hash("/panthera")] = object }) + +-- Create over objects from spawned collectionfactory +local objects = collectionfactory.create("#collectionfactory") +local go_animation = panthera.create_go(PATH, nil, objects) + +-- Create over objects from collectionfactory inside spawned collection +local objects = collectionfactory.create("#collectionfactory") +local go_animation = panthera.create_go(PATH, "collection_name", objects) +``` + +```lua +-- Using Lua table with animation data +local animation_data = require("animations.my_animation_data") +local go_animation = panthera.create_go(animation_data) +``` + + +**panthera.create** +--- +Load an animation from a JSON file or Lua table and create an animation state using a specified adapter. This is a foundational method that `create_go` and `create_gui` build upon, allowing for generic animation creation with custom adapters. + +The Panthera uses `sys.load_resource` to load the JSON animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. + +```lua +panthera.create(animation_path_or_table, adapter, get_node) +``` + +- **Parameters:** + - `animation_path_or_table`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_animation.json`. + - `adapter`: An adapter object that specifies how Panthera Runtime interacts with Engine. + - `get_node`: A custom function to resolve nodes by their ID. This function is used by the adapter to retrieve Defold nodes for animation. + +- **Returns:** An animation state object. This object contains the loaded animation data and state necessary for playback. Returns `nil` and an error message if the animation cannot be loaded. + +- **Usage Example:** + +```lua +-- For GO animations +local adapter_go = require("panthera.adapters.adapter_go") +local go_animation_state = panthera.create("/animations/player_animation.json", adapter_go) + +-- For GUI animations +local adapter_gui = require("panthera.adapters.adapter_gui") +local gui_animation_state = panthera.create("/animations/gui_animation.json", adapter_gui) +``` + +```lua +-- Using Lua table with animation data +local adapter = require("panthera.adapters.adapter_go") +local animation_data = require("animations.my_animation_data") +local go_animation_state = panthera.create(animation_data, adapter) +``` + +This method is essential for advanced users who need to implement custom animation logic or integrate Panthera animations with non-standard Defold components. It provides the flexibility to work directly with the underlying adapters, enabling a wide range of animation functionalities. Read about Panthera adapters in the [adapter documentation](docs/panthera_adapter.md). + + +**panthera.clone_state** +--- +Clone an existing animation state object, enabling multiple instances of the same animation to play simultaneously or independently. + +```lua +panthera.clone_state(animation_state) +``` + +- **Parameters:** + - `animation_state`: The animation state object to clone. + +- **Returns:** A new animation state object that is a copy of the original. + +- **Usage Example:** + +```lua +local go_animation_state = panthera.create_go("/animations/player_animation.json") +local cloned_state = panthera.clone_state(go_animation_state) +``` + + +**panthera.play** +--- +Play an animation with specified ID and options. + +```lua +panthera.play(animation_state, animation_id, [options]) +``` + +- **Parameters:** + - `animation_state`: The animation state object returned by `create_go` or `create_gui`. + - `animation_id`: A string identifier for the animation to play. + - `options` (optional): A table of playback options, as described in the [Animation Playback Options](#animation-playback-options) section. + +- **Usage Example:** + +```lua +panthera.play(go_animation_state, "walk", { is_loop = true, speed = 1 }) +``` + +### Animation Playback Options + +Customize animation behavior in Panthera Runtime using a table of options passed to `panthera.play`. + +**Options:** + +- **`is_loop`**: Loop the animation (`true`/`false`). Triggers the callback at each loop end if set to `true`. +- **`is_skip_init`**: Start animation from its current state, skipping initial setup (`true`/`false`). +- **`is_relative`**: Apply tween values relative to the object's current state (`true`/`false`). +- **`speed`**: Playback speed multiplier (default `1`). Values >1 increase speed, <1 decrease. +- **`callback`**: Function called when the animation finishes. Receives `animation_id`. +- **`callback_event`**: Function triggered by animation events. Receives `event_id`, optional `node`, `string_value`, and `number_value`. + +- **Usage Example:** + +```lua +local options = { + is_loop = true, + speed = 1.2, + callback = function(animation_id) + print("Finished animation: " .. animation_id) + end, + callback_event = function(event_id, node, string_value, number_value) + print("Event: " .. event_id) + end +} + +panthera.play(animation_state, "animation_id", options) +``` + +These options enable precise control over animation playback, enhancing interactivity and visual dynamics in your game projects. + +**panthera.stop** +--- +Stop a currently playing animation. + +```lua +panthera.stop(animation_state) +``` + +- **Parameters:** + - `animation_state`: The animation state object to stop. + +- **Usage Example:** + +```lua +panthera.stop(go_animation_state) +``` + +**panthera.reload_animation** +--- +Reload animations from JSON files, useful for development and debugging. If no path is provided, all loaded animations are reloaded. + +The animations loaded from Lua tables will not be reloaded. + +```lua +panthera.reload_animation([animation_path]) +``` + +- **Parameters:** + - `animation_path` (optional): Specific animation to reload. If omitted, all loaded animations are reloaded. + +- **Usage Example:** + +```lua +-- Reload single animation +panthera.reload_animation("/animations/my_animation.json") + +-- Reload all loaded animations +panthera.reload_animation() +``` + +**panthera.set_time** +--- +Directly set the current playback time of an animation, useful for seeking to a specific point or synchronizing animations. + +```lua +panthera.set_time(animation_state, animation_id, time) +``` + +- **Parameters:** + - `animation_state`: The animation state object returned by `create_go` or `create_gui`. + - `animation_id`: The ID of the animation to modify. + - `time`: The target time in seconds to which the animation should be set. + +- **Usage Example:** + +```lua +-- Set the animation to start playing from 2 seconds in +panthera.set_time(self.go_animation, "run", 2) +``` + +This function stops any currently playing animation and updates the animation state to the specified time, allowing for immediate playback from that point or preparation for a triggered start. + + +**panthera.get_time** +--- +Retrieve the current playback time of an animation, useful for tracking the animation's progress or synchronizing game events. If the animation is not playing, the function returns 0. + +```lua +local time = panthera.get_time(animation_state) +``` + +- **Parameters:** + - `animation_state`: The animation state object. + +- **Returns:** The current playback time of the animation in seconds. + +- **Usage Example:** + +```lua +local time = panthera.get_time(self.go_animation) +print("Current animation time: ", time, "seconds") +``` + +**panthera.get_duration** +--- +Retrieve the total duration of a specific animation, enabling dynamic timing decisions or UI updates based on animation length. + +```lua +local duration = panthera.get_duration(animation_state, animation_id) +``` + +- **Parameters:** + - `animation_state`: The animation state object. + - `animation_id`: The ID of the animation whose duration you want to retrieve. + +- **Returns:** The total duration of the animation in seconds. + +- **Usage Example:** + +```lua +local duration = panthera.get_duration(self.go_animation, "run") +print("Total animation duration: ", duration, "seconds") +``` + +Knowing the duration of an animation is particularly useful for scheduling other events or actions to occur immediately after an animation completes, ensuring smooth transitions and cohesive gameplay experiences. + +**panthera.is_playing** +--- +Check if an animation is currently playing. + +```lua +local is_playing = panthera.is_playing(animation_state) +``` + +- **Parameters:** + - `animation_state`: The animation state object. + +- **Returns:** `true` if the animation is currently playing, `false` otherwise. + +- **Usage Example:** + +```lua +local is_playing = panthera.is_playing(self.go_animation) +if is_playing then + print("The animation is currently playing") +end +``` + +This function is useful for determining whether an animation is active and can be used to trigger other game events or actions based on the animation's state. + + +**panthera.get_latest_animation_id** +--- +Check the ID of the last animation that was started. + +```lua +local animation_id = panthera.get_latest_animation_id(animation_state) +``` + +- **Parameters:** + - `animation_state`: The animation state object. + +- **Returns:** The ID of the last animation that was started. + +- **Usage Example:** + +```lua +local animation_id = panthera.get_latest_animation_id(self.go_animation) +print("Latest started animation ID: ", animation_id) +``` + +This function is useful for tracking the last animation that was started, allowing for dynamic behavior based on the most recent animation played. + + +## Configuration Functions + +**panthera.set_logger** +--- +Customize the logging mechanism used by **Panthera Runtime**. You can use **Defold Log** library or provide a custom logger. + +```lua +panthera.set_logger(logger_instance) +``` + +- **Parameters:** + - `logger_instance`: A logger object that follows the specified logging interface, including methods for `trace`, `debug`, `info`, `warn`, `error`. Pass `nil` to remove the default logger. + +- **Usage Example:** + +Using the [Defold Log](https://github.com/Insality/defold-log) module: +```lua +local log = require("log.log") +local panthera = require("panthera.panthera") + +panthera.set_logger(log.get_logger("panthera")) +``` + +Creating a custom user logger: +```lua +local logger = { + trace = function(_, message, context) end, + debug = function(_, message, context) end, + info = function(_, message, context) end, + warn = function(_, message, context) end, + error = function(_, message, context) end +} +panthera.set_logger(logger) +``` + +Remove the default logger: +```lua +panthera.set_logger(nil) +``` diff --git a/README.md b/README.md index d0969b0..8cde1d2 100644 --- a/README.md +++ b/README.md @@ -81,7 +81,7 @@ window.set_listener(function(_, event) end) ``` -> **Note:** Hot reloading is designed for use in development environments only. +> **Note:** Hot reloading is designed for use in development environments only. Hot reloading only works for animations from JSON files. If you using a lua table for animations, hot reloading will not work. ## API Reference @@ -89,9 +89,9 @@ end) ### Quick API Reference ```lua -panthera.create_gui(animation_path, [template], [nodes]) -panthera.create_go(animation_path, [collection_name], [objects]) -panthera.create(animation_path, adapter, [get_node]) +panthera.create_gui(animation_path_or_table, [template], [nodes]) +panthera.create_go(animation_path_or_table, [collection_name], [objects]) +panthera.create(animation_path_or_table, adapter, [get_node]) panthera.clone_state(animation_state) panthera.play(animation_state, animation_id, [options]) panthera.stop(animation_state) @@ -104,394 +104,11 @@ panthera.set_logger([logger_instance]) panthera.reload_animation([animation_path]) ``` -### Setup and Initialization -To utilize Panthera Runtime in your Defold project for playing **Panthera 2.0** animations, start by importing the Panthera Runtime module: +### API Reference -```lua -local panthera = require("panthera.panthera") -``` - -### Configuration Functions - -**panthera.set_logger** ---- -Customize the logging mechanism used by Panthera Runtime. You can use **Defold Log** library or provide a custom logger. - -```lua -panthera.set_logger(logger_instance) -``` - -- **Parameters:** - - `logger_instance`: A logger object that follows the specified logging interface, including methods for `trace`, `debug`, `info`, `warn`, `error`. Pass `nil` to remove the default logger. - -- **Usage Example:** - -Using the [Defold Log](https://github.com/Insality/defold-log) module: -```lua -local log = require("log.log") -local panthera = require("panthera.panthera") - -panthera.set_logger(log.get_logger("panthera")) -``` - -Creating a custom user logger: -```lua -local logger = { - trace = function(_, message, context) end, - debug = function(_, message, context) end, - info = function(_, message, context) end, - warn = function(_, message, context) end, - error = function(_, message, context) end -} -panthera.set_logger(logger) -``` - -Remove the default logger: -```lua -panthera.set_logger(nil) -``` - -### Animation Functions - -**panthera.create_gui** ---- -Load and create a GUI animation state from a JSON file. - -The Panthera uses `sys.load_resource` to load the animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. - -```lua -panthera.create_gui(animation_path, [template], [nodes]) -``` - -- **Parameters:** - - `animation_path`: The path to the animation JSON file. Example: `/animations/my_gui_animation.json`. - - `template` (optional): The GUI template id to load nodes from. Pass nil if no template is used. - - `nodes` (optional): Table with nodes from `gui.clone_tree()` function. Pass nil if nodes are not cloned. - -- **Returns:** An animation state object or `nil` if the animation cannot be loaded. - -- **Usage Example:** - -```lua -local PATH = "/animations/my_gui_animation.json" - --- Create over GUI on current scene -local gui_animation = panthera.create_gui(PATH) - --- Create over GUI template on current scene -local gui_animation = panthera.create_gui(PATH, "template_name") - --- Create over cloned GUI nodes -local nodes = gui.clone_tree(gui.get_node("root")) -local gui_animation = panthera.create_gui(PATH, nil, nodes) - --- Create over cloned GUI template -local nodes = gui.clone_tree(gui.get_node("template_name/root")) -local gui_animation = panthera.create_gui(PATH, "template_name", nodes) -``` - -**panthera.create_go** ---- -Load and create a game object (GO) animation state from a JSON file. - -The Panthera uses `sys.load_resource` to load the animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. - -```lua -panthera.create_go(animation_path, [collection_name], [objects]) -``` - -- **Parameters:** - - `animation_path`: The path to the animation JSON file. Example: `/animations/my_animation.json`. - - `collection_name` (optional): The name of the collection to load objects from. Pass `nil` if no collection is used. - - `objects` (optional): Table with object ids from collectionfactory.create() function. Pass `nil` if objects are not created. - -- **Returns:** An animation state object or `nil` if the animation cannot be loaded. - -- **Usage Example:** - -```lua -local PATH = "/animations/my_animation.json" - --- Create over objects on current scene -local go_animation = panthera.create_go(PATH) - --- Create over collection on current scene -local go_animation = panthera.create_go(PATH, "collection_name") - --- Create over Game Object from spawned factory --- You should create a table with mapping object to created instance. --- Instead "/pantera" use object id from animation -local object = factory.create("#factory") -local go_animation = panthera.create_go(PATH, nil, { [hash("/panthera")] = object }) - --- Create over objects from spawned collectionfactory -local objects = collectionfactory.create("#collectionfactory") -local go_animation = panthera.create_go(PATH, nil, objects) - --- Create over objects from collectionfactory inside spawned collection -local objects = collectionfactory.create("#collectionfactory") -local go_animation = panthera.create_go(PATH, "collection_name", objects) -``` - -**panthera.create** ---- -Load an animation from a JSON file and create an animation state using a specified adapter. This is a foundational method that `create_go` and `create_gui` build upon, allowing for generic animation creation with custom adapters. - -The Panthera uses `sys.load_resource` to load the animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. - -```lua -panthera.create(animation_path, adapter, get_node) -``` - -- **Parameters:** - - `animation_path`: The path to the animation JSON file. - - `adapter`: An adapter object that specifies how Panthera Runtime interacts with Engine. - - `get_node`: A custom function to resolve nodes by their ID. This function is used by the adapter to retrieve Defold nodes for animation. - -- **Returns:** An animation state object. This object contains the loaded animation data and state necessary for playback. Returns `nil` and an error message if the animation cannot be loaded. - -- **Usage Example:** - -```lua --- For GO animations -local adapter_go = require("panthera.adapters.adapter_go") -local go_animation_state = panthera.create("/animations/player_animation.json", adapter_go) - --- For GUI animations -local adapter_gui = require("panthera.adapters.adapter_gui") -local gui_animation_state = panthera.create("/animations/gui_animation.json", adapter_gui) -``` - -This method is essential for advanced users who need to implement custom animation logic or integrate Panthera animations with non-standard Defold components. It provides the flexibility to work directly with the underlying adapters, enabling a wide range of animation functionalities. Read about Panthera adapters in the [adapter documentation](docs/panthera_adapter.md). - -**panthera.clone_state** ---- -Clone an existing animation state object, enabling multiple instances of the same animation to play simultaneously or independently. - -```lua -panthera.clone_state(animation_state) -``` - -- **Parameters:** - - `animation_state`: The animation state object to clone. - -- **Returns:** A new animation state object that is a copy of the original. - -- **Usage Example:** - -```lua -local go_animation_state = panthera.create_go("/animations/player_animation.json") -local cloned_state = panthera.clone_state(go_animation_state) -``` - - -**panthera.play** ---- -Play an animation with specified ID and options. - -```lua -panthera.play(animation_state, animation_id, [options]) -``` - -- **Parameters:** - - `animation_state`: The animation state object returned by `create_go` or `create_gui`. - - `animation_id`: A string identifier for the animation to play. - - `options` (optional): A table of playback options, as described in the [Animation Playback Options](#animation-playback-options) section. - -- **Usage Example:** - -```lua -panthera.play(go_animation_state, "walk", { is_loop = true, speed = 1 }) -``` - -#### Animation Playback Options - -Customize animation behavior in Panthera Runtime using a table of options passed to `panthera.play`. +Read the [API Reference](API_REFERENCE.md) file to see the full API documentation for the module. -**Options:** - -- **`is_loop`**: Loop the animation (`true`/`false`). Triggers the callback at each loop end if set to `true`. -- **`is_skip_init`**: Start animation from its current state, skipping initial setup (`true`/`false`). -- **`is_relative`**: Apply tween values relative to the object's current state (`true`/`false`). -- **`speed`**: Playback speed multiplier (default `1`). Values >1 increase speed, <1 decrease. -- **`callback`**: Function called when the animation finishes. Receives `animation_id`. -- **`callback_event`**: Function triggered by animation events. Receives `event_id`, optional `node`, `string_value`, and `number_value`. - -- **Usage Example:** - -```lua -local options = { - is_loop = true, - speed = 1.2, - callback = function(animation_id) - print("Finished animation: " .. animation_id) - end, - callback_event = function(event_id, node, string_value, number_value) - print("Event: " .. event_id) - end -} - -panthera.play(animation_state, "animation_id", options) -``` - -These options enable precise control over animation playback, enhancing interactivity and visual dynamics in your game projects. - -**panthera.stop** ---- -Stop a currently playing animation. - -```lua -panthera.stop(animation_state) -``` - -- **Parameters:** - - `animation_state`: The animation state object to stop. - -- **Usage Example:** - -```lua -panthera.stop(go_animation_state) -``` - -**panthera.reload_animation** ---- -Reload animations from JSON files, useful for development and debugging. - -```lua -panthera.reload_animation([animation_path]) -``` - -- **Parameters:** - - `animation_path` (optional): Specific animation to reload. If omitted, all loaded animations are reloaded. - -- **Usage Example:** - -```lua --- Reload single animation -panthera.reload_animation("/animations/my_animation.json") - --- Reload all loaded animations -panthera.reload_animation() -``` - -**panthera.set_time** ---- -Directly set the current playback time of an animation, useful for seeking to a specific point or synchronizing animations. - -```lua -panthera.set_time(animation_state, animation_id, time) -``` - -- **Parameters:** - - `animation_state`: The animation state object returned by `create_go` or `create_gui`. - - `animation_id`: The ID of the animation to modify. - - `time`: The target time in seconds to which the animation should be set. - -- **Usage Example:** - -```lua --- Set the animation to start playing from 2 seconds in -panthera.set_time(self.go_animation, "run", 2) -``` - -This function stops any currently playing animation and updates the animation state to the specified time, allowing for immediate playback from that point or preparation for a triggered start. - - -**panthera.get_time** ---- -Retrieve the current playback time of an animation, useful for tracking the animation's progress or synchronizing game events. If the animation is not playing, the function returns 0. - -```lua -local time = panthera.get_time(animation_state) -``` - -- **Parameters:** - - `animation_state`: The animation state object. - -- **Returns:** The current playback time of the animation in seconds. - -- **Usage Example:** - -```lua -local time = panthera.get_time(self.go_animation) -print("Current animation time: ", time, "seconds") -``` - -**panthera.get_duration** ---- -Retrieve the total duration of a specific animation, enabling dynamic timing decisions or UI updates based on animation length. - -```lua -local duration = panthera.get_duration(animation_state, animation_id) -``` - -- **Parameters:** - - `animation_state`: The animation state object. - - `animation_id`: The ID of the animation whose duration you want to retrieve. - -- **Returns:** The total duration of the animation in seconds. - -- **Usage Example:** - -```lua -local duration = panthera.get_duration(self.go_animation, "run") -print("Total animation duration: ", duration, "seconds") -``` - -Knowing the duration of an animation is particularly useful for scheduling other events or actions to occur immediately after an animation completes, ensuring smooth transitions and cohesive gameplay experiences. - -**panthera.is_playing** ---- -Check if an animation is currently playing. - -```lua -local is_playing = panthera.is_playing(animation_state) -``` - -- **Parameters:** - - `animation_state`: The animation state object. - -- **Returns:** `true` if the animation is currently playing, `false` otherwise. - -- **Usage Example:** - -```lua -local is_playing = panthera.is_playing(self.go_animation) -if is_playing then - print("The animation is currently playing") -end -``` - -This function is useful for determining whether an animation is active and can be used to trigger other game events or actions based on the animation's state. - - -**panthera.get_latest_animation_id** ---- -Check the ID of the last animation that was started. - -```lua -local animation_id = panthera.get_latest_animation_id(animation_state) -``` - - -- **Parameters:** - - `animation_state`: The animation state object. - -- **Returns:** The ID of the last animation that was started. - -- **Usage Example:** - -```lua -local animation_id = panthera.get_latest_animation_id(self.go_animation) -print("Latest started animation ID: ", animation_id) -``` - -This function is useful for tracking the last animation that was started, allowing for dynamic behavior based on the most recent animation played. - ---- - -These functions provide a comprehensive interface for integrating and controlling Panthera 2.0 animations within Defold projects, enhancing the visual fidelity and interactivity of your games. ### Usage Examples @@ -582,6 +199,7 @@ Panthera Runtime is licensed under the MIT License - see the [LICENSE](/LICENSE) For any issues, questions, or suggestions, please [create an issue](https://github.com/Insality/panthera/issues). + ## Changelog Read the [CHANGELOG](/CHANGELOG.md) to learn about the latest updates and features in Panthera Runtime. diff --git a/docs_editor/README.md b/docs_editor/README.md index 3608f5c..da5a6c2 100644 --- a/docs_editor/README.md +++ b/docs_editor/README.md @@ -8,18 +8,18 @@ **Panthera 2.0 Editor** is a cross-platform animation software solution developed using the [Defold](https://defold.com/) engine, with the goal of streamlining the process of designing layouts and animations for game projects. -Integrated tightly with Defold, Panthera allows the import of `.gui` files, which can then be animated directly within the editor interface. This tool offers support for various animation techniques, including tweening, triggering, events, and animation keys, allowing users to create complex animations effortlessly. +Integrated tightly with Defold, Panthera allows the import of **Defold** files, which can then be animated directly within the editor interface. This tool offers support for various animation techniques, including tweening, triggering, events, and animation keys, allowing users to create complex animations effortlessly. -**Panthera 2.0 Editor** uses a simple animation [JSON format](/docs_editor/animation_data_format.md) for animation files. If you are not using Defold, the animation runtime can be easily implemented in any game engine or framework. +**Panthera 2.0 Editor** uses a simple [animation format](/docs_editor/animation_data_format.md) for animation files. If you are not using Defold, the animation runtime can be easily implemented in any game engine or framework. ## Features - **Intuitive Layout Creation**: Design and arrange your scene elements effortlessly. - **Advanced Animation Tools**: Craft smooth and complex animations to bring your game to life. -- **Simple Animation Format**: Export animations in a simple [JSON format](/docs_editor/animation_data_format.md) for easy integration into your projects. +- **Simple Animation Format**: Export animations in a simple [JSON format](/docs_editor/animation_data_format.md) or as Lua table for easy integration into your projects. - **Compact Size**: Lightweight and easy to install, with no additional dependencies required. -- **Defold Tight Integration**: Seamlessly import **Defold** `*.gui` files for direct animation within the editor. +- **Defold Tight Integration**: Seamlessly import **Defold** `*.gui`, `*.go` and `*.collection` files for direct animation within the editor. ## Animation Editor Features diff --git a/panthera/annotations.lua b/panthera/annotations.lua index 3d64128..e709fe4 100644 --- a/panthera/annotations.lua +++ b/panthera/annotations.lua @@ -18,6 +18,12 @@ ---@field group_animation_keys table>> @group_animation_keys[animation_id][node_id][property_id]: keys[]. Value filled at loading animation data ---@field animations_dict table @animations_dict[animation_id]: animation. Value filled at loading animation data +---@class panthera.animation.project_file +---@field data panthera.animation.data @Animation data +---@field format string @Animation format +---@field version string @Animation version +---@field type string @Animation type. Example: "animation_editor", "atlas" + ---@class panthera.animation.data.animation_key ---@field key_type string ---@field node_id string diff --git a/panthera/panthera.lua b/panthera/panthera.lua index 1ebc420..c11d8c6 100644 --- a/panthera/panthera.lua +++ b/panthera/panthera.lua @@ -13,36 +13,37 @@ function M.set_logger(logger_instance) end ----Load animation from JSON file and create it with Panthera GO adapter ----@param animation_path string +---Load animation from JSON file or direct data and create it with Panthera GO adapter +---@param animation_path_or_table string|table @Path to JSON animation file in custom resources or table with animation data ---@param collection_name string|nil @Collection name to load nodes from. Pass nil if no collection is used ---@param objects table|nil @Table with game objects from collectionfactory. Pass nil if no objects are used ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message -function M.create_go(animation_path, collection_name, objects) +function M.create_go(animation_path_or_table, collection_name, objects) local get_node = adapter_go.create_get_node_function(collection_name, objects) - return M.create(animation_path, adapter_go, get_node) + return M.create(animation_path_or_table, adapter_go, get_node) end ----Load animation from JSON file and create it with Panthera GUI adapter ----@param animation_path string +---Load animation from JSON file or direct data and create it with Panthera GUI adapter +---@param animation_path_or_table string|table @Path to JSON animation file in custom resources or table with animation data ---@param template string|nil @The GUI template id to load nodes from. Pass nil if no template is used ---@param nodes table|nil @Table with nodes from gui.clone_tree() function. Pass nil if no nodes are used ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message -function M.create_gui(animation_path, template, nodes) +function M.create_gui(animation_path_or_table, template, nodes) local get_node = adapter_gui.create_get_node_function(template, nodes) - return M.create(animation_path, adapter_gui, get_node) + return M.create(animation_path_or_table, adapter_gui, get_node) end ---Load animation from JSON file ----@param animation_path string +---@param animation_path_or_table string|table @Path to JSON animation file in custom resources or table with animation data ---@param adapter panthera.adapter ---@param get_node (fun(node_id: string): node) @Function to get node by node_id. Default is defined in adapter ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message -function M.create(animation_path, adapter, get_node) - local animation_data, error_reason = panthera_internal.load(animation_path, false) - if not animation_data then +function M.create(animation_path_or_table, adapter, get_node) + local animation_data, animation_path, error_reason = panthera_internal.load(animation_path_or_table, false) + + if not animation_data or not animation_path then panthera_internal.logger:error("Can't load Panthera animation", error_reason) return nil end diff --git a/panthera/panthera_internal.lua b/panthera/panthera_internal.lua index b8d3102..88982c5 100644 --- a/panthera/panthera_internal.lua +++ b/panthera/panthera_internal.lua @@ -24,32 +24,56 @@ M.logger = { } ----@type table +---The list of loaded animations. +---@type table @Animation path -> animation data M.LOADED_ANIMATIONS = {} +-- The list of animations that loaded directly from the table. We can't reload them on runtime, and we should not clear them on hot reload +---@type table @Animation fake path -> true +M.INLINE_ANIMATIONS = {} + M.PROJECT_FOLDER = nil -- Current game project folder, used for hot reload animations in debug mode M.IS_HOTRELOAD_ANIMATIONS = nil local IS_DEBUG = sys.get_engine_info().is_debug ---Load animation from file and store it in cache ----@param animation_path string ----@param is_cache_reset boolean @If true - animation will be reloaded from file ----@return panthera.animation.data|nil, string|nil @animation_data, error_reason -function M.load(animation_path, is_cache_reset) - if is_cache_reset then +---@param animation_path_or_table string|panthera.animation.project_file @Path to the animation file or animation table +---@param is_cache_reset boolean @If true - animation will be reloaded from file. Will be ignored for inline animations +---@return panthera.animation.data|nil, string|nil, string|nil @animation_data, animation_path, error_reason. +function M.load(animation_path_or_table, is_cache_reset) + -- If we have already loaded animation table + local is_table = type(animation_path_or_table) == "table" + if is_table then + local animation_path = M._get_fake_animation_path() + local project_data = animation_path_or_table --[[@as panthera.animation.project_file]] + + local data = project_data.data + M._preprocess_animation_keys(data) + M.LOADED_ANIMATIONS[animation_path] = data + M.INLINE_ANIMATIONS[animation_path] = true + + return data, animation_path, nil + end + + -- If we have path to the file + assert(type(animation_path_or_table) == "string", "Path should be a string") + local animation_path = animation_path_or_table --[[@as string]] + local is_inline_animation = M.INLINE_ANIMATIONS[animation_path] + if is_cache_reset and not is_inline_animation then M.LOADED_ANIMATIONS[animation_path] = nil end if not M.LOADED_ANIMATIONS[animation_path] then local animation, error_reason = M._get_animation_by_path(animation_path) if not animation then - return nil, error_reason + return nil, nil, error_reason end + M._preprocess_animation_keys(animation) M.LOADED_ANIMATIONS[animation_path] = animation end - return M.LOADED_ANIMATIONS[animation_path], nil + return M.LOADED_ANIMATIONS[animation_path], animation_path, nil end @@ -455,16 +479,13 @@ function M._get_animation_by_path(path) return nil, error end + resource = resource --[[@as panthera.animation.project_file]] local filetype = resource.type if filetype ~= "animation_editor" then return nil, "The JSON file is not an animation editor file" end - ---@type panthera.animation.data - local data = resource.data - M._preprocess_animation_keys(data) - - return data, nil + return resource.data, nil end @@ -568,17 +589,13 @@ end ---Get current application folder (only desktop) ---@return string|nil @Current application folder, nil if failed function M._get_current_game_project_folder() - local tmpfile = os.tmpname() - os.execute("pwd > " .. tmpfile) - - local file = io.open(tmpfile, "r") + local file = io.popen("pwd") if not file then return nil end local pwd = file:read("*l") file:close() - os.remove(tmpfile) if not pwd then return nil @@ -596,6 +613,13 @@ function M._get_current_game_project_folder() end +local path_counter = 0 +function M._get_fake_animation_path() + path_counter = path_counter + 1 + return "panthera_animation_table_" .. path_counter +end + + -- Init hot reload animations if IS_DEBUG then M.IS_HOTRELOAD_ANIMATIONS = sys.get_config_int("panthera.hotreload_animations", 0) == 1 From 03226e55f6cc0b062c7c0e884d0815ace53ba413 Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 27 Jul 2024 13:46:13 +0300 Subject: [PATCH 10/17] Add TOC to API Reference --- API_REFERENCE.md | 19 +++++++++++++++++++ README.md | 2 +- 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/API_REFERENCE.md b/API_REFERENCE.md index e8f4f57..ff809bb 100644 --- a/API_REFERENCE.md +++ b/API_REFERENCE.md @@ -1,5 +1,24 @@ # API Reference +## Table of Contents + +- [Setup and Initialization](#setup-and-initialization) +- [Animation Functions](#animation-functions) + - [panthera.create_gui](#pantheracreate_gui) + - [panthera.create_go](#pantheracreate_go) + - [panthera.create](#pantheracreate) + - [panthera.clone_state](#pantheraclone_state) + - [panthera.play](#pantheraplay) + - [panthera.stop](#pantherastop) + - [panthera.reload_animation](#pantherareload_animation) + - [panthera.set_time](#pantheraset_time) + - [panthera.get_time](#pantheraget_time) + - [panthera.get_duration](#pantheraget_duration) + - [panthera.is_playing](#pantherais_playing) + - [panthera.get_latest_animation_id](#pantheraget_latest_animation_id) +- [Configuration Functions](#configuration-functions) + - [panthera.set_logger](#pantheraset_logger) + ## Setup and Initialization To utilize Panthera Runtime in your Defold project for playing **Panthera 2.0** animations, start by importing the Panthera Runtime module: diff --git a/README.md b/README.md index 8cde1d2..d557ab6 100644 --- a/README.md +++ b/README.md @@ -91,7 +91,7 @@ end) ```lua panthera.create_gui(animation_path_or_table, [template], [nodes]) panthera.create_go(animation_path_or_table, [collection_name], [objects]) -panthera.create(animation_path_or_table, adapter, [get_node]) +panthera.create(animation_path_or_table, adapter, get_node) panthera.clone_state(animation_state) panthera.play(animation_state, animation_id, [options]) panthera.stop(animation_state) From 594636cd703ee15fbffb660c57461a84e67449d4 Mon Sep 17 00:00:00 2001 From: Insality Date: Sun, 28 Jul 2024 18:50:59 +0300 Subject: [PATCH 11/17] Add changelog v3 --- CHANGELOG.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index a5164e5..8b78177 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -18,3 +18,17 @@ Initial resease! - The default sprite color property is `tint`. To use panthera color property, use `/panthera/materials/sprite.material` or any other with `color` property. - GUI: fix slice9 property. - GUI: fix for pie vertices and piebounds properties. + + +## Version v3 + +- **BREAKING CHANGES**: Change `panthera.create_go` and `panthera.create_gui` functions signature. + - Now `panthera.create_go(animation_path_or_table, [collection_name], [objects])` instead of `panthera.create_go(animation_path, [get_node)`. + - Now `panthera.create_gui(animation_path_or_table, [template_name], [nodes])` instead of `panthera.create_gui(animation_path, [get_node])`. + - Animation now can be created with a table with animation data directly. You can load JSON by yourself or load it from lua table. + - Instead of `get_node` parameter, you should pass template/collection name and nodes/objects table. Nodes are created from `gui.clone_tree`, objects are created from `collectionfactory.create`. + - To migrate to new version, you should modify your code to the new signature, or create animations with `panthera.create(animation_path_or_table, adapter, get_node)` function. Adapter can be obtained by `require("panthera.adapters.adapter_[go|gui]")`. +- Update documentation. +- Add more examples with running animations in different scenarios. +- The `animation_state` table now contains `animation_id`, instead of `animation` table data. It will be better to log/pprint the animation state. +- Rename file `panthera_system` to `panthera_internal`. From 7b4434e8ab0a8c984a57dc37e0a25b7671c07fc2 Mon Sep 17 00:00:00 2001 From: Insality Date: Sun, 28 Jul 2024 21:19:11 +0300 Subject: [PATCH 12/17] Fix GUI collection example --- .../gui/example_gui_template_nodes.collection | 40 ------------------- 1 file changed, 40 deletions(-) diff --git a/example/example_go_gui_templates/gui/example_gui_template_nodes.collection b/example/example_go_gui_templates/gui/example_gui_template_nodes.collection index a89ef60..ad71c56 100644 --- a/example/example_go_gui_templates/gui/example_gui_template_nodes.collection +++ b/example/example_go_gui_templates/gui/example_gui_template_nodes.collection @@ -1,24 +1,4 @@ name: "example_go_gui_templates" -collection_instances { - id: "test_collection" - collection: "/example/example_go_gui_templates/go/example_go_template_nodes.collection" - position { - x: 0.0 - y: 0.0 - z: 0.0 - } - rotation { - x: 0.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - scale3 { - x: 1.0 - y: 1.0 - z: 1.0 - } -} scale_along_z: 0 embedded_instances { id: "gui" @@ -57,23 +37,3 @@ embedded_instances { z: 1.0 } } -embedded_instances { - id: "test_go" - data: "" - position { - x: 0.0 - y: 0.0 - z: 0.0 - } - rotation { - x: 0.0 - y: 0.0 - z: 0.0 - w: 1.0 - } - scale3 { - x: 1.0 - y: 1.0 - z: 1.0 - } -} From 93fdfb820a39fde4ce724b3c5cd1ca10a00d16e7 Mon Sep 17 00:00:00 2001 From: Insality Date: Mon, 29 Jul 2024 20:12:11 +0300 Subject: [PATCH 13/17] Rename animation_path_or_table -> animation_path_or_data --- API_REFERENCE.md | 12 ++++++------ CHANGELOG.md | 10 +++++----- README.md | 6 +++--- panthera/panthera.lua | 18 +++++++++--------- panthera/panthera_internal.lua | 12 ++++++------ 5 files changed, 29 insertions(+), 29 deletions(-) diff --git a/API_REFERENCE.md b/API_REFERENCE.md index ff809bb..17402b4 100644 --- a/API_REFERENCE.md +++ b/API_REFERENCE.md @@ -36,11 +36,11 @@ Load and create a GUI animation state from a JSON file or Lua table. The Panthera uses `sys.load_resource` to load the JSON animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. ```lua -panthera.create_gui(animation_path_or_table, [template], [nodes]) +panthera.create_gui(animation_path_or_data, [template], [nodes]) ``` - **Parameters:** - - `animation_path_or_table`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_gui_animation.json`. + - `animation_path_or_data`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_gui_animation.json`. - `template` (optional): The GUI template id to load nodes from. Pass nil if no template is used. - `nodes` (optional): Table with nodes from `gui.clone_tree()` function. Pass nil if nodes are not cloned. @@ -80,11 +80,11 @@ Load and create a game object (GO) animation state from a JSON file or Lua table The Panthera uses `sys.load_resource` to load the JSON animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. ```lua -panthera.create_go(animation_path_or_table, [collection_name], [objects]) +panthera.create_go(animation_path_or_data, [collection_name], [objects]) ``` - **Parameters:** - - `animation_path_or_table`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_animation.json`. + - `animation_path_or_data`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_animation.json`. - `collection_name` (optional): The name of the collection to load objects from. Pass `nil` if no collection is used. - `objects` (optional): Table with object ids from collectionfactory.create() function. Pass `nil` if objects are not created. @@ -130,11 +130,11 @@ Load an animation from a JSON file or Lua table and create an animation state us The Panthera uses `sys.load_resource` to load the JSON animation file. Place your animation files inside your [custom resources folder](https://defold.com/manuals/project-settings/#custom-resources) to ensure they are included in the build. ```lua -panthera.create(animation_path_or_table, adapter, get_node) +panthera.create(animation_path_or_data, adapter, get_node) ``` - **Parameters:** - - `animation_path_or_table`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_animation.json`. + - `animation_path_or_data`: The path to the animation JSON file or a table with animation data. Example: `/animations/my_animation.json`. - `adapter`: An adapter object that specifies how Panthera Runtime interacts with Engine. - `get_node`: A custom function to resolve nodes by their ID. This function is used by the adapter to retrieve Defold nodes for animation. diff --git a/CHANGELOG.md b/CHANGELOG.md index 8b78177..b6b794c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -23,12 +23,12 @@ Initial resease! ## Version v3 - **BREAKING CHANGES**: Change `panthera.create_go` and `panthera.create_gui` functions signature. - - Now `panthera.create_go(animation_path_or_table, [collection_name], [objects])` instead of `panthera.create_go(animation_path, [get_node)`. - - Now `panthera.create_gui(animation_path_or_table, [template_name], [nodes])` instead of `panthera.create_gui(animation_path, [get_node])`. + - Now `panthera.create_go(animation_path_or_data, [collection_name], [objects])` instead of `panthera.create_go(animation_path, [get_node)`. + - Now `panthera.create_gui(animation_path_or_data, [template_name], [nodes])` instead of `panthera.create_gui(animation_path, [get_node])`. - Animation now can be created with a table with animation data directly. You can load JSON by yourself or load it from lua table. - Instead of `get_node` parameter, you should pass template/collection name and nodes/objects table. Nodes are created from `gui.clone_tree`, objects are created from `collectionfactory.create`. - - To migrate to new version, you should modify your code to the new signature, or create animations with `panthera.create(animation_path_or_table, adapter, get_node)` function. Adapter can be obtained by `require("panthera.adapters.adapter_[go|gui]")`. + - To migrate to new version, you should modify your code to the new signature, or create animations with `panthera.create(animation_path_or_data, adapter, get_node)` function. Adapter can be obtained by `require("panthera.adapters.adapter_[go|gui]")`. +- Add more examples with playing animations in different scenarios. - Update documentation. -- Add more examples with running animations in different scenarios. -- The `animation_state` table now contains `animation_id`, instead of `animation` table data. It will be better to log/pprint the animation state. +- The `animation_state` table now contains `animation_id`, instead of `animation` table data. It will be better to log or `pprint` the animation state. - Rename file `panthera_system` to `panthera_internal`. diff --git a/README.md b/README.md index d557ab6..e3a6c85 100644 --- a/README.md +++ b/README.md @@ -89,9 +89,9 @@ end) ### Quick API Reference ```lua -panthera.create_gui(animation_path_or_table, [template], [nodes]) -panthera.create_go(animation_path_or_table, [collection_name], [objects]) -panthera.create(animation_path_or_table, adapter, get_node) +panthera.create_gui(animation_path_or_data, [template], [nodes]) +panthera.create_go(animation_path_or_data, [collection_name], [objects]) +panthera.create(animation_path_or_data, adapter, get_node) panthera.clone_state(animation_state) panthera.play(animation_state, animation_id, [options]) panthera.stop(animation_state) diff --git a/panthera/panthera.lua b/panthera/panthera.lua index c11d8c6..899e802 100644 --- a/panthera/panthera.lua +++ b/panthera/panthera.lua @@ -14,34 +14,34 @@ end ---Load animation from JSON file or direct data and create it with Panthera GO adapter ----@param animation_path_or_table string|table @Path to JSON animation file in custom resources or table with animation data +---@param animation_path_or_data string|table @Path to JSON animation file in custom resources or table with animation data ---@param collection_name string|nil @Collection name to load nodes from. Pass nil if no collection is used ---@param objects table|nil @Table with game objects from collectionfactory. Pass nil if no objects are used ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message -function M.create_go(animation_path_or_table, collection_name, objects) +function M.create_go(animation_path_or_data, collection_name, objects) local get_node = adapter_go.create_get_node_function(collection_name, objects) - return M.create(animation_path_or_table, adapter_go, get_node) + return M.create(animation_path_or_data, adapter_go, get_node) end ---Load animation from JSON file or direct data and create it with Panthera GUI adapter ----@param animation_path_or_table string|table @Path to JSON animation file in custom resources or table with animation data +---@param animation_path_or_data string|table @Path to JSON animation file in custom resources or table with animation data ---@param template string|nil @The GUI template id to load nodes from. Pass nil if no template is used ---@param nodes table|nil @Table with nodes from gui.clone_tree() function. Pass nil if no nodes are used ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message -function M.create_gui(animation_path_or_table, template, nodes) +function M.create_gui(animation_path_or_data, template, nodes) local get_node = adapter_gui.create_get_node_function(template, nodes) - return M.create(animation_path_or_table, adapter_gui, get_node) + return M.create(animation_path_or_data, adapter_gui, get_node) end ---Load animation from JSON file ----@param animation_path_or_table string|table @Path to JSON animation file in custom resources or table with animation data +---@param animation_path_or_data string|table @Path to JSON animation file in custom resources or table with animation data ---@param adapter panthera.adapter ---@param get_node (fun(node_id: string): node) @Function to get node by node_id. Default is defined in adapter ---@return panthera.animation.state|nil @Animation data or nil if animation can't be loaded, error message -function M.create(animation_path_or_table, adapter, get_node) - local animation_data, animation_path, error_reason = panthera_internal.load(animation_path_or_table, false) +function M.create(animation_path_or_data, adapter, get_node) + local animation_data, animation_path, error_reason = panthera_internal.load(animation_path_or_data, false) if not animation_data or not animation_path then panthera_internal.logger:error("Can't load Panthera animation", error_reason) diff --git a/panthera/panthera_internal.lua b/panthera/panthera_internal.lua index 88982c5..c37799e 100644 --- a/panthera/panthera_internal.lua +++ b/panthera/panthera_internal.lua @@ -37,15 +37,15 @@ M.IS_HOTRELOAD_ANIMATIONS = nil local IS_DEBUG = sys.get_engine_info().is_debug ---Load animation from file and store it in cache ----@param animation_path_or_table string|panthera.animation.project_file @Path to the animation file or animation table +---@param animation_path_or_data string|panthera.animation.project_file @Path to the animation file or animation table ---@param is_cache_reset boolean @If true - animation will be reloaded from file. Will be ignored for inline animations ---@return panthera.animation.data|nil, string|nil, string|nil @animation_data, animation_path, error_reason. -function M.load(animation_path_or_table, is_cache_reset) +function M.load(animation_path_or_data, is_cache_reset) -- If we have already loaded animation table - local is_table = type(animation_path_or_table) == "table" + local is_table = type(animation_path_or_data) == "table" if is_table then local animation_path = M._get_fake_animation_path() - local project_data = animation_path_or_table --[[@as panthera.animation.project_file]] + local project_data = animation_path_or_data --[[@as panthera.animation.project_file]] local data = project_data.data M._preprocess_animation_keys(data) @@ -56,8 +56,8 @@ function M.load(animation_path_or_table, is_cache_reset) end -- If we have path to the file - assert(type(animation_path_or_table) == "string", "Path should be a string") - local animation_path = animation_path_or_table --[[@as string]] + assert(type(animation_path_or_data) == "string", "Path should be a string") + local animation_path = animation_path_or_data --[[@as string]] local is_inline_animation = M.INLINE_ANIMATIONS[animation_path] if is_cache_reset and not is_inline_animation then M.LOADED_ANIMATIONS[animation_path] = nil From 30e1678a045088a8ea15d6e15e7c30d8c0372de9 Mon Sep 17 00:00:00 2001 From: Insality Date: Wed, 31 Jul 2024 00:45:39 +0300 Subject: [PATCH 14/17] Add is_editor_only timeline key property --- docs_editor/getting_started.md | 2 +- panthera/annotations.lua | 1 + panthera/panthera.lua | 2 +- panthera/panthera_internal.lua | 6 +++++- 4 files changed, 8 insertions(+), 3 deletions(-) diff --git a/docs_editor/getting_started.md b/docs_editor/getting_started.md index 11bf79a..b671dcc 100644 --- a/docs_editor/getting_started.md +++ b/docs_editor/getting_started.md @@ -50,7 +50,7 @@ Quickly dive into creating animations with **Panthera Editor 2.0** using this st Here are some fast helpful tips and reminders for using Panthera Editor: -- To create animation you have to create a layout with nodes in **Layout mode** (or export GUI layout from **[Defold](https://defold.com/)** project). +- To create animation you have to create a layout with nodes in **Layout mode** (or export GUI/Collection/GO layout from **[Defold](https://defold.com/)** project). - Then layout created, you can switch to **Animation mode** and start making animations. - Pan the editor view by holding `Ctrl` or `Alt` and dragging the view. - Property names in 🔸 orange indicate unapplied changes. ![changed_property](/docs_editor/media/icon_changed_property.png) diff --git a/panthera/annotations.lua b/panthera/annotations.lua index e709fe4..66bd709 100644 --- a/panthera/annotations.lua +++ b/panthera/annotations.lua @@ -36,6 +36,7 @@ ---@field start_data string ---@field data string ---@field event_id string +---@field is_editor_only boolean ---@class panthera.animation.state ---@field adapter panthera.adapter @Adapter to use for animation diff --git a/panthera/panthera.lua b/panthera/panthera.lua index 899e802..11694dd 100644 --- a/panthera/panthera.lua +++ b/panthera/panthera.lua @@ -58,9 +58,9 @@ function M.create(animation_path_or_data, adapter, get_node) animation = nil, current_time = 0, adapter = adapter, + get_node = get_node, animation_keys_index = 1, animation_path = animation_path, - get_node = get_node, } return animation_state diff --git a/panthera/panthera_internal.lua b/panthera/panthera_internal.lua index c37799e..bf330ce 100644 --- a/panthera/panthera_internal.lua +++ b/panthera/panthera_internal.lua @@ -516,7 +516,7 @@ function M._preprocess_animation_keys(data) for index = 1, #data.animations do local animation = data.animations[index] - for key_index = 1, #animation.animation_keys do + for key_index = #animation.animation_keys, 1, -1 do -- These default keys can be nil local key = animation.animation_keys[key_index] key.start_value = key.start_value or 0 @@ -524,6 +524,10 @@ function M._preprocess_animation_keys(data) key.end_value = key.end_value or 0 key.duration = key.duration or 0 key.node_id = key.node_id or "" + + if key.is_editor_only then + table.remove(animation.animation_keys, key_index) + end end table.sort(animation.animation_keys, M._sort_keys_function) From ca4c34aca6c148a794a040213358818133aa4b7e Mon Sep 17 00:00:00 2001 From: Insality Date: Thu, 1 Aug 2024 00:08:51 +0300 Subject: [PATCH 15/17] Add supports for custom easings --- game.project | 4 ++-- panthera/adapters/adapter_go.lua | 2 +- panthera/adapters/adapter_gui.lua | 2 +- panthera/annotations.lua | 3 ++- panthera/panthera_internal.lua | 12 +++++++++--- 5 files changed, 15 insertions(+), 8 deletions(-) diff --git a/game.project b/game.project index aa7ed59..aa3a748 100644 --- a/game.project +++ b/game.project @@ -18,8 +18,8 @@ version = 2.0 publisher = Insality developer = Maksim Tuprikov, Insality custom_resources = /resources -dependencies#0 = https://github.com/Insality/defold-tweener/archive/refs/tags/2.zip -dependencies#1 = https://github.com/Insality/defold-log/archive/refs/tags/2.zip +dependencies#0 = https://github.com/Insality/defold-log/archive/refs/tags/2.zip +dependencies#1 = https://github.com/Insality/defold-tweener/archive/refs/tags/3.zip [library] include_dirs = panthera diff --git a/panthera/adapters/adapter_go.lua b/panthera/adapters/adapter_go.lua index ba52295..a0267f0 100644 --- a/panthera/adapters/adapter_go.lua +++ b/panthera/adapters/adapter_go.lua @@ -236,7 +236,7 @@ end ---@param node node ---@param property_id string ----@param easing userdata +---@param easing userdata|number[] ---@param duration number ---@param end_value number local function tween_animation_key(node, property_id, easing, duration, end_value) diff --git a/panthera/adapters/adapter_gui.lua b/panthera/adapters/adapter_gui.lua index d16771b..3a401a4 100644 --- a/panthera/adapters/adapter_gui.lua +++ b/panthera/adapters/adapter_gui.lua @@ -391,7 +391,7 @@ end ---@param node node ---@param property_id string ----@param easing userdata +---@param easing userdata|number[] ---@param duration number ---@param end_value number local function tween_animation_key(node, property_id, easing, duration, end_value) diff --git a/panthera/annotations.lua b/panthera/annotations.lua index 66bd709..a3012a7 100644 --- a/panthera/annotations.lua +++ b/panthera/annotations.lua @@ -33,6 +33,7 @@ ---@field start_value number ---@field end_value number ---@field easing string +---@field easing_custom number[]|nil ---@field start_data string ---@field data string ---@field event_id string @@ -62,7 +63,7 @@ ---@class panthera.adapter ---@field get_node fun(node_id: string): node @Function to get node by node_id. ---@field get_easing fun(easing_id: string): hash @Function to get defold easing by easing_id. Default is gui.EASING ----@field tween_animation_key fun(node: node, property_id: string, easing: hash, duration: number, end_value: number): nil @Function to tween animation key. +---@field tween_animation_key fun(node: node, property_id: string, easing: hash|number[], duration: number, end_value: number): nil @Function to tween animation key. ---@field trigger_animation_key fun(node: node, property_id: string, value: any): nil @Function to trigger animation key. ---@field event_animation_key fun(node: node, key: panthera.animation.data.animation_key): nil @Function to trigger event in animation. ---@field set_node_property fun(node: node, property_id: string, value: number|string): boolean @Function to set node property. Return true if success diff --git a/panthera/panthera_internal.lua b/panthera/panthera_internal.lua index bf330ce..1cd45fd 100644 --- a/panthera/panthera_internal.lua +++ b/panthera/panthera_internal.lua @@ -316,7 +316,7 @@ function M.run_timeline_key(animation_state, key, options) local node = M.get_node(animation_state, key.node_id) if node and key.key_type == "tween" then - local easing = adapter.get_easing(key.easing) + local easing = key.easing_custom or adapter.get_easing(key.easing) local delta = key.end_value - key.start_value local start_value = key.start_value @@ -358,7 +358,7 @@ function M.event_animation_key(node, key, callback_event) if key.duration == 0 then callback_event(key.event_id, node, key.data, key.end_value) else - local easing = tweener[key.easing] or tweener.linear + local easing = key.easing_custom or tweener[key.easing] or tweener.linear tweener.tween(easing, key.start_value, key.end_value, key.duration, function(value) callback_event(key.event_id, node, key.data, value) end) @@ -525,9 +525,15 @@ function M._preprocess_animation_keys(data) key.duration = key.duration or 0 key.node_id = key.node_id or "" + -- Remove editor only keys, they are used only in Panthera Editor to preview animations if key.is_editor_only then table.remove(animation.animation_keys, key_index) end + + -- Custom easings have more priority than easing and Defold requires vector for custom easing + if key.easing_custom then + key.easing_custom = vmath.vector(key.easing_custom) + end end table.sort(animation.animation_keys, M._sort_keys_function) @@ -583,7 +589,7 @@ function M._get_key_value_at_time(key, time) return key.end_value end - local easing = tweener[key.easing] or tweener.linear + local easing = key.easing_custom or tweener[key.easing] or tweener.linear local value = tweener.ease(easing, key.start_value, key.end_value, key.duration, time - key.start_time) return value From 5bfce0e9795c6f1b5d5d032dfc686b111383d6bb Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 3 Aug 2024 12:45:16 +0300 Subject: [PATCH 16/17] Add Druid component example with animation --- .vscode/settings.json | 3 +- CHANGELOG.md | 2 + README.md | 4 +- .../druid_component.gui | 202 ++++++++++++ .../druid_component.lua | 39 +++ .../druid_component_animation.lua | 148 +++++++++ .../exampel_druid_component.gui_script | 23 ++ .../example_druid_component.collection | 39 +++ .../example_druid_component.gui | 295 ++++++++++++++++++ game.project | 1 + 10 files changed, 753 insertions(+), 3 deletions(-) create mode 100644 example/example_druid_component/druid_component.gui create mode 100644 example/example_druid_component/druid_component.lua create mode 100644 example/example_druid_component/druid_component_animation.lua create mode 100644 example/example_druid_component/exampel_druid_component.gui_script create mode 100644 example/example_druid_component/example_druid_component.collection create mode 100644 example/example_druid_component/example_druid_component.gui diff --git a/.vscode/settings.json b/.vscode/settings.json index 606ee1d..e920013 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -17,6 +17,7 @@ "label", "sprite", "update", - "on_message" + "on_message", + "final" ] } diff --git a/CHANGELOG.md b/CHANGELOG.md index b6b794c..59f3f0f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -32,3 +32,5 @@ Initial resease! - Update documentation. - The `animation_state` table now contains `animation_id`, instead of `animation` table data. It will be better to log or `pprint` the animation state. - Rename file `panthera_system` to `panthera_internal`. +- Add support for `is_editor_only` timeline key property +- Add support for `easing_custom` timeline key property \ No newline at end of file diff --git a/README.md b/README.md index e3a6c85..8cded56 100644 --- a/README.md +++ b/README.md @@ -30,13 +30,13 @@ Open your `game.project` file and add the following lines to the dependencies fi **[Defold Tweener](https://github.com/Insality/defold-tweener)** ``` -https://github.com/Insality/defold-tweener/archive/refs/tags/2.zip +https://github.com/Insality/defold-tweener/archive/refs/tags/3.zip ``` **[Panthera Runtime](https://github.com/Insality/panthera)** ``` -https://github.com/Insality/panthera/archive/refs/tags/runtime.2.zip +https://github.com/Insality/panthera/archive/refs/tags/runtime.3.zip ``` After that, select `Project ▸ Fetch Libraries` to update [library dependencies]((https://defold.com/manuals/libraries/#setting-up-library-dependencies)). This happens automatically whenever you open a project so you will only need to do this if the dependencies change without re-opening the project. diff --git a/example/example_druid_component/druid_component.gui b/example/example_druid_component/druid_component.gui new file mode 100644 index 0000000..7ff5bf5 --- /dev/null +++ b/example/example_druid_component/druid_component.gui @@ -0,0 +1,202 @@ +script: "" +fonts { + name: "troika" + font: "/example/assets/troika.font" +} +textures { + name: "example" + texture: "/example/assets/example.atlas" +} +background_color { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 256.0 + y: 196.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.754 + y: 0.924 + z: 0.879 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/ui_rect_round_16" + id: "root" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + layer: "" + inherit_alpha: true + slice9 { + x: 16.0 + y: 16.0 + z: 16.0 + w: 16.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "panthera" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "root" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 80.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 30.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.2 + y: 0.2 + z: 0.2 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "Hello" + font: "troika" + id: "text" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: false + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +material: "/builtins/materials/gui.material" +adjust_reference: ADJUST_REFERENCE_PARENT +max_nodes: 512 diff --git a/example/example_druid_component/druid_component.lua b/example/example_druid_component/druid_component.lua new file mode 100644 index 0000000..0eb3d32 --- /dev/null +++ b/example/example_druid_component/druid_component.lua @@ -0,0 +1,39 @@ +local component = require("druid.component") +local panthera = require("panthera.panthera") +local druid_component_animation = require("example.example_druid_component.druid_component_animation") + +---@class druid_component: druid.base_component +---@field root node +---@field text druid.text +---@field druid druid_instance +local M = component.create("druid_component") + +local SCHEME = { + ROOT = "root", + PANTHERA = "panthera", + TEXT = "text" +} + + +---@param template string +---@param nodes table +function M:init(template, nodes) + self:set_template(template) + self:set_nodes(nodes) + self.druid = self:get_druid() + + self.root = self:get_node(SCHEME.ROOT) + self.text = self.druid:new_text(SCHEME.TEXT) + + self.animation_state = panthera.create_gui(druid_component_animation, self:get_template(), nodes) +end + + +function M:run_animation() + panthera.play(self.animation_state, "default", { + is_loop = true + }) +end + + +return M diff --git a/example/example_druid_component/druid_component_animation.lua b/example/example_druid_component/druid_component_animation.lua new file mode 100644 index 0000000..23efa56 --- /dev/null +++ b/example/example_druid_component/druid_component_animation.lua @@ -0,0 +1,148 @@ +return { + type = "animation_editor", + format = "json", + version = 1, + data = { + nodes = { + }, + animations = { + { + duration = 2.2, + animation_keys = { + { + property_id = "position_y", + easing = "outsine", + duration = 0.4, + key_type = "tween", + node_id = "panthera", + end_value = -42, + }, + { + property_id = "scale_x", + easing = "outback", + duration = 0.42, + key_type = "tween", + node_id = "text", + end_value = 1.3, + start_value = 1, + }, + { + property_id = "scale_y", + easing = "outback", + duration = 0.42, + key_type = "tween", + node_id = "text", + end_value = 1.3, + start_value = 1, + }, + { + property_id = "position_y", + easing = "outback", + duration = 0.42, + key_type = "tween", + node_id = "text", + end_value = 45, + start_value = 80, + }, + { + property_id = "position_x", + easing = "outsine", + duration = 0.8, + key_type = "tween", + node_id = "panthera", + end_value = 75, + }, + { + property_id = "text", + easing = "linear", + node_id = "text", + key_type = "trigger", + start_time = 0.22, + data = "Just", + start_data = "Hello", + }, + { + property_id = "position_y", + easing = "outsine", + duration = 1.6, + key_type = "tween", + start_time = 0.4, + node_id = "panthera", + start_value = -42, + }, + { + property_id = "scale_x", + easing = "outsine", + duration = 0.45, + node_id = "text", + key_type = "tween", + start_time = 0.42, + end_value = 1, + start_value = 1.3, + }, + { + property_id = "scale_y", + easing = "outsine", + duration = 0.45, + node_id = "text", + key_type = "tween", + start_time = 0.42, + end_value = 1, + start_value = 1.3, + }, + { + property_id = "position_y", + easing = "outsine", + duration = 0.45, + node_id = "text", + key_type = "tween", + start_time = 0.42, + end_value = 75, + start_value = 45, + }, + { + property_id = "position_x", + easing = "outsine", + duration = 0.6, + node_id = "panthera", + key_type = "tween", + start_time = 0.8, + end_value = -65, + start_value = 75, + }, + { + property_id = "text", + easing = "linear", + node_id = "text", + key_type = "trigger", + start_time = 0.87, + data = "Example", + start_data = "Just", + }, + { + property_id = "position_x", + easing = "outsine", + duration = 0.6, + key_type = "tween", + start_time = 1.4, + node_id = "panthera", + start_value = -65, + }, + }, + animation_id = "default", + }, + }, + metadata = { + gui_path = "/example/example_druid_component/druid_component.gui", + fps = 60, + settings = { + font_size = 40, + }, + layers = { + }, + gizmo_steps = { + time = 0.1, + }, + }, + }, +} \ No newline at end of file diff --git a/example/example_druid_component/exampel_druid_component.gui_script b/example/example_druid_component/exampel_druid_component.gui_script new file mode 100644 index 0000000..75e13a5 --- /dev/null +++ b/example/example_druid_component/exampel_druid_component.gui_script @@ -0,0 +1,23 @@ +local druid = require("druid.druid") + +local druid_component = require("example.example_druid_component.druid_component") + +function init(self) + self.druid = druid.new(self) + + local prefab = gui.get_node("druid_component_template/root") + + local druid_component_on_scene = self.druid:new(druid_component, "druid_component_template") + + local nodes = gui.clone_tree(prefab) + local druid_component_cloned = self.druid:new(druid_component, "druid_component_template", nodes) + gui.set_position(druid_component_cloned.root, vmath.vector3(700, 340, 0)) + + druid_component_on_scene:run_animation() + druid_component_cloned:run_animation() +end + + +function final(self) + self.druid:final() +end diff --git a/example/example_druid_component/example_druid_component.collection b/example/example_druid_component/example_druid_component.collection new file mode 100644 index 0000000..6d333eb --- /dev/null +++ b/example/example_druid_component/example_druid_component.collection @@ -0,0 +1,39 @@ +name: "example_druid_component" +scale_along_z: 0 +embedded_instances { + id: "go" + data: "components {\n" + " id: \"example_druid_component\"\n" + " component: \"/example/example_druid_component/example_druid_component.gui\"\n" + " position {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " }\n" + " rotation {\n" + " x: 0.0\n" + " y: 0.0\n" + " z: 0.0\n" + " w: 1.0\n" + " }\n" + " property_decls {\n" + " }\n" + "}\n" + "" + position { + x: 0.0 + y: 0.0 + z: 0.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale3 { + x: 1.0 + y: 1.0 + z: 1.0 + } +} diff --git a/example/example_druid_component/example_druid_component.gui b/example/example_druid_component/example_druid_component.gui new file mode 100644 index 0000000..1f95206 --- /dev/null +++ b/example/example_druid_component/example_druid_component.gui @@ -0,0 +1,295 @@ +script: "/example/example_druid_component/exampel_druid_component.gui_script" +background_color { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "" + id: "root" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: false + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: false + material: "" +} +nodes { + position { + x: 260.0 + y: 340.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_TEMPLATE + id: "druid_component_template" + parent: "root" + layer: "" + inherit_alpha: true + alpha: 1.0 + template: "/example/example_druid_component/druid_component.gui" + template_node_child: false + custom_type: 0 + enabled: true +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 256.0 + y: 196.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.754 + y: 0.924 + z: 0.879 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/ui_rect_round_16" + id: "druid_component_template/root" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "druid_component_template" + layer: "" + inherit_alpha: true + slice9 { + x: 16.0 + y: 16.0 + z: 16.0 + w: 16.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: true + size_mode: SIZE_MODE_MANUAL + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 100.0 + z: 0.0 + w: 1.0 + } + color { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + type: TYPE_BOX + blend_mode: BLEND_MODE_ALPHA + texture: "example/panthera" + id: "druid_component_template/panthera" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + adjust_mode: ADJUST_MODE_FIT + parent: "druid_component_template/root" + layer: "" + inherit_alpha: true + slice9 { + x: 0.0 + y: 0.0 + z: 0.0 + w: 0.0 + } + clipping_mode: CLIPPING_MODE_NONE + clipping_visible: true + clipping_inverted: false + alpha: 1.0 + template_node_child: true + size_mode: SIZE_MODE_AUTO + custom_type: 0 + enabled: true + visible: true + material: "" +} +nodes { + position { + x: 0.0 + y: 80.0 + z: 0.0 + w: 1.0 + } + rotation { + x: 0.0 + y: 0.0 + z: 0.0 + w: 1.0 + } + scale { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + size { + x: 200.0 + y: 30.0 + z: 0.0 + w: 1.0 + } + color { + x: 0.2 + y: 0.2 + z: 0.2 + w: 1.0 + } + type: TYPE_TEXT + blend_mode: BLEND_MODE_ALPHA + text: "Hello" + font: "troika" + id: "druid_component_template/text" + xanchor: XANCHOR_NONE + yanchor: YANCHOR_NONE + pivot: PIVOT_CENTER + outline { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + shadow { + x: 1.0 + y: 1.0 + z: 1.0 + w: 1.0 + } + adjust_mode: ADJUST_MODE_FIT + line_break: false + parent: "druid_component_template/root" + layer: "" + inherit_alpha: true + alpha: 1.0 + outline_alpha: 0.0 + shadow_alpha: 0.0 + template_node_child: true + text_leading: 1.0 + text_tracking: 0.0 + custom_type: 0 + enabled: true + visible: true + material: "" +} +material: "/builtins/materials/gui.material" +adjust_reference: ADJUST_REFERENCE_PARENT +max_nodes: 512 diff --git a/game.project b/game.project index aa3a748..899dda1 100644 --- a/game.project +++ b/game.project @@ -20,6 +20,7 @@ developer = Maksim Tuprikov, Insality custom_resources = /resources dependencies#0 = https://github.com/Insality/defold-log/archive/refs/tags/2.zip dependencies#1 = https://github.com/Insality/defold-tweener/archive/refs/tags/3.zip +dependencies#2 = https://github.com/Insality/druid/archive/refs/tags/0.11.0.zip [library] include_dirs = panthera From f9a323b2fdf54ebf5d6f181049fd05621725b933 Mon Sep 17 00:00:00 2001 From: Insality Date: Sat, 3 Aug 2024 12:46:51 +0300 Subject: [PATCH 17/17] Remove Defold annotations from Panthera repo --- annotations/defold_annotations/b2d.body.lua | 275 ---- annotations/defold_annotations/b2d.lua | 27 - annotations/defold_annotations/bit.lua | 104 -- annotations/defold_annotations/buffer.lua | 107 -- annotations/defold_annotations/builtins.lua | 32 - annotations/defold_annotations/camera.lua | 26 - .../defold_annotations/collectionfactory.lua | 86 -- .../defold_annotations/collectionproxy.lua | 40 - annotations/defold_annotations/crash.lua | 117 -- .../defold_annotations/defold_types.lua | 46 - annotations/defold_annotations/factory.lua | 78 -- annotations/defold_annotations/go.lua | 355 ----- annotations/defold_annotations/gui.lua | 1240 ----------------- annotations/defold_annotations/html5.lua | 37 - annotations/defold_annotations/http.lua | 49 - annotations/defold_annotations/image.lua | 78 -- annotations/defold_annotations/json.lua | 41 - annotations/defold_annotations/label.lua | 28 - annotations/defold_annotations/liveupdate.lua | 155 --- annotations/defold_annotations/model.lua | 92 -- annotations/defold_annotations/msg.lua | 54 - annotations/defold_annotations/particlefx.lua | 85 -- annotations/defold_annotations/physics.lua | 307 ---- annotations/defold_annotations/profiler.lua | 126 -- annotations/defold_annotations/render.lua | 689 --------- annotations/defold_annotations/resource.lua | 760 ---------- annotations/defold_annotations/socket.lua | 173 --- annotations/defold_annotations/sound.lua | 160 --- annotations/defold_annotations/sprite.lua | 62 - annotations/defold_annotations/sys.lua | 314 ----- annotations/defold_annotations/tilemap.lua | 90 -- annotations/defold_annotations/timer.lua | 68 - annotations/defold_annotations/types.lua | 140 -- annotations/defold_annotations/vmath.lua | 404 ------ annotations/defold_annotations/window.lua | 110 -- annotations/defold_annotations/zlib.lua | 28 - 36 files changed, 6583 deletions(-) delete mode 100644 annotations/defold_annotations/b2d.body.lua delete mode 100644 annotations/defold_annotations/b2d.lua delete mode 100644 annotations/defold_annotations/bit.lua delete mode 100644 annotations/defold_annotations/buffer.lua delete mode 100644 annotations/defold_annotations/builtins.lua delete mode 100644 annotations/defold_annotations/camera.lua delete mode 100644 annotations/defold_annotations/collectionfactory.lua delete mode 100644 annotations/defold_annotations/collectionproxy.lua delete mode 100644 annotations/defold_annotations/crash.lua delete mode 100644 annotations/defold_annotations/defold_types.lua delete mode 100644 annotations/defold_annotations/factory.lua delete mode 100644 annotations/defold_annotations/go.lua delete mode 100644 annotations/defold_annotations/gui.lua delete mode 100644 annotations/defold_annotations/html5.lua delete mode 100644 annotations/defold_annotations/http.lua delete mode 100644 annotations/defold_annotations/image.lua delete mode 100644 annotations/defold_annotations/json.lua delete mode 100644 annotations/defold_annotations/label.lua delete mode 100644 annotations/defold_annotations/liveupdate.lua delete mode 100644 annotations/defold_annotations/model.lua delete mode 100644 annotations/defold_annotations/msg.lua delete mode 100644 annotations/defold_annotations/particlefx.lua delete mode 100644 annotations/defold_annotations/physics.lua delete mode 100644 annotations/defold_annotations/profiler.lua delete mode 100644 annotations/defold_annotations/render.lua delete mode 100644 annotations/defold_annotations/resource.lua delete mode 100644 annotations/defold_annotations/socket.lua delete mode 100644 annotations/defold_annotations/sound.lua delete mode 100644 annotations/defold_annotations/sprite.lua delete mode 100644 annotations/defold_annotations/sys.lua delete mode 100644 annotations/defold_annotations/tilemap.lua delete mode 100644 annotations/defold_annotations/timer.lua delete mode 100644 annotations/defold_annotations/types.lua delete mode 100644 annotations/defold_annotations/vmath.lua delete mode 100644 annotations/defold_annotations/window.lua delete mode 100644 annotations/defold_annotations/zlib.lua diff --git a/annotations/defold_annotations/b2d.body.lua b/annotations/defold_annotations/b2d.body.lua deleted file mode 100644 index d8434d3..0000000 --- a/annotations/defold_annotations/b2d.body.lua +++ /dev/null @@ -1,275 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Box2D b2Body documentation - - Functions for interacting with Box2D bodies. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.b2d.body -b2d.body = {} - ----Dynamic body -b2d.body.B2_DYNAMIC_BODY = nil - ----Kinematic body -b2d.body.B2_KINEMATIC_BODY = nil - ----Static (immovable) body -b2d.body.B2_STATIC_BODY = nil - ----Apply an angular impulse. ----@param body b2Body body ----@param impulse number impulse the angular impulse in units of kgmm/s -function b2d.body.apply_angular_impulse(body, impulse) end - ----Apply a force at a world point. If the force is not ----applied at the center of mass, it will generate a torque and ----affect the angular velocity. This wakes up the body. ----@param body b2Body body ----@param force vector3 the world force vector, usually in Newtons (N). ----@param point vector3 the world position of the point of application. -function b2d.body.apply_force(body, force, point) end - ----Apply a force to the center of mass. This wakes up the body. ----@param body b2Body body ----@param force vector3 the world force vector, usually in Newtons (N). -function b2d.body.apply_force_to_center(body, force) end - ----Apply an impulse at a point. This immediately modifies the velocity. ----It also modifies the angular velocity if the point of application ----is not at the center of mass. This wakes up the body. ----@param body b2Body body ----@param impulse vector3 the world impulse vector, usually in N-seconds or kg-m/s. ----@param point vector3 the world position of the point of application. -function b2d.body.apply_linear_impulse(body, impulse, point) end - ----Apply a torque. This affects the angular velocity ----without affecting the linear velocity of the center of mass. ----This wakes up the body. ----@param body b2Body body ----@param torque number torque about the z-axis (out of the screen), usually in N-m. -function b2d.body.apply_torque(body, torque) end - ----Print the body representation to the log output ----@param body b2Body body -function b2d.body.dump(body) end - ----Get the angular damping of the body. ----@param body b2Body body ----@return number damping the damping -function b2d.body.get_angular_damping(body) end - ----Get the angular velocity. ----@param body b2Body body ----@return number velocity the angular velocity in radians/second. -function b2d.body.get_angular_velocity(body) end - ----Set the angular velocity. ----@param body b2Body body ----@param omega number the new angular velocity in radians/second. -function b2d.body.get_angular_velocity(body, omega) end - ----Get the gravity scale of the body. ----@param body b2Body body ----@return number scale the scale -function b2d.body.get_gravity_scale(body) end - ----Get the rotational inertia of the body about the local origin. ----@param body b2Body body ----@return number inertia the rotational inertia, usually in kg-m^2. -function b2d.body.get_inertia(body) end - ----Get the linear damping of the body. ----@param body b2Body body ----@return number damping the damping -function b2d.body.get_linear_damping(body) end - ----Get the linear velocity of the center of mass. ----@param body b2Body body ----@return vector3 velocity the linear velocity of the center of mass. -function b2d.body.get_linear_velocity(body) end - ----Get the world velocity of a local point. ----@param body b2Body body ----@param local_point vector3 a point in local coordinates. ----@return vector3 velocity the world velocity of a point. -function b2d.body.get_linear_velocity_from_local_point(body, local_point) end - ----Get the world linear velocity of a world point attached to this body. ----@param body b2Body body ----@param world_point vector3 a point in world coordinates. ----@return vector3 velocity the world velocity of a point. -function b2d.body.get_linear_velocity_from_world_point(body, world_point) end - ----Get the local position of the center of mass. ----@param body b2Body body ----@return vector3 center Get the local position of the center of mass. -function b2d.body.get_local_center(body) end - ----Gets a local point relative to the body's origin given a world point. ----@param body b2Body body ----@param world_point vector3 a point in world coordinates. ----@return vector3 vector the corresponding local point relative to the body's origin. -function b2d.body.get_local_point(body, world_point) end - ----Gets a local vector given a world vector. ----@param body b2Body body ----@param world_vector vector3 a vector in world coordinates. ----@return vector3 vector the corresponding local vector. -function b2d.body.get_local_vector(body, world_vector) end - ----Get the total mass of the body. ----@param body b2Body body ----@return number mass the mass, usually in kilograms (kg). -function b2d.body.get_mass(body) end - ----Get the next body in the world's body list. ----@param body b2Body body ----@return b2Body body the next body -function b2d.body.get_next(body) end - ----Get the world body origin position. ----@param body b2Body body ----@return vector3 position the world position of the body's origin. -function b2d.body.get_position(body) end - ----Get the type of this body. ----@param body b2Body body ----@return b2BodyType type the body type -function b2d.body.get_type(body) end - ----Get the parent world of this body. ----@param body b2Body body ----@return b2World world -function b2d.body.get_world(body) end - ----Get the angle in radians. ----@param body b2Body body ----@return number angle the current world rotation angle in radians. -function b2d.body.get_world_center(body) end - ----Get the world position of the center of mass. ----@param body b2Body body ----@return vector3 center Get the world position of the center of mass. -function b2d.body.get_world_center(body) end - ----Get the world coordinates of a point given the local coordinates. ----@param body b2Body body ----@param local_vector vector3 localPoint a point on the body measured relative the the body's origin. ----@return vector3 vector the same point expressed in world coordinates. -function b2d.body.get_world_point(body, local_vector) end - ----Get the world coordinates of a vector given the local coordinates. ----@param body b2Body body ----@param local_vector vector3 a vector fixed in the body. ----@return vector3 vector the same vector expressed in world coordinates. -function b2d.body.get_world_vector(body, local_vector) end - ----Get the active state of the body. ----@param body b2Body body ----@return bool enabled is the body active -function b2d.body.is_active(body) end - ----Get the sleeping state of this body. ----@param body b2Body body ----@return bool enabled true if the body is awake, false if it's sleeping. -function b2d.body.is_awake(body) end - ----Is this body in bullet mode ----@param body b2Body body ----@return bool enabled true if the body is in bullet mode -function b2d.body.is_bullet(body) end - ----Does this body have fixed rotation? ----@param body b2Body body ----@return bool enabled is the rotation fixed -function b2d.body.is_fixed_rotation(body) end - ----Is this body allowed to sleep ----@param body b2Body body ----@return bool enabled true if the body is allowed to sleep -function b2d.body.is_sleeping_allowed(body) end - ----This resets the mass properties to the sum of the mass properties of the fixtures. ----This normally does not need to be called unless you called SetMassData to override ----@param body b2Body body -function b2d.body.reset_mass_data(body) end - ----Set the active state of the body. An inactive body is not ----simulated and cannot be collided with or woken up. ----If you pass a flag of true, all fixtures will be added to the ----broad-phase. ----If you pass a flag of false, all fixtures will be removed from ----the broad-phase and all contacts will be destroyed. ----Fixtures and joints are otherwise unaffected. You may continue ----to create/destroy fixtures and joints on inactive bodies. ----Fixtures on an inactive body are implicitly inactive and will ----not participate in collisions, ray-casts, or queries. ----Joints connected to an inactive body are implicitly inactive. ----An inactive body is still owned by a b2World object and remains ----in the body list. ----@param body b2Body body ----@param enable bool true if the body should be active -function b2d.body.set_active(body, enable) end - ----Set the angular damping of the body. ----@param body b2Body body ----@param damping number the damping -function b2d.body.set_angular_damping(body, damping) end - ----Set the sleep state of the body. A sleeping body has very low CPU cost. ----@param body b2Body body ----@param enable bool flag set to false to put body to sleep, true to wake it. -function b2d.body.set_awake(body, enable) end - ----Should this body be treated like a bullet for continuous collision detection? ----@param body b2Body body ----@param enable bool if true, the body will be in bullet mode -function b2d.body.set_bullet(body, enable) end - ----Set this body to have fixed rotation. This causes the mass to be reset. ----@param body b2Body body ----@param enable bool true if the rotation should be fixed -function b2d.body.set_fixed_rotation(body, enable) end - ----Set the gravity scale of the body. ----@param body b2Body body ----@param scale number the scale -function b2d.body.set_gravity_scale(body, scale) end - ----Set the linear damping of the body. ----@param body b2Body body ----@param damping number the damping -function b2d.body.set_linear_damping(body, damping) end - ----Set the linear velocity of the center of mass. ----@param body b2Body body ----@param velocity vector3 the new linear velocity of the center of mass. -function b2d.body.set_linear_velocity(body, velocity) end - ----You can disable sleeping on this body. If you disable sleeping, the body will be woken. ----@param body b2Body body ----@param enable bool if false, the body will never sleep, and consume more CPU -function b2d.body.set_sleeping_allowed(body, enable) end - ----Set the position of the body's origin and rotation. ----This breaks any contacts and wakes the other bodies. ----Manipulating a body's transform may cause non-physical behavior. ----@param body b2Body body ----@param position vector3 the world position of the body's local origin. ----@param angle number the world position of the body's local origin. -function b2d.body.set_transform(body, position, angle) end - ----Set the type of this body. This may alter the mass and velocity. ----@param body b2Body body ----@param type b2BodyType the body type -function b2d.body.set_type(body, type) end - -return b2d.body \ No newline at end of file diff --git a/annotations/defold_annotations/b2d.lua b/annotations/defold_annotations/b2d.lua deleted file mode 100644 index 4741330..0000000 --- a/annotations/defold_annotations/b2d.lua +++ /dev/null @@ -1,27 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Box2D documentation - - Functions for interacting with Box2D. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.b2d -b2d = {} - ----Get the Box2D body from a collision object ----@param url string|hash|url the url to the game object collision component ----@return b2Body body the body if successful. Otherwise nil. -function b2d.get_body(url) end - ----Get the Box2D world from the current collection ----@return b2World world the world if successful. Otherwise nil. -function b2d.get_world() end - -return b2d \ No newline at end of file diff --git a/annotations/defold_annotations/bit.lua b/annotations/defold_annotations/bit.lua deleted file mode 100644 index 46ac0c6..0000000 --- a/annotations/defold_annotations/bit.lua +++ /dev/null @@ -1,104 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Bitwise operations API documentation - - Lua BitOp is a C extension module for Lua 5.1/5.2 which adds bitwise operations on numbers. - Lua BitOp is Copyright © 2008-2012 Mike Pall. - Lua BitOp is free software, released under the MIT license (same license as the Lua core). - Lua BitOp is compatible with the built-in bitwise operations in LuaJIT 2.0 and is used - on platforms where Defold runs without LuaJIT. - For clarity the examples assume the definition of a helper function printx(). - This prints its argument as an unsigned 32 bit hexadecimal number on all platforms: - function printx(x) - print("0x"..bit.tohex(x)) - end ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.bit -bit = {} - ----Returns the bitwise arithmetic right-shift of its first argument by the number of bits given by the second argument. ----Arithmetic right-shift treats the most-significant bit as a sign bit and replicates it. ----Only the lower 5 bits of the shift count are used (reduces to the range [0..31]). ----@param x number number ----@param n number number of bits ----@return number y bitwise arithmetic right-shifted number -function bit.arshift(x, n) end - ----Returns the bitwise and of all of its arguments. Note that more than two arguments are allowed. ----@param x1 number number ----@param ... number|nil number(s) ----@return number y bitwise and of the provided arguments -function bit.band(x1, ...) end - ----Returns the bitwise not of its argument. ----@param x number number ----@return number y bitwise not of number x -function bit.bnot(x) end - ----Returns the bitwise or of all of its arguments. Note that more than two arguments are allowed. ----@param x1 number number ----@param ... number|nil number(s) ----@return number y bitwise or of the provided arguments -function bit.bor(x1, ...) end - ----Swaps the bytes of its argument and returns it. This can be used to convert little-endian 32 bit numbers to big-endian 32 bit numbers or vice versa. ----@param x number number ----@return number y bitwise swapped number -function bit.bswap(x) end - ----Returns the bitwise xor of all of its arguments. Note that more than two arguments are allowed. ----@param x1 number number ----@param ... number|nil number(s) ----@return number y bitwise xor of the provided arguments -function bit.bxor(x1, ...) end - ----Returns the bitwise logical left-shift of its first argument by the number of bits given by the second argument. ----Logical shifts treat the first argument as an unsigned number and shift in 0-bits. ----Only the lower 5 bits of the shift count are used (reduces to the range [0..31]). ----@param x number number ----@param n number number of bits ----@return number y bitwise logical left-shifted number -function bit.lshift(x, n) end - ----Returns the bitwise left rotation of its first argument by the number of bits given by the second argument. Bits shifted out on one side are shifted back in on the other side. ----Only the lower 5 bits of the rotate count are used (reduces to the range [0..31]). ----@param x number number ----@param n number number of bits ----@return number y bitwise left-rotated number -function bit.rol(x, n) end - ----Returns the bitwise right rotation of its first argument by the number of bits given by the second argument. Bits shifted out on one side are shifted back in on the other side. ----Only the lower 5 bits of the rotate count are used (reduces to the range [0..31]). ----@param x number number ----@param n number number of bits ----@return number y bitwise right-rotated number -function bit.ror(x, n) end - ----Returns the bitwise logical right-shift of its first argument by the number of bits given by the second argument. ----Logical shifts treat the first argument as an unsigned number and shift in 0-bits. ----Only the lower 5 bits of the shift count are used (reduces to the range [0..31]). ----@param x number number ----@param n number number of bits ----@return number y bitwise logical right-shifted number -function bit.rshift(x, n) end - ----Normalizes a number to the numeric range for bit operations and returns it. This function is usually not needed since all bit operations already normalize all of their input arguments. ----@param x number number to normalize ----@return number y normalized number -function bit.tobit(x) end - ----Converts its first argument to a hex string. The number of hex digits is given by the absolute value of the optional second argument. Positive numbers between 1 and 8 generate lowercase hex digits. Negative numbers generate uppercase hex digits. Only the least-significant 4*|n| bits are used. The default is to generate 8 lowercase hex digits. ----@param x number number to convert ----@param n number number of hex digits to return ----@return string s hexadecimal string -function bit.tohex(x, n) end - -return bit \ No newline at end of file diff --git a/annotations/defold_annotations/buffer.lua b/annotations/defold_annotations/buffer.lua deleted file mode 100644 index b44f05d..0000000 --- a/annotations/defold_annotations/buffer.lua +++ /dev/null @@ -1,107 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Buffer API documentation - - Functions for manipulating buffers and streams ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.buffer -buffer = {} - ----Float, single precision, 4 bytes -buffer.VALUE_TYPE_FLOAT32 = nil - ----Signed integer, 2 bytes -buffer.VALUE_TYPE_INT16 = nil - ----Signed integer, 4 bytes -buffer.VALUE_TYPE_INT32 = nil - ----Signed integer, 8 bytes -buffer.VALUE_TYPE_INT64 = nil - ----Signed integer, 1 byte -buffer.VALUE_TYPE_INT8 = nil - ----Unsigned integer, 2 bytes -buffer.VALUE_TYPE_UINT16 = nil - ----Unsigned integer, 4 bytes -buffer.VALUE_TYPE_UINT32 = nil - ----Unsigned integer, 8 bytes -buffer.VALUE_TYPE_UINT64 = nil - ----Unsigned integer, 1 byte -buffer.VALUE_TYPE_UINT8 = nil - ----Copy all data streams from one buffer to another, element wise. ---- Each of the source streams must have a matching stream in the ----destination buffer. The streams must match in both type and size. ----The source and destination buffer can be the same. ----@param dst buffer_data the destination buffer ----@param dstoffset number the offset to start copying data to ----@param src buffer_data the source data buffer ----@param srcoffset number the offset to start copying data from ----@param count number the number of elements to copy -function buffer.copy_buffer(dst, dstoffset, src, srcoffset, count) end - ----Copy a specified amount of data from one stream to another. ---- The value type and size must match between source and destination streams. ----The source and destination streams can be the same. ----@param dst buffer_stream the destination stream ----@param dstoffset number the offset to start copying data to (measured in value type) ----@param src buffer_stream the source data stream ----@param srcoffset number the offset to start copying data from (measured in value type) ----@param count number the number of values to copy (measured in value type) -function buffer.copy_stream(dst, dstoffset, src, srcoffset, count) end - ----Create a new data buffer containing a specified set of streams. A data buffer ----can contain one or more streams with typed data. This is useful for managing ----compound data, for instance a vertex buffer could contain separate streams for ----vertex position, color, normal etc. ----@param element_count number The number of elements the buffer should hold ----@param declaration { name:hash|string, type:constant, count:number }[] A table where each entry (table) describes a stream ---- ----hash | string name: The name of the stream ----constant type: The data type of the stream ----number count: The number of values each element should hold ---- ----@return buffer_data buffer the new buffer -function buffer.create(element_count, declaration) end - ----Get a copy of all the bytes from a specified stream as a Lua string. ----@param buffer buffer_data the source buffer ----@param stream_name hash the name of the stream ----@return string data the buffer data as a Lua string -function buffer.get_bytes(buffer, stream_name) end - ----Get a named metadata entry from a buffer along with its type. ----@param buf buffer_data the buffer to get the metadata from ----@param metadata_name hash|string name of the metadata entry ----@return number[]|nil values table of metadata values or nil if the entry does not exist ----@return constant|nil value_type numeric type of values or nil -function buffer.get_metadata(buf, metadata_name) end - ----Get a specified stream from a buffer. ----@param buffer buffer_data the buffer to get the stream from ----@param stream_name hash|string the stream name ----@return buffer_stream stream the data stream -function buffer.get_stream(buffer, stream_name) end - ----Creates or updates a metadata array entry on a buffer. ---- The value type and count given when updating the entry should match those used when first creating it. ----@param buf buffer_data the buffer to set the metadata on ----@param metadata_name hash|string name of the metadata entry ----@param values number[] actual metadata, an array of numeric values ----@param value_type constant type of values when stored -function buffer.set_metadata(buf, metadata_name, values, value_type) end - -return buffer \ No newline at end of file diff --git a/annotations/defold_annotations/builtins.lua b/annotations/defold_annotations/builtins.lua deleted file mode 100644 index 907dbb9..0000000 --- a/annotations/defold_annotations/builtins.lua +++ /dev/null @@ -1,32 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Built-ins API documentation - - Built-in scripting functions. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----All ids in the engine are represented as hashes, so a string needs to be hashed ----before it can be compared with an id. ----@param s string string to hash ----@return hash hash a hashed string -function hash(s) end - ----Returns a hexadecimal representation of a hash value. ----The returned string is always padded with leading zeros. ----@param h hash hash value to get hex string for ----@return string hex hex representation of the hash -function hash_to_hex(h) end - ----Pretty printing of Lua values. This function prints Lua values ----in a manner similar to +print()+, but will also recurse into tables ----and pretty print them. There is a limit to how deep the function ----will recurse. ----@param ... any value to print -function pprint(...) end \ No newline at end of file diff --git a/annotations/defold_annotations/camera.lua b/annotations/defold_annotations/camera.lua deleted file mode 100644 index a8152b3..0000000 --- a/annotations/defold_annotations/camera.lua +++ /dev/null @@ -1,26 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.7.0 - - Camera API documentation - - Messages to control camera components and camera focus. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class camera -camera = {} - ----makes camera active ----@param url string|hash|url url of camera component -function camera.acquire_focus(url) end - ----deactivate camera ----@param url string|hash|url url of camera component -function camera.release_focus(url) end - -return camera \ No newline at end of file diff --git a/annotations/defold_annotations/collectionfactory.lua b/annotations/defold_annotations/collectionfactory.lua deleted file mode 100644 index bb071a2..0000000 --- a/annotations/defold_annotations/collectionfactory.lua +++ /dev/null @@ -1,86 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Collection factory API documentation - - Functions for controlling collection factory components which are - used to dynamically spawn collections into the runtime. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.collectionfactory -collectionfactory = {} - ----loaded -collectionfactory.STATUS_LOADED = nil - ----loading -collectionfactory.STATUS_LOADING = nil - ----unloaded -collectionfactory.STATUS_UNLOADED = nil - ----The URL identifies the collectionfactory component that should do the spawning. ----Spawning is instant, but spawned game objects get their first update calls the following frame. The supplied parameters for position, rotation and scale ----will be applied to the whole collection when spawned. ----Script properties in the created game objects can be overridden through ----a properties-parameter table. The table should contain game object ids ----(hash) as keys and property tables as values to be used when initiating each ----spawned game object. ----See go.property for more information on script properties. ----The function returns a table that contains a key for each game object ----id (hash), as addressed if the collection file was top level, and the ----corresponding spawned instance id (hash) as value with a unique path ----prefix added to each instance. ---- Calling collectionfactory.create create on a collection factory that is marked as dynamic without having loaded resources ----using collectionfactory.load will synchronously load and create resources which may affect application performance. ----@param url string|hash|url the collection factory component to be used ----@param position vector3|nil position to assign to the newly spawned collection ----@param rotation quaternion|nil rotation to assign to the newly spawned collection ----@param properties table|nil table of script properties to propagate to any new game object instances ----@param scale number|nil uniform scaling to apply to the newly spawned collection (must be greater than 0). ----@return table ids a table mapping the id:s from the collection to the new instance id:s -function collectionfactory.create(url, position, rotation, properties, scale) end - ----This returns status of the collection factory. ----Calling this function when the factory is not marked as dynamic loading always returns COMP_COLLECTION_FACTORY_STATUS_LOADED. ----@param url string|hash|url|nil the collection factory component to get status from ----@return constant status status of the collection factory component ---- ----collectionfactory.STATUS_UNLOADED ----collectionfactory.STATUS_LOADING ----collectionfactory.STATUS_LOADED ---- -function collectionfactory.get_status(url) end - ----Resources loaded are referenced by the collection factory component until the existing (parent) collection is destroyed or collectionfactory.unload is called. ----Calling this function when the factory is not marked as dynamic loading does nothing. ----@param url string|hash|url|nil the collection factory component to load ----@param complete_function fun(self, url, result)|nil function to call when resources are loaded. ---- ----self ----object The current object. ----url ----url url of the collection factory component ----result ----boolean True if resource were loaded successfully ---- -function collectionfactory.load(url, complete_function) end - ----Changes the prototype for the collection factory. ----Setting the prototype to "nil" will revert back to the original prototype. ----@param url string|hash|url|nil the collection factory component ----@param prototype string|nil the path to the new prototype, or nil -function collectionfactory.set_prototype(url, prototype) end - ----This decreases the reference count for each resource loaded with collectionfactory.load. If reference is zero, the resource is destroyed. ----Calling this function when the factory is not marked as dynamic loading does nothing. ----@param url string|hash|url|nil the collection factory component to unload -function collectionfactory.unload(url) end - -return collectionfactory \ No newline at end of file diff --git a/annotations/defold_annotations/collectionproxy.lua b/annotations/defold_annotations/collectionproxy.lua deleted file mode 100644 index 06648f4..0000000 --- a/annotations/defold_annotations/collectionproxy.lua +++ /dev/null @@ -1,40 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Collection proxy API documentation - - Messages for controlling and interacting with collection proxies - which are used to dynamically load collections into the runtime. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.collectionproxy -collectionproxy = {} - ----return an indexed table of resources for a collection proxy. Each ----entry is a hexadecimal string that represents the data of the specific ----resource. This representation corresponds with the filename for each ----individual resource that is exported when you bundle an application with ----LiveUpdate functionality. ----@param collectionproxy url the collectionproxy to check for resources. ----@return string[] resources the resources -function collectionproxy.get_resources(collectionproxy) end - ----return an array of missing resources for a collection proxy. Each ----entry is a hexadecimal string that represents the data of the specific ----resource. This representation corresponds with the filename for each ----individual resource that is exported when you bundle an application with ----LiveUpdate functionality. It should be considered good practise to always ----check whether or not there are any missing resources in a collection proxy ----before attempting to load the collection proxy. ----@param collectionproxy url the collectionproxy to check for missing ----resources. ----@return string[] resources the missing resources -function collectionproxy.missing_resources(collectionproxy) end - -return collectionproxy \ No newline at end of file diff --git a/annotations/defold_annotations/crash.lua b/annotations/defold_annotations/crash.lua deleted file mode 100644 index 75cfc45..0000000 --- a/annotations/defold_annotations/crash.lua +++ /dev/null @@ -1,117 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Crash API documentation - - Native crash logging functions and constants. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.crash -crash = {} - ----android build fingerprint -crash.SYSFIELD_ANDROID_BUILD_FINGERPRINT = nil - ----system device language as reported by sys.get_sys_info -crash.SYSFIELD_DEVICE_LANGUAGE = nil - ----device model as reported by sys.get_sys_info -crash.SYSFIELD_DEVICE_MODEL = nil - ----engine version as hash -crash.SYSFIELD_ENGINE_HASH = nil - ----engine version as release number -crash.SYSFIELD_ENGINE_VERSION = nil - ----system language as reported by sys.get_sys_info -crash.SYSFIELD_LANGUAGE = nil - ----device manufacturer as reported by sys.get_sys_info -crash.SYSFIELD_MANUFACTURER = nil - ----The max number of sysfields. -crash.SYSFIELD_MAX = nil - ----system name as reported by sys.get_sys_info -crash.SYSFIELD_SYSTEM_NAME = nil - ----system version as reported by sys.get_sys_info -crash.SYSFIELD_SYSTEM_VERSION = nil - ----system territory as reported by sys.get_sys_info -crash.SYSFIELD_TERRITORY = nil - ----The max number of user fields. -crash.USERFIELD_MAX = nil - ----The max size of a single user field. -crash.USERFIELD_SIZE = nil - ----A table is returned containing the addresses of the call stack. ----@param handle number crash dump handle ----@return table backtrace table containing the backtrace -function crash.get_backtrace(handle) end - ----The format of read text blob is platform specific ----and not guaranteed ----but can be useful for manual inspection. ----@param handle number crash dump handle ----@return string blob string with the platform specific data -function crash.get_extra_data(handle) end - ----The function returns a table containing entries with sub-tables that ----have fields 'name' and 'address' set for all loaded modules. ----@param handle number crash dump handle ----@return { name:string, address:string }[] modules module table -function crash.get_modules(handle) end - ----read signal number from a crash report ----@param handle number crash dump handle ----@return number signal signal number -function crash.get_signum(handle) end - ----reads a system field from a loaded crash dump ----@param handle number crash dump handle ----@param index number system field enum. Must be less than crash.SYSFIELD_MAX ----@return string|nil value value recorded in the crash dump, or nil if it didn't exist -function crash.get_sys_field(handle, index) end - ----reads user field from a loaded crash dump ----@param handle number crash dump handle ----@param index number user data slot index ----@return string value user data value recorded in the crash dump -function crash.get_user_field(handle, index) end - ----The crash dump will be removed from disk upon a successful ----load, so loading is one-shot. ----@return number|nil handle handle to the loaded dump, or nil if no dump was found -function crash.load_previous() end - ----releases a previously loaded crash dump ----@param handle number handle to loaded crash dump -function crash.release(handle) end - ----Crashes occuring before the path is set will be stored to a default engine location. ----@param path string file path to use -function crash.set_file_path(path) end - ----Store a user value that will get written to a crash dump when ----a crash occurs. This can be user id:s, breadcrumb data etc. ----There are 32 slots indexed from 0. Each slot stores at most 255 characters. ----@param index number slot index. 0-indexed ----@param value string string value to store -function crash.set_user_field(index, value) end - ----Performs the same steps as if a crash had just occured but ----allows the program to continue. ----The generated dump can be read by crash.load_previous -function crash.write_dump() end - -return crash \ No newline at end of file diff --git a/annotations/defold_annotations/defold_types.lua b/annotations/defold_annotations/defold_types.lua deleted file mode 100644 index 7b7821c..0000000 --- a/annotations/defold_annotations/defold_types.lua +++ /dev/null @@ -1,46 +0,0 @@ ----@class action ----@field value number The amount of input given by the user. This is usually 1 for buttons and 0-1 for analogue inputs. This is not present for mouse movement. ----@field pressed boolean If the input was pressed this frame. This is not present for mouse movement. ----@field released boolean If the input was released this frame. This is not present for mouse movement. ----@field repeated boolean If the input was repeated this frame. This is similar to how a key on a keyboard is repeated when you hold it down. This is not present for mouse movement. ----@field x number The x value of a pointer device, if present. ----@field y number The y value of a pointer device, if present. ----@field screen_x number The screen space x value of a pointer device, if present. ----@field screen_y number The screen space y value of a pointer device, if present. ----@field dx number The change in x value of a pointer device, if present. ----@field dy number The change in y value of a pointer device, if present. ----@field screen_dx number The change in screen space x value of a pointer device, if present. ----@field screen_dy number The change in screen space y value of a pointer device, if present. ----@field gamepad number The index of the gamepad device that provided the input. ----@field touch touch[] List of touch input, one element per finger, if present. See table below about touch input - ----@class touch ----@field id number A number identifying the touch input during its duration. ----@field pressed boolean True if the finger was pressed this frame. ----@field released boolean True if the finger was released this frame. ----@field tap_count number Number of taps, one for single, two for double-tap, etc ----@field x number The x touch location. ----@field y number The y touch location. ----@field dx number The change in x value. ----@field dy number The change in y value. ----@field acc_x number|nil Accelerometer x value (if present). ----@field acc_y number|nil Accelerometer y value (if present). ----@field acc_z number|nil Accelerometer z value (if present). - ----@class utf8 ----@field len fun(s: string) ----@field sub fun(s: string, start_index: number, length: number) ----@field reverse fun() ----@field char fun() ----@field unicode fun() ----@field gensub fun() ----@field byte fun() ----@field find fun() ----@field match fun(s: string, m: string) ----@field gmatch fun(s: string, m: string) ----@field gsub fun() ----@field dump fun() ----@field format fun() ----@field lower fun() ----@field upper fun() ----@field rep fun() diff --git a/annotations/defold_annotations/factory.lua b/annotations/defold_annotations/factory.lua deleted file mode 100644 index ba3c245..0000000 --- a/annotations/defold_annotations/factory.lua +++ /dev/null @@ -1,78 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Factory API documentation - - Functions for controlling factory components which are used to - dynamically spawn game objects into the runtime. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.factory -factory = {} - ----loaded -factory.STATUS_LOADED = nil - ----loading -factory.STATUS_LOADING = nil - ----unloaded -factory.STATUS_UNLOADED = nil - ----The URL identifies which factory should create the game object. ----If the game object is created inside of the frame (e.g. from an update callback), the game object will be created instantly, but none of its component will be updated in the same frame. ----Properties defined in scripts in the created game object can be overridden through the properties-parameter below. ----See go.property for more information on script properties. ---- Calling factory.create on a factory that is marked as dynamic without having loaded resources ----using factory.load will synchronously load and create resources which may affect application performance. ----@param url string|hash|url the factory that should create a game object. ----@param position vector3|nil the position of the new game object, the position of the game object calling factory.create() is used by default, or if the value is nil. ----@param rotation quaternion|nil the rotation of the new game object, the rotation of the game object calling factory.create() is used by default, or if the value is nil. ----@param properties table|nil the properties defined in a script attached to the new game object. ----@param scale number|vector3|nil the scale of the new game object (must be greater than 0), the scale of the game object containing the factory is used by default, or if the value is nil ----@return hash id the global id of the spawned game object -function factory.create(url, position, rotation, properties, scale) end - ----This returns status of the factory. ----Calling this function when the factory is not marked as dynamic loading always returns ----factory.STATUS_LOADED. ----@param url string|hash|url|nil the factory component to get status from ----@return constant status status of the factory component ---- ----factory.STATUS_UNLOADED ----factory.STATUS_LOADING ----factory.STATUS_LOADED ---- -function factory.get_status(url) end - ----Resources are referenced by the factory component until the existing (parent) collection is destroyed or factory.unload is called. ----Calling this function when the factory is not marked as dynamic loading does nothing. ----@param url string|hash|url|nil the factory component to load ----@param complete_function fun(self, url, result)|nil function to call when resources are loaded. ---- ----self ----object The current object. ----url ----url url of the factory component ----result ----boolean True if resources were loaded successfully ---- -function factory.load(url, complete_function) end - ----Changes the prototype for the factory. ----@param url string|hash|url|nil the factory component ----@param prototype string|nil the path to the new prototype, or nil -function factory.set_prototype(url, prototype) end - ----This decreases the reference count for each resource loaded with factory.load. If reference is zero, the resource is destroyed. ----Calling this function when the factory is not marked as dynamic loading does nothing. ----@param url string|hash|url|nil the factory component to unload -function factory.unload(url) end - -return factory \ No newline at end of file diff --git a/annotations/defold_annotations/go.lua b/annotations/defold_annotations/go.lua deleted file mode 100644 index 60b4e5e..0000000 --- a/annotations/defold_annotations/go.lua +++ /dev/null @@ -1,355 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Game object API documentation - - Functions, core hooks, messages and constants for manipulation of - game objects. The "go" namespace is accessible from game object script - files. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.go -go = {} - ----in-back -go.EASING_INBACK = nil - ----in-bounce -go.EASING_INBOUNCE = nil - ----in-circlic -go.EASING_INCIRC = nil - ----in-cubic -go.EASING_INCUBIC = nil - ----in-elastic -go.EASING_INELASTIC = nil - ----in-exponential -go.EASING_INEXPO = nil - ----in-out-back -go.EASING_INOUTBACK = nil - ----in-out-bounce -go.EASING_INOUTBOUNCE = nil - ----in-out-circlic -go.EASING_INOUTCIRC = nil - ----in-out-cubic -go.EASING_INOUTCUBIC = nil - ----in-out-elastic -go.EASING_INOUTELASTIC = nil - ----in-out-exponential -go.EASING_INOUTEXPO = nil - ----in-out-quadratic -go.EASING_INOUTQUAD = nil - ----in-out-quartic -go.EASING_INOUTQUART = nil - ----in-out-quintic -go.EASING_INOUTQUINT = nil - ----in-out-sine -go.EASING_INOUTSINE = nil - ----in-quadratic -go.EASING_INQUAD = nil - ----in-quartic -go.EASING_INQUART = nil - ----in-quintic -go.EASING_INQUINT = nil - ----in-sine -go.EASING_INSINE = nil - ----linear interpolation -go.EASING_LINEAR = nil - ----out-back -go.EASING_OUTBACK = nil - ----out-bounce -go.EASING_OUTBOUNCE = nil - ----out-circlic -go.EASING_OUTCIRC = nil - ----out-cubic -go.EASING_OUTCUBIC = nil - ----out-elastic -go.EASING_OUTELASTIC = nil - ----out-exponential -go.EASING_OUTEXPO = nil - ----out-in-back -go.EASING_OUTINBACK = nil - ----out-in-bounce -go.EASING_OUTINBOUNCE = nil - ----out-in-circlic -go.EASING_OUTINCIRC = nil - ----out-in-cubic -go.EASING_OUTINCUBIC = nil - ----out-in-elastic -go.EASING_OUTINELASTIC = nil - ----out-in-exponential -go.EASING_OUTINEXPO = nil - ----out-in-quadratic -go.EASING_OUTINQUAD = nil - ----out-in-quartic -go.EASING_OUTINQUART = nil - ----out-in-quintic -go.EASING_OUTINQUINT = nil - ----out-in-sine -go.EASING_OUTINSINE = nil - ----out-quadratic -go.EASING_OUTQUAD = nil - ----out-quartic -go.EASING_OUTQUART = nil - ----out-quintic -go.EASING_OUTQUINT = nil - ----out-sine -go.EASING_OUTSINE = nil - ----loop backward -go.PLAYBACK_LOOP_BACKWARD = nil - ----loop forward -go.PLAYBACK_LOOP_FORWARD = nil - ----ping pong loop -go.PLAYBACK_LOOP_PINGPONG = nil - ----no playback -go.PLAYBACK_NONE = nil - ----once backward -go.PLAYBACK_ONCE_BACKWARD = nil - ----once forward -go.PLAYBACK_ONCE_FORWARD = nil - ----once ping pong -go.PLAYBACK_ONCE_PINGPONG = nil - ----This is only supported for numerical properties. If the node property is already being ----animated, that animation will be canceled and replaced by the new one. ----If a complete_function (lua function) is specified, that function will be called when the animation has completed. ----By starting a new animation in that function, several animations can be sequenced together. See the examples for more information. ---- If you call go.animate() from a game object's final() function, ----any passed complete_function will be ignored and never called upon animation completion. ----See the properties guide for which properties can be animated and the animation guide for how ----them. ----@param url string|hash|url url of the game object or component having the property ----@param property string|hash id of the property to animate ----@param playback constant playback mode of the animation ---- ----go.PLAYBACK_ONCE_FORWARD ----go.PLAYBACK_ONCE_BACKWARD ----go.PLAYBACK_ONCE_PINGPONG ----go.PLAYBACK_LOOP_FORWARD ----go.PLAYBACK_LOOP_BACKWARD ----go.PLAYBACK_LOOP_PINGPONG ---- ----@param to number|vector3|vector4|quaternion target property value ----@param easing constant|vector4|vector3 easing to use during animation. Either specify a constant, see the animation guide for a complete list, or a vmath.vector with a curve ----@param duration number duration of the animation in seconds ----@param delay number|nil delay before the animation starts in seconds ----@param complete_function fun(self, url, property)|nil optional function to call when the animation has completed ---- ----self ---- ----object The current object. ---- ----url ---- ----url The game object or component instance for which the property is animated. ---- ----property ---- ----hash The id of the animated property. ---- ---- -function go.animate(url, property, playback, to, easing, duration, delay, complete_function) end - ----By calling this function, all or specified stored property animations of the game object or component will be canceled. ----See the properties guide for which properties can be animated and the animation guide for how to animate them. ----@param url string|hash|url url of the game object or component ----@param property string|hash|nil optional id of the property to cancel -function go.cancel_animations(url, property) end - ----Delete one or more game objects identified by id. Deletion is asynchronous meaning that ----the game object(s) are scheduled for deletion which will happen at the end of the current ----frame. Note that game objects scheduled for deletion will be counted against ----max_instances in "game.project" until they are actually removed. ---- Deleting a game object containing a particle FX component emitting particles will not immediately stop the particle FX from emitting particles. You need to manually stop the particle FX using particlefx.stop(). ---- Deleting a game object containing a sound component that is playing will not immediately stop the sound from playing. You need to manually stop the sound using sound.stop(). ----@param id string|hash|url|table|nil optional id or table of id's of the instance(s) to delete, the instance of the calling script is deleted by default ----@param recursive boolean|nil optional boolean, set to true to recursively delete child hiearchy in child to parent order -function go.delete(id, recursive) end - ----check if the specified game object exists ----@param url string|hash|url url of the game object to check ----@return bool exists true if the game object exists -function go.exists(url) end - ----gets a named property of the specified game object or component ----@param url string|hash|url url of the game object or component having the property ----@param property string|hash id of the property to retrieve ----@param options table|nil optional options table ----- index integer index into array property (1 based) ----- key hash name of internal property ----@return any value the value of the specified property -function go.get(url, property, options) end - ----Returns or constructs an instance identifier. The instance id is a hash ----of the absolute path to the instance. ----If path is specified, it can either be absolute or relative to the instance of the calling script. ----If path is not specified, the id of the game object instance the script is attached to will be returned. ----@param path string|nil path of the instance for which to return the id ----@return hash id instance id -function go.get_id(path) end - ----Get the parent for a game object instance. ----@param id string|hash|url|nil optional id of the game object instance to get parent for, defaults to the instance containing the calling script ----@return hash|nil parent_id parent instance or nil -function go.get_parent(id) end - ----The position is relative the parent (if any). Use go.get_world_position to retrieve the global world position. ----@param id string|hash|url|nil optional id of the game object instance to get the position for, by default the instance of the calling script ----@return vector3 position instance position -function go.get_position(id) end - ----The rotation is relative to the parent (if any). Use go.get_world_rotation to retrieve the global world rotation. ----@param id string|hash|url|nil optional id of the game object instance to get the rotation for, by default the instance of the calling script ----@return quaternion rotation instance rotation -function go.get_rotation(id) end - ----The scale is relative the parent (if any). Use go.get_world_scale to retrieve the global world 3D scale factor. ----@param id string|hash|url|nil optional id of the game object instance to get the scale for, by default the instance of the calling script ----@return vector3 scale instance scale factor -function go.get_scale(id) end - ----The uniform scale is relative the parent (if any). If the underlying scale vector is non-uniform the min element of the vector is returned as the uniform scale factor. ----@param id string|hash|url|nil optional id of the game object instance to get the uniform scale for, by default the instance of the calling script ----@return number scale uniform instance scale factor -function go.get_scale_uniform(id) end - ----The function will return the world position calculated at the end of the previous frame. ----Use go.get_position to retrieve the position relative to the parent. ----@param id string|hash|url|nil optional id of the game object instance to get the world position for, by default the instance of the calling script ----@return vector3 position instance world position -function go.get_world_position(id) end - ----The function will return the world rotation calculated at the end of the previous frame. ----Use go.get_rotation to retrieve the rotation relative to the parent. ----@param id string|hash|url|nil optional id of the game object instance to get the world rotation for, by default the instance of the calling script ----@return quaternion rotation instance world rotation -function go.get_world_rotation(id) end - ----The function will return the world 3D scale factor calculated at the end of the previous frame. ----Use go.get_scale to retrieve the 3D scale factor relative to the parent. ----This vector is derived by decomposing the transformation matrix and should be used with care. ----For most cases it should be fine to use go.get_world_scale_uniform instead. ----@param id string|hash|url|nil optional id of the game object instance to get the world scale for, by default the instance of the calling script ----@return vector3 scale instance world 3D scale factor -function go.get_world_scale(id) end - ----The function will return the world scale factor calculated at the end of the previous frame. ----Use go.get_scale_uniform to retrieve the scale factor relative to the parent. ----@param id string|hash|url|nil optional id of the game object instance to get the world scale for, by default the instance of the calling script ----@return number scale instance world scale factor -function go.get_world_scale_uniform(id) end - ----The function will return the world transform matrix calculated at the end of the previous frame. ----@param id string|hash|url|nil optional id of the game object instance to get the world transform for, by default the instance of the calling script ----@return matrix4 transform instance world transform -function go.get_world_transform(id) end - ----This function defines a property which can then be used in the script through the self-reference. ----The properties defined this way are automatically exposed in the editor in game objects and collections which use the script. ----Note that you can only use this function outside any callback-functions like init and update. ----@param name string the id of the property ----@param value number|hash|url|vector3|vector4|quaternion|resource_data|boolean default value of the property. In the case of a url, only the empty constructor msg.url() is allowed. In the case of a resource one of the resource constructors (eg resource.atlas(), resource.font() etc) is expected. -function go.property(name, value) end - ----sets a named property of the specified game object or component, or a material constant ----@param url string|hash|url url of the game object or component having the property ----@param property string|hash id of the property to set ----@param value any|table the value to set ----@param options table|nil optional options table ----- index integer index into array property (1 based) ----- key hash name of internal property -function go.set(url, property, value, options) end - ----Sets the parent for a game object instance. This means that the instance will exist in the geometrical space of its parent, ----like a basic transformation hierarchy or scene graph. If no parent is specified, the instance will be detached from any parent and exist in world ----space. ----This function will generate a set_parent message. It is not until the message has been processed that the change actually takes effect. This ----typically happens later in the same frame or the beginning of the next frame. Refer to the manual to learn how messages are processed by the ----engine. ----@param id string|hash|url|nil optional id of the game object instance to set parent for, defaults to the instance containing the calling script ----@param parent_id string|hash|url|nil optional id of the new parent game object, defaults to detaching game object from its parent ----@param keep_world_transform boolean|nil optional boolean, set to true to maintain the world transform when changing spaces. Defaults to false. -function go.set_parent(id, parent_id, keep_world_transform) end - ----The position is relative to the parent (if any). The global world position cannot be manually set. ----@param position vector3 position to set ----@param id string|hash|url|nil optional id of the game object instance to set the position for, by default the instance of the calling script -function go.set_position(position, id) end - ----The rotation is relative to the parent (if any). The global world rotation cannot be manually set. ----@param rotation quaternion rotation to set ----@param id string|hash|url|nil optional id of the game object instance to get the rotation for, by default the instance of the calling script -function go.set_rotation(rotation, id) end - ----The scale factor is relative to the parent (if any). The global world scale factor cannot be manually set. ---- Physics are currently not affected when setting scale from this function. ----@param scale number|vector3 vector or uniform scale factor, must be greater than 0 ----@param id string|hash|url|nil optional id of the game object instance to get the scale for, by default the instance of the calling script -function go.set_scale(scale, id) end - ---- The function uses world transformation calculated at the end of previous frame. ----@param position vector3 position which need to be converted ----@param url string|hash|url url of the game object which coordinate system convert to ----@return vector3 converted_postion converted position -function go.world_to_local_position(position, url) end - ---- The function uses world transformation calculated at the end of previous frame. ----@param transformation matrix4 transformation which need to be converted ----@param url string|hash|url url of the game object which coordinate system convert to ----@return matrix4 converted_transform converted transformation -function go.world_to_local_transform(transformation, url) end - - - -return go \ No newline at end of file diff --git a/annotations/defold_annotations/gui.lua b/annotations/defold_annotations/gui.lua deleted file mode 100644 index 3fa05ff..0000000 --- a/annotations/defold_annotations/gui.lua +++ /dev/null @@ -1,1240 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - GUI API documentation - - GUI core hooks, functions, messages, properties and constants for - creation and manipulation of GUI nodes. The "gui" namespace is - accessible only from gui scripts. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.gui -gui = {} - ----Adjust mode is used when the screen resolution differs from the project settings. ----The fit mode ensures that the entire node is visible in the adjusted gui scene. -gui.ADJUST_FIT = nil - ----Adjust mode is used when the screen resolution differs from the project settings. ----The stretch mode ensures that the node is displayed as is in the adjusted gui scene, which might scale it non-uniformally. -gui.ADJUST_STRETCH = nil - ----Adjust mode is used when the screen resolution differs from the project settings. ----The zoom mode ensures that the node fills its entire area and might make the node exceed it. -gui.ADJUST_ZOOM = nil - ----bottom y-anchor -gui.ANCHOR_BOTTOM = nil - ----left x-anchor -gui.ANCHOR_LEFT = nil - ----no anchor -gui.ANCHOR_NONE = nil - ----right x-anchor -gui.ANCHOR_RIGHT = nil - ----top y-anchor -gui.ANCHOR_TOP = nil - ----additive blending -gui.BLEND_ADD = nil - ----additive alpha blending -gui.BLEND_ADD_ALPHA = nil - ----alpha blending -gui.BLEND_ALPHA = nil - ----multiply blending -gui.BLEND_MULT = nil - ----screen blending -gui.BLEND_SCREEN = nil - ----clipping mode none -gui.CLIPPING_MODE_NONE = nil - ----clipping mode stencil -gui.CLIPPING_MODE_STENCIL = nil - ----in-back -gui.EASING_INBACK = nil - ----in-bounce -gui.EASING_INBOUNCE = nil - ----in-circlic -gui.EASING_INCIRC = nil - ----in-cubic -gui.EASING_INCUBIC = nil - ----in-elastic -gui.EASING_INELASTIC = nil - ----in-exponential -gui.EASING_INEXPO = nil - ----in-out-back -gui.EASING_INOUTBACK = nil - ----in-out-bounce -gui.EASING_INOUTBOUNCE = nil - ----in-out-circlic -gui.EASING_INOUTCIRC = nil - ----in-out-cubic -gui.EASING_INOUTCUBIC = nil - ----in-out-elastic -gui.EASING_INOUTELASTIC = nil - ----in-out-exponential -gui.EASING_INOUTEXPO = nil - ----in-out-quadratic -gui.EASING_INOUTQUAD = nil - ----in-out-quartic -gui.EASING_INOUTQUART = nil - ----in-out-quintic -gui.EASING_INOUTQUINT = nil - ----in-out-sine -gui.EASING_INOUTSINE = nil - ----in-quadratic -gui.EASING_INQUAD = nil - ----in-quartic -gui.EASING_INQUART = nil - ----in-quintic -gui.EASING_INQUINT = nil - ----in-sine -gui.EASING_INSINE = nil - ----linear interpolation -gui.EASING_LINEAR = nil - ----out-back -gui.EASING_OUTBACK = nil - ----out-bounce -gui.EASING_OUTBOUNCE = nil - ----out-circlic -gui.EASING_OUTCIRC = nil - ----out-cubic -gui.EASING_OUTCUBIC = nil - ----out-elastic -gui.EASING_OUTELASTIC = nil - ----out-exponential -gui.EASING_OUTEXPO = nil - ----out-in-back -gui.EASING_OUTINBACK = nil - ----out-in-bounce -gui.EASING_OUTINBOUNCE = nil - ----out-in-circlic -gui.EASING_OUTINCIRC = nil - ----out-in-cubic -gui.EASING_OUTINCUBIC = nil - ----out-in-elastic -gui.EASING_OUTINELASTIC = nil - ----out-in-exponential -gui.EASING_OUTINEXPO = nil - ----out-in-quadratic -gui.EASING_OUTINQUAD = nil - ----out-in-quartic -gui.EASING_OUTINQUART = nil - ----out-in-quintic -gui.EASING_OUTINQUINT = nil - ----out-in-sine -gui.EASING_OUTINSINE = nil - ----out-quadratic -gui.EASING_OUTQUAD = nil - ----out-quartic -gui.EASING_OUTQUART = nil - ----out-quintic -gui.EASING_OUTQUINT = nil - ----out-sine -gui.EASING_OUTSINE = nil - ----default keyboard -gui.KEYBOARD_TYPE_DEFAULT = nil - ----email keyboard -gui.KEYBOARD_TYPE_EMAIL = nil - ----number input keyboard -gui.KEYBOARD_TYPE_NUMBER_PAD = nil - ----password keyboard -gui.KEYBOARD_TYPE_PASSWORD = nil - ----elliptical pie node bounds -gui.PIEBOUNDS_ELLIPSE = nil - ----rectangular pie node bounds -gui.PIEBOUNDS_RECTANGLE = nil - ----center pivot -gui.PIVOT_CENTER = nil - ----east pivot -gui.PIVOT_E = nil - ----north pivot -gui.PIVOT_N = nil - ----north-east pivot -gui.PIVOT_NE = nil - ----north-west pivot -gui.PIVOT_NW = nil - ----south pivot -gui.PIVOT_S = nil - ----south-east pivot -gui.PIVOT_SE = nil - ----south-west pivot -gui.PIVOT_SW = nil - ----west pivot -gui.PIVOT_W = nil - ----loop backward -gui.PLAYBACK_LOOP_BACKWARD = nil - ----loop forward -gui.PLAYBACK_LOOP_FORWARD = nil - ----ping pong loop -gui.PLAYBACK_LOOP_PINGPONG = nil - ----once backward -gui.PLAYBACK_ONCE_BACKWARD = nil - ----once forward -gui.PLAYBACK_ONCE_FORWARD = nil - ----once forward and then backward -gui.PLAYBACK_ONCE_PINGPONG = nil - ----color property -gui.PROP_COLOR = nil - ----euler property -gui.PROP_EULER = nil - ----fill_angle property -gui.PROP_FILL_ANGLE = nil - ----inner_radius property -gui.PROP_INNER_RADIUS = nil - ----outline color property -gui.PROP_OUTLINE = nil - ----position property -gui.PROP_POSITION = nil - ----rotation property -gui.PROP_ROTATION = nil - ----scale property -gui.PROP_SCALE = nil - ----shadow color property -gui.PROP_SHADOW = nil - ----size property -gui.PROP_SIZE = nil - ----slice9 property -gui.PROP_SLICE9 = nil - ----The provided data is not in the expected format or is in some other way ----incorrect, for instance the image data provided to gui.new_texture(). -gui.RESULT_DATA_ERROR = nil - ----The system is out of resources, for instance when trying to create a new ----texture using gui.new_texture(). -gui.RESULT_OUT_OF_RESOURCES = nil - ----The texture id already exists when trying to use gui.new_texture(). -gui.RESULT_TEXTURE_ALREADY_EXISTS = nil - ----The size of the node is determined by the currently assigned texture. -gui.SIZE_MODE_AUTO = nil - ----The size of the node is determined by the size set in the editor, the constructor or by gui.set_size() -gui.SIZE_MODE_MANUAL = nil - ----This starts an animation of a node property according to the specified parameters. ----If the node property is already being animated, that animation will be canceled and ----replaced by the new one. Note however that several different node properties ----can be animated simultaneously. Use gui.cancel_animation to stop the animation ----before it has completed. ----Composite properties of type vector3, vector4 or quaternion ----also expose their sub-components (x, y, z and w). ----You can address the components individually by suffixing the name with a dot '.' ----and the name of the component. ----For instance, "position.x" (the position x coordinate) or "color.w" ----(the color alpha value). ----If a complete_function (Lua function) is specified, that function will be called ----when the animation has completed. ----By starting a new animation in that function, several animations can be sequenced ----together. See the examples below for more information. ----@param node node node to animate ----@param property string|constant property to animate ---- ----"position" ----"rotation" ----"euler" ----"scale" ----"color" ----"outline" ----"shadow" ----"size" ----"fill_angle" (pie) ----"inner_radius" (pie) ----"slice9" (slice9) ---- ----The following property constants are defined equaling the corresponding property string names. ---- ----gui.PROP_POSITION ----gui.PROP_ROTATION ----gui.PROP_EULER ----gui.PROP_SCALE ----gui.PROP_COLOR ----gui.PROP_OUTLINE ----gui.PROP_SHADOW ----gui.PROP_SIZE ----gui.PROP_FILL_ANGLE ----gui.PROP_INNER_RADIUS ----gui.PROP_SLICE9 ---- ----@param to number|vector3|vector4|quaternion target property value ----@param easing constant|vector4|vector3 easing to use during animation. ---- Either specify one of the gui.EASING_* constants or provide a ---- vector with a custom curve. See the animation guide for more information. ----@param duration number duration of the animation in seconds. ----@param delay number|nil delay before the animation starts in seconds. ----@param complete_function fun(self, node)|nil function to call when the ---- animation has completed ----@param playback constant|nil playback mode ---- ----gui.PLAYBACK_ONCE_FORWARD ----gui.PLAYBACK_ONCE_BACKWARD ----gui.PLAYBACK_ONCE_PINGPONG ----gui.PLAYBACK_LOOP_FORWARD ----gui.PLAYBACK_LOOP_BACKWARD ----gui.PLAYBACK_LOOP_PINGPONG ---- -function gui.animate(node, property, to, easing, duration, delay, complete_function, playback) end - ----If an animation of the specified node is currently running (started by gui.animate), it will immediately be canceled. ----@param node node node that should have its animation canceled ----@param property string|constant property for which the animation should be canceled ---- ----"position" ----"rotation" ----"euler" ----"scale" ----"color" ----"outline" ----"shadow" ----"size" ----"fill_angle" (pie) ----"inner_radius" (pie) ----"slice9" (slice9) ---- -function gui.cancel_animation(node, property) end - ----Cancels any running flipbook animation on the specified node. ----@param node node node cancel flipbook animation for -function gui.cancel_flipbook(node) end - ----Make a clone instance of a node. The cloned node will be identical to the ----original node, except the id which is generated as the string "node" plus ----a sequential unsigned integer value. ----This function does not clone the supplied node's children nodes. ----Use gui.clone_tree for that purpose. ----@param node node node to clone ----@return node clone the cloned node -function gui.clone(node) end - ----Make a clone instance of a node and all its children. ----Use gui.clone to clone a node excluding its children. ----@param node node root node to clone ----@return table clones a table mapping node ids to the corresponding cloned nodes -function gui.clone_tree(node) end - ----Deletes the specified node. Any child nodes of the specified node will be ----recursively deleted. ----@param node node node to delete -function gui.delete_node(node) end - ----Delete a dynamically created texture. ----@param texture string|hash texture id -function gui.delete_texture(texture) end - ----Instead of using specific getters such as gui.get_position or gui.get_scale, ----you can use gui.get instead and supply the property as a string or a hash. ----While this function is similar to go.get, there are a few more restrictions ----when operating in the gui namespace. Most notably, only these propertie identifiers are supported: ----"position" ----"rotation" ----"euler" ----"scale" ----"color" ----"outline" ----"shadow" ----"size" ----"fill_angle" (pie) ----"inner_radius" (pie) ----"slice9" (slice9) ----The value returned will either be a vmath.vector4 or a single number, i.e getting the "position" ----property will return a vec4 while getting the "position.x" property will return a single value. ----@param node node node to get the property for ----@param property string|hash|constant the property to retrieve -function gui.get(node, property) end - ----Returns the adjust mode of a node. ----The adjust mode defines how the node will adjust itself to screen ----resolutions that differs from the one in the project settings. ----@param node node node from which to get the adjust mode (node) ----@return constant adjust_mode the current adjust mode ---- ----gui.ADJUST_FIT ----gui.ADJUST_ZOOM ----gui.ADJUST_STRETCH ---- -function gui.get_adjust_mode(node) end - ----gets the node alpha ----@param node node node from which to get alpha -function gui.get_alpha(node) end - ----Returns the blend mode of a node. ----Blend mode defines how the node will be blended with the background. ----@param node node node from which to get the blend mode ----@return constant blend_mode blend mode ---- ----gui.BLEND_ALPHA ----gui.BLEND_ADD ----gui.BLEND_ADD_ALPHA ----gui.BLEND_MULT ----gui.BLEND_SCREEN ---- -function gui.get_blend_mode(node) end - ----If node is set as an inverted clipping node, it will clip anything inside as opposed to outside. ----@param node node node from which to get the clipping inverted state ----@return boolean inverted true or false -function gui.get_clipping_inverted(node) end - ----Clipping mode defines how the node will clip it's children nodes ----@param node node node from which to get the clipping mode ----@return constant clipping_mode clipping mode ---- ---- gui.CLIPPING_MODE_NONE ---- gui.CLIPPING_MODE_STENCIL ---- -function gui.get_clipping_mode(node) end - ----If node is set as visible clipping node, it will be shown as well as clipping. Otherwise, it will only clip but not show visually. ----@param node node node from which to get the clipping visibility state ----@return boolean visible true or false -function gui.get_clipping_visible(node) end - ----Returns the color of the supplied node. The components ----of the returned vector4 contains the color channel values: ----Component ----Color value ----x ----Red value ----y ----Green value ----z ----Blue value ----w ----Alpha value ----@param node node node to get the color from ----@return vector4 color node color -function gui.get_color(node) end - ----Returns the rotation of the supplied node. ----The rotation is expressed in degree Euler angles. ----@param node node node to get the rotation from ----@return vector3 rotation node rotation -function gui.get_euler(node) end - ----Returns the sector angle of a pie node. ----@param node node node from which to get the fill angle ----@return number angle sector angle -function gui.get_fill_angle(node) end - ----Get node flipbook animation. ----@param node node node to get flipbook animation from ----@return hash animation animation id -function gui.get_flipbook(node) end - ----This is only useful nodes with flipbook animations. Gets the normalized cursor of the flipbook animation on a node. ----@param node node node to get the cursor for (node) ----@return number cursor cursor value -function gui.get_flipbook_cursor(node) end - ----This is only useful nodes with flipbook animations. Gets the playback rate of the flipbook animation on a node. ----@param node node node to set the cursor for ----@return number rate playback rate -function gui.get_flipbook_playback_rate(node) end - ----This is only useful for text nodes. The font must be mapped to the gui scene in the gui editor. ----@param node node node from which to get the font ----@return hash font font id -function gui.get_font(node) end - ----This is only useful for text nodes. The font must be mapped to the gui scene in the gui editor. ----@param font_name hash|string font of which to get the path hash ----@return hash hash path hash to resource -function gui.get_font_resource(font_name) end - ----Returns the scene height. ----@return number height scene height -function gui.get_height() end - ----Retrieves the id of the specified node. ----@param node node the node to retrieve the id from ----@return hash id the id of the node -function gui.get_id(node) end - ----Retrieve the index of the specified node among its siblings. ----The index defines the order in which a node appear in a GUI scene. ----Higher index means the node is drawn on top of lower indexed nodes. ----@param node node the node to retrieve the id from ----@return number index the index of the node -function gui.get_index(node) end - ----gets the node inherit alpha state ----@param node node node from which to get the inherit alpha state -function gui.get_inherit_alpha(node) end - ----Returns the inner radius of a pie node. ----The radius is defined along the x-axis. ----@param node node node from where to get the inner radius ----@return number radius inner radius -function gui.get_inner_radius(node) end - ----The layer must be mapped to the gui scene in the gui editor. ----@param node node node from which to get the layer ----@return hash layer layer id -function gui.get_layer(node) end - ----gets the scene current layout ----@return hash layout layout id -function gui.get_layout() end - ----Returns the leading value for a text node. ----@param node node node from where to get the leading ----@return number leading leading scaling value (default=1) -function gui.get_leading(node) end - ----Returns whether a text node is in line-break mode or not. ----This is only useful for text nodes. ----@param node node node from which to get the line-break for ----@return boolean line_break true or false -function gui.get_line_break(node) end - ----Returns the material of a node. ----The material must be mapped to the gui scene in the gui editor. ----@param node node node to get the material for -function gui.get_material(node) end - ----Retrieves the node with the specified id. ----@param id string|hash id of the node to retrieve ----@return node instance a new node instance -function gui.get_node(id) end - ----Returns the outer bounds mode for a pie node. ----@param node node node from where to get the outer bounds mode ----@return constant bounds_mode the outer bounds mode of the pie node: ---- ----gui.PIEBOUNDS_RECTANGLE ----gui.PIEBOUNDS_ELLIPSE ---- -function gui.get_outer_bounds(node) end - ----Returns the outline color of the supplied node. ----See gui.get_color for info how vectors encode color values. ----@param node node node to get the outline color from ----@return vector4 color outline color -function gui.get_outline(node) end - ----Returns the parent node of the specified node. ----If the supplied node does not have a parent, nil is returned. ----@param node node the node from which to retrieve its parent ----@return node|nil parent parent instance or nil -function gui.get_parent(node) end - ----Get the paricle fx for a gui node ----@param node node node to get particle fx for ----@return hash particlefx particle fx id -function gui.get_particlefx(node) end - ----Returns the number of generated vertices around the perimeter ----of a pie node. ----@param node node pie node ----@return number vertices vertex count -function gui.get_perimeter_vertices(node) end - ----The pivot specifies how the node is drawn and rotated from its position. ----@param node node node to get pivot from ----@return constant pivot pivot constant ---- ---- gui.PIVOT_CENTER ---- gui.PIVOT_N ---- gui.PIVOT_NE ---- gui.PIVOT_E ---- gui.PIVOT_SE ---- gui.PIVOT_S ---- gui.PIVOT_SW ---- gui.PIVOT_W ---- gui.PIVOT_NW ---- -function gui.get_pivot(node) end - ----Returns the position of the supplied node. ----@param node node node to get the position from ----@return vector3 position node position -function gui.get_position(node) end - ----Returns the rotation of the supplied node. ----The rotation is expressed as a quaternion ----@param node node node to get the rotation from ----@return quaternion rotation node rotation -function gui.get_rotation(node) end - ----Returns the scale of the supplied node. ----@param node node node to get the scale from ----@return vector3 scale node scale -function gui.get_scale(node) end - ----Returns the screen position of the supplied node. This function returns the ----calculated transformed position of the node, taking into account any parent node ----transforms. ----@param node node node to get the screen position from ----@return vector3 position node screen position -function gui.get_screen_position(node) end - ----Returns the shadow color of the supplied node. ----See gui.get_color for info how vectors encode color values. ----@param node node node to get the shadow color from ----@return vector4 color node shadow color -function gui.get_shadow(node) end - ----Returns the size of the supplied node. ----@param node node node to get the size from ----@return vector3 size node size -function gui.get_size(node) end - ----Returns the size of a node. ----The size mode defines how the node will adjust itself in size. Automatic ----size mode alters the node size based on the node's content. Automatic size ----mode works for Box nodes and Pie nodes which will both adjust their size ----to match the assigned image. Particle fx and Text nodes will ignore ----any size mode setting. ----@param node node node from which to get the size mode (node) ----@return constant size_mode the current size mode ---- ----gui.SIZE_MODE_MANUAL ----gui.SIZE_MODE_AUTO ---- -function gui.get_size_mode(node) end - ----Returns the slice9 configuration values for the node. ----@param node node node to manipulate ----@return vector4 values configuration values -function gui.get_slice9(node) end - ----Returns the text value of a text node. This is only useful for text nodes. ----@param node node node from which to get the text ----@return string text text value -function gui.get_text(node) end - ----Returns the texture of a node. ----This is currently only useful for box or pie nodes. ----The texture must be mapped to the gui scene in the gui editor. ----@param node node node to get texture from ----@return hash texture texture id -function gui.get_texture(node) end - ----Returns the tracking value of a text node. ----@param node node node from where to get the tracking ----@return number tracking tracking scaling number (default=0) -function gui.get_tracking(node) end - ----Get a node and all its children as a Lua table. ----@param node node root node to get node tree from ----@return table clones a table mapping node ids to the corresponding nodes -function gui.get_tree(node) end - ----Returns true if a node is visible and false if it's not. ----Invisible nodes are not rendered. ----@param node node node to query ----@return boolean visible whether the node is visible or not -function gui.get_visible(node) end - ----Returns the scene width. ----@return number width scene width -function gui.get_width() end - ----The x-anchor specifies how the node is moved when the game is run in a different resolution. ----@param node node node to get x-anchor from ----@return constant anchor anchor constant ---- ----gui.ANCHOR_NONE ----gui.ANCHOR_LEFT ----gui.ANCHOR_RIGHT ---- -function gui.get_xanchor(node) end - ----The y-anchor specifies how the node is moved when the game is run in a different resolution. ----@param node node node to get y-anchor from ----@return constant anchor anchor constant ---- ----gui.ANCHOR_NONE ----gui.ANCHOR_TOP ----gui.ANCHOR_BOTTOM ---- -function gui.get_yanchor(node) end - ----Hides the on-display touch keyboard on the device. -function gui.hide_keyboard() end - ----Returns true if a node is enabled and false if it's not. ----Disabled nodes are not rendered and animations acting on them are not evaluated. ----@param node node node to query ----@param recursive boolean|nil check hierarchy recursively ----@return boolean enabled whether the node is enabled or not -function gui.is_enabled(node, recursive) end - ----Alters the ordering of the two supplied nodes by moving the first node ----above the second. ----If the second argument is nil the first node is moved to the top. ----@param node node to move ----@param reference node|nil reference node above which the first node should be moved -function gui.move_above(node, reference) end - ----Alters the ordering of the two supplied nodes by moving the first node ----below the second. ----If the second argument is nil the first node is moved to the bottom. ----@param node node to move ----@param reference node|nil reference node below which the first node should be moved -function gui.move_below(node, reference) end - ----Dynamically create a new box node. ----@param pos vector3|vector4 node position ----@param size vector3 node size ----@return node node new box node -function gui.new_box_node(pos, size) end - ----Dynamically create a particle fx node. ----@param pos vector3|vector4 node position ----@param particlefx hash|string particle fx resource name ----@return node node new particle fx node -function gui.new_particlefx_node(pos, particlefx) end - ----Dynamically create a new pie node. ----@param pos vector3|vector4 node position ----@param size vector3 node size ----@return node node new pie node -function gui.new_pie_node(pos, size) end - ----Dynamically create a new text node. ----@param pos vector3|vector4 node position ----@param text string node text ----@return node node new text node -function gui.new_text_node(pos, text) end - ----Dynamically create a new texture. ----@param texture_id string|hash texture id ----@param width number texture width ----@param height number texture height ----@param type string|constant texture type ---- ----"rgb" - RGB ----"rgba" - RGBA ----"l" - LUMINANCE ---- ----@param buffer string texture data ----@param flip boolean flip texture vertically ----@return boolean success texture creation was successful ----@return number code one of the gui.RESULT_* codes if unsuccessful -function gui.new_texture(texture_id, width, height, type, buffer, flip) end - ----Tests whether a coordinate is within the bounding box of a ----node. ----@param node node node to be tested for picking ----@param x number x-coordinate (see on_input ) ----@param y number y-coordinate (see on_input ) ----@return boolean pickable pick result -function gui.pick_node(node, x, y) end - ----Play flipbook animation on a box or pie node. ----The current node texture must contain the animation. ----Use this function to set one-frame still images on the node. ----@param node node node to set animation for ----@param animation string|hash animation id ----@param complete_function fun(self, node)|nil optional function to call when the animation has completed ---- ----self ---- ----object The current object. ---- ----node ---- ----node The node that is animated. ---- ---- ----@param play_properties { offset:number|nil, playback_rate:number|nil }|nil optional table with properties ---- ----offset ----number The normalized initial value of the animation cursor when the animation starts playing ----playback_rate ----number The rate with which the animation will be played. Must be positive ---- -function gui.play_flipbook(node, animation, complete_function, play_properties) end - ----Plays the paricle fx for a gui node ----@param node node node to play particle fx for ----@param emitter_state_function fun(self, node, emitter, state)|nil optional callback function that will be called when an emitter attached to this particlefx changes state. ---- ----self ----object The current object ----node ----hash The particle fx node, or nil if the node was deleted ----emitter ----hash The id of the emitter ----state ----constant the new state of the emitter: ---- ---- ----particlefx.EMITTER_STATE_SLEEPING ----particlefx.EMITTER_STATE_PRESPAWN ----particlefx.EMITTER_STATE_SPAWNING ----particlefx.EMITTER_STATE_POSTSPAWN ---- -function gui.play_particlefx(node, emitter_state_function) end - ----Resets the input context of keyboard. This will clear marked text. -function gui.reset_keyboard() end - ----Resets the node material to the material assigned in the gui scene. ----@param node node node to reset the material for -function gui.reset_material(node) end - ----Resets all nodes in the current GUI scene to their initial state. ----The reset only applies to static node loaded from the scene. ----Nodes that are created dynamically from script are not affected. -function gui.reset_nodes() end - ----Convert the screen position to the local position of supplied node ----@param node node node used for getting local transformation matrix ----@param screen_position vector3 screen position ----@return vector3 local_position local position -function gui.screen_to_local(node, screen_position) end - ----Instead of using specific setteres such as gui.set_position or gui.set_scale, ----you can use gui.set instead and supply the property as a string or a hash. ----While this function is similar to go.get and go.set, there are a few more restrictions ----when operating in the gui namespace. Most notably, only these propertie identifiers are supported: ----"position" ----"rotation" ----"euler" ----"scale" ----"color" ----"outline" ----"shadow" ----"size" ----"fill_angle" (pie) ----"inner_radius" (pie) ----"slice9" (slice9) ----The value to set must either be a vmath.vector4, vmath.vector3, vmath.quat or a single number and depends on the property name you want to set. ----I.e when setting the "position" property, you need to use a vmath.vector4 and when setting a single component of the property, ----such as "position.x", you need to use a single value. ----Note: When setting the rotation using the "rotation" property, you need to pass in a vmath.quat. This behaviour is different than from the gui.set_rotation function, ----the intention is to move new functionality closer to go namespace so that migrating between gui and go is easier. To set the rotation using degrees instead, ----use the "euler" property instead. The rotation and euler properties are linked, changing one of them will change the backing data of the other. ----@param node node node to set the property for ----@param property string|hash|constant the property to set ----@param value number|vector4|vector3|quaternion the property to set -function gui.set(node, property, value) end - ----Sets the adjust mode on a node. ----The adjust mode defines how the node will adjust itself to screen ----resolutions that differs from the one in the project settings. ----@param node node node to set adjust mode for ----@param adjust_mode constant adjust mode to set ---- ----gui.ADJUST_FIT ----gui.ADJUST_ZOOM ----gui.ADJUST_STRETCH ---- -function gui.set_adjust_mode(node, adjust_mode) end - ----sets the node alpha ----@param node node node for which to set alpha ----@param alpha number 0..1 alpha color -function gui.set_alpha(node, alpha) end - ----Set the blend mode of a node. ----Blend mode defines how the node will be blended with the background. ----@param node node node to set blend mode for ----@param blend_mode constant blend mode to set ---- ----gui.BLEND_ALPHA ----gui.BLEND_ADD ----gui.BLEND_ADD_ALPHA ----gui.BLEND_MULT ----gui.BLEND_SCREEN ---- -function gui.set_blend_mode(node, blend_mode) end - ----If node is set as an inverted clipping node, it will clip anything inside as opposed to outside. ----@param node node node to set clipping inverted state for ----@param inverted boolean true or false -function gui.set_clipping_inverted(node, inverted) end - ----Clipping mode defines how the node will clip it's children nodes ----@param node node node to set clipping mode for ----@param clipping_mode constant clipping mode to set ---- ---- gui.CLIPPING_MODE_NONE ---- gui.CLIPPING_MODE_STENCIL ---- -function gui.set_clipping_mode(node, clipping_mode) end - ----If node is set as an visible clipping node, it will be shown as well as clipping. Otherwise, it will only clip but not show visually. ----@param node node node to set clipping visibility for ----@param visible boolean true or false -function gui.set_clipping_visible(node, visible) end - ----Sets the color of the supplied node. The components ----of the supplied vector3 or vector4 should contain the color channel values: ----Component ----Color value ----x ----Red value ----y ----Green value ----z ----Blue value ----w vector4 ----Alpha value ----@param node node node to set the color for ----@param color vector3|vector4 new color -function gui.set_color(node, color) end - ----Sets a node to the disabled or enabled state. ----Disabled nodes are not rendered and animations acting on them are not evaluated. ----@param node node node to be enabled/disabled ----@param enabled boolean whether the node should be enabled or not -function gui.set_enabled(node, enabled) end - ----Sets the rotation of the supplied node. ----The rotation is expressed in degree Euler angles. ----@param node node node to set the rotation for ----@param rotation vector3|vector4 new rotation -function gui.set_euler(node, rotation) end - ----Set the sector angle of a pie node. ----@param node node node to set the fill angle for ----@param angle number sector angle -function gui.set_fill_angle(node, angle) end - ----This is only useful nodes with flipbook animations. The cursor is normalized. ----@param node node node to set the cursor for ----@param cursor number cursor value -function gui.set_flipbook_cursor(node, cursor) end - ----This is only useful nodes with flipbook animations. Sets the playback rate of the flipbook animation on a node. Must be positive. ----@param node node node to set the cursor for ----@param playback_rate number playback rate -function gui.set_flipbook_playback_rate(node, playback_rate) end - ----This is only useful for text nodes. ----The font must be mapped to the gui scene in the gui editor. ----@param node node node for which to set the font ----@param font string|hash font id -function gui.set_font(node, font) end - ----Set the id of the specicied node to a new value. ----Nodes created with the gui.new_*_node() functions get ----an empty id. This function allows you to give dynamically ----created nodes an id. ---- No checking is done on the uniqueness of supplied ids. ----It is up to you to make sure you use unique ids. ----@param node node node to set the id for ----@param id string|hash id to set -function gui.set_id(node, id) end - ----sets the node inherit alpha state ----@param node node node from which to set the inherit alpha state ----@param inherit_alpha boolean true or false -function gui.set_inherit_alpha(node, inherit_alpha) end - ----Sets the inner radius of a pie node. ----The radius is defined along the x-axis. ----@param node node node to set the inner radius for ----@param radius number inner radius -function gui.set_inner_radius(node, radius) end - ----The layer must be mapped to the gui scene in the gui editor. ----@param node node node for which to set the layer ----@param layer string|hash layer id -function gui.set_layer(node, layer) end - ----Sets the leading value for a text node. This value is used to ----scale the line spacing of text. ----@param node node node for which to set the leading ----@param leading number a scaling value for the line spacing (default=1) -function gui.set_leading(node, leading) end - ----Sets the line-break mode on a text node. ----This is only useful for text nodes. ----@param node node node to set line-break for ----@param line_break boolean true or false -function gui.set_line_break(node, line_break) end - ----Set the material on a node. The material must be mapped to the gui scene in the gui editor, ----and assigning a material is supported for all node types. To set the default material that ----is assigned to the gui scene node, use gui.reset_material(node_id) instead. ----@param node node node to set material for ----@param material string|hash material id -function gui.set_material(node, material) end - ----Sets the outer bounds mode for a pie node. ----@param node node node for which to set the outer bounds mode ----@param bounds_mode constant the outer bounds mode of the pie node: ---- ----gui.PIEBOUNDS_RECTANGLE ----gui.PIEBOUNDS_ELLIPSE ---- -function gui.set_outer_bounds(node, bounds_mode) end - ----Sets the outline color of the supplied node. ----See gui.set_color for info how vectors encode color values. ----@param node node node to set the outline color for ----@param color vector3|vector4 new outline color -function gui.set_outline(node, color) end - ----Sets the parent node of the specified node. ----@param node node node for which to set its parent ----@param parent node|nil parent node to set, pass nil to remove parent ----@param keep_scene_transform boolean|nil optional flag to make the scene position being perserved -function gui.set_parent(node, parent, keep_scene_transform) end - ----Set the paricle fx for a gui node ----@param node node node to set particle fx for ----@param particlefx hash|string particle fx id -function gui.set_particlefx(node, particlefx) end - ----Sets the number of generated vertices around the perimeter of a pie node. ----@param node node pie node ----@param vertices number vertex count -function gui.set_perimeter_vertices(node, vertices) end - ----The pivot specifies how the node is drawn and rotated from its position. ----@param node node node to set pivot for ----@param pivot constant pivot constant ---- ---- gui.PIVOT_CENTER ---- gui.PIVOT_N ---- gui.PIVOT_NE ---- gui.PIVOT_E ---- gui.PIVOT_SE ---- gui.PIVOT_S ---- gui.PIVOT_SW ---- gui.PIVOT_W ---- gui.PIVOT_NW ---- -function gui.set_pivot(node, pivot) end - ----Sets the position of the supplied node. ----@param node node node to set the position for ----@param position vector3|vector4 new position -function gui.set_position(node, position) end - ----Set the order number for the current GUI scene. ----The number dictates the sorting of the "gui" render predicate, ----in other words in which order the scene will be rendered in relation ----to other currently rendered GUI scenes. ----The number must be in the range 0 to 15. ----@param order number rendering order (0-15) -function gui.set_render_order(order) end - ----Sets the rotation of the supplied node. ----The rotation is expressed as a quaternion ----@param node node node to set the rotation for ----@param rotation quaternion|vector4 new rotation -function gui.set_rotation(node, rotation) end - ----Sets the scaling of the supplied node. ----@param node node node to set the scale for ----@param scale vector3|vector4 new scale -function gui.set_scale(node, scale) end - ----Set the screen position to the supplied node ----@param node node node to set the screen position to ----@param screen_position vector3 screen position -function gui.set_screen_position(node, screen_position) end - ----Sets the shadow color of the supplied node. ----See gui.set_color for info how vectors encode color values. ----@param node node node to set the shadow color for ----@param color vector3|vector4 new shadow color -function gui.set_shadow(node, color) end - ----Sets the size of the supplied node. ---- You can only set size on nodes with size mode set to SIZE_MODE_MANUAL ----@param node node node to set the size for ----@param size vector3|vector4 new size -function gui.set_size(node, size) end - ----Sets the size mode of a node. ----The size mode defines how the node will adjust itself in size. Automatic ----size mode alters the node size based on the node's content. Automatic size ----mode works for Box nodes and Pie nodes which will both adjust their size ----to match the assigned image. Particle fx and Text nodes will ignore ----any size mode setting. ----@param node node node to set size mode for ----@param size_mode constant size mode to set ---- ----gui.SIZE_MODE_MANUAL ----gui.SIZE_MODE_AUTO ---- -function gui.set_size_mode(node, size_mode) end - ----Set the slice9 configuration values for the node. ----@param node node node to manipulate ----@param values vector4 new values -function gui.set_slice9(node, values) end - ----Set the text value of a text node. This is only useful for text nodes. ----@param node node node to set text for ----@param text string|number text to set -function gui.set_text(node, text) end - ----Set the texture on a box or pie node. The texture must be mapped to ----the gui scene in the gui editor. The function points out which texture ----the node should render from. If the texture is an atlas, further ----information is needed to select which image/animation in the atlas ----to render. In such cases, use gui.play_flipbook() in ----addition to this function. ----@param node node node to set texture for ----@param texture string|hash texture id -function gui.set_texture(node, texture) end - ----Set the texture buffer data for a dynamically created texture. ----@param texture string|hash texture id ----@param width number texture width ----@param height number texture height ----@param type string|constant texture type ---- ---- "rgb" - RGB ---- "rgba" - RGBA ---- "l" - LUMINANCE ---- ----@param buffer string texture data ----@param flip boolean flip texture vertically ----@return boolean success setting the data was successful -function gui.set_texture_data(texture, width, height, type, buffer, flip) end - ----Sets the tracking value of a text node. This value is used to ----adjust the vertical spacing of characters in the text. ----@param node node node for which to set the tracking ----@param tracking number a scaling number for the letter spacing (default=0) -function gui.set_tracking(node, tracking) end - ----Set if a node should be visible or not. Only visible nodes are rendered. ----@param node node node to be visible or not ----@param visible boolean whether the node should be visible or not -function gui.set_visible(node, visible) end - ----The x-anchor specifies how the node is moved when the game is run in a different resolution. ----@param node node node to set x-anchor for ----@param anchor constant anchor constant ---- ----gui.ANCHOR_NONE ----gui.ANCHOR_LEFT ----gui.ANCHOR_RIGHT ---- -function gui.set_xanchor(node, anchor) end - ----The y-anchor specifies how the node is moved when the game is run in a different resolution. ----@param node node node to set y-anchor for ----@param anchor constant anchor constant ---- ----gui.ANCHOR_NONE ----gui.ANCHOR_TOP ----gui.ANCHOR_BOTTOM ---- -function gui.set_yanchor(node, anchor) end - ----Shows the on-display touch keyboard. ----The specified type of keyboard is displayed if it is available on ----the device. ----This function is only available on iOS and Android. . ----@param type constant keyboard type ---- ----gui.KEYBOARD_TYPE_DEFAULT ----gui.KEYBOARD_TYPE_EMAIL ----gui.KEYBOARD_TYPE_NUMBER_PAD ----gui.KEYBOARD_TYPE_PASSWORD ---- ----@param autoclose boolean if the keyboard should automatically close when clicking outside -function gui.show_keyboard(type, autoclose) end - ----Stops the particle fx for a gui node ----@param node node node to stop particle fx for ----@param options { clear:boolean|nil }|nil options when stopping the particle fx. Supported options: ---- ----boolean clear: instantly clear spawned particles ---- -function gui.stop_particlefx(node, options) end - - - -return gui \ No newline at end of file diff --git a/annotations/defold_annotations/html5.lua b/annotations/defold_annotations/html5.lua deleted file mode 100644 index 6b2c506..0000000 --- a/annotations/defold_annotations/html5.lua +++ /dev/null @@ -1,37 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - HTML5 API documentation - - HTML5 platform specific functions. - The following functions are only available on HTML5 builds, the html5.* Lua namespace will not be available on other platforms. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.html5 -html5 = {} - ----Executes the supplied string as JavaScript inside the browser. ----A call to this function is blocking, the result is returned as-is, as a string. ----(Internally this will execute the string using the eval() JavaScript function.) ----@param code string Javascript code to run ----@return string result result as string -function html5.run(code) end - ----Set a JavaScript interaction listener callaback from lua that will be ----invoked when a user interacts with the web page by clicking, touching or typing. ----The callback can then call DOM restricted actions like requesting a pointer lock, ----or start playing sounds the first time the callback is invoked. ----@param callback fun(self)|nil The interaction callback. Pass an empty function or nil if you no longer wish to receive callbacks. ---- ----self ----object The calling script ---- -function html5.set_interaction_listener(callback) end - -return html5 \ No newline at end of file diff --git a/annotations/defold_annotations/http.lua b/annotations/defold_annotations/http.lua deleted file mode 100644 index a44c8b4..0000000 --- a/annotations/defold_annotations/http.lua +++ /dev/null @@ -1,49 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - HTTP API documentation - - Functions for performing HTTP and HTTPS requests. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.http -http = {} - ----Perform a HTTP/HTTPS request. ---- If no timeout value is passed, the configuration value "network.http_timeout" is used. If that is not set, the timeout value is 0 (which blocks indefinitely). ----@param url string target url ----@param method string HTTP/HTTPS method, e.g. "GET", "PUT", "POST" etc. ----@param callback fun(self, id, response) response callback function ---- ----self ----object The script instance ----id ----hash Internal message identifier. Do not use! ----response ----table The response data. Contains the fields: ---- ---- ----number status: the status of the response ----string response: the response data (if not saved on disc) ----table headers: all the returned headers ----string path: the stored path (if saved to disc) ----string error: if any unforeseen errors occurred (e.g. file I/O) ---- ----@param headers table|nil optional table with custom headers ----@param post_data string|nil optional data to send ----@param options table|nil optional table with request parameters. Supported entries: ---- ----number timeout: timeout in seconds ----string path: path on disc where to download the file. Only overwrites the path if status is 200. Path should be absolute ----boolean ignore_cache: don't return cached data if we get a 304. Not available in HTML5 build ----boolean chunked_transfer: use chunked transfer encoding for https requests larger than 16kb. Defaults to true. Not available in HTML5 build ---- -function http.request(url, method, callback, headers, post_data, options) end - -return http \ No newline at end of file diff --git a/annotations/defold_annotations/image.lua b/annotations/defold_annotations/image.lua deleted file mode 100644 index caa4738..0000000 --- a/annotations/defold_annotations/image.lua +++ /dev/null @@ -1,78 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Image API documentation - - Functions for creating image objects. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.image -image = {} - ----luminance image type -image.TYPE_LUMINANCE = nil - ----luminance image type -image.TYPE_LUMINANCE_ALPHA = nil - ----RGB image type -image.TYPE_RGB = nil - ----RGBA image type -image.TYPE_RGBA = nil - ----Load image (PNG or JPEG) from buffer. ----@param buffer string image data buffer ----@param options table|nil An optional table containing parameters for loading the image. Supported entries: ---- ----premultiply_alpha ----boolean True if alpha should be premultiplied into the color components. Defaults to false. ----flip_vertically ----boolean True if the image contents should be flipped vertically. Defaults to false. ---- ----@return { width:number, height:number, type:constant, buffer:string }|nil image object or nil if loading fails. The object is a table with the following fields: ---- ----number width: image width ----number height: image height ----constant type: image type ----image.TYPE_RGB ----image.TYPE_RGBA ----image.TYPE_LUMINANCE ----image.TYPE_LUMINANCE_ALPHA ---- ---- ----string buffer: the raw image data ---- -function image.load(buffer, options) end - ----Load image (PNG or JPEG) from a string buffer. ----@param buffer string image data buffer ----@param options table|nil An optional table containing parameters for loading the image. Supported entries: ---- ----premultiply_alpha ----boolean True if alpha should be premultiplied into the color components. Defaults to false. ----flip_vertically ----boolean True if the image contents should be flipped vertically. Defaults to false. ---- ----@return { width:number, height:number, type:constant, buffer:buffer_data }|nil image object or nil if loading fails. The object is a table with the following fields: ---- ----number width: image width ----number height: image height ----constant type: image type ----image.TYPE_RGB ----image.TYPE_RGBA ----image.TYPE_LUMINANCE ----image.TYPE_LUMINANCE_ALPHA ---- ---- ----buffer buffer: the script buffer that holds the decompressed image data. See buffer.create how to use the buffer. ---- -function image.load_buffer(buffer, options) end - -return image \ No newline at end of file diff --git a/annotations/defold_annotations/json.lua b/annotations/defold_annotations/json.lua deleted file mode 100644 index f45e862..0000000 --- a/annotations/defold_annotations/json.lua +++ /dev/null @@ -1,41 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - JSON API documentation - - Manipulation of JSON data strings. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.json -json = {} - ----Represents the null primitive from a json file -json.null = nil - ----Decode a string of JSON data into a Lua table. ----A Lua error is raised for syntax errors. ----@param json string json data ----@param options { decode_null_as_userdata:boolean|nil }|nil table with decode options ---- ----bool decode_null_as_userdata: wether to decode a JSON null value as json.null or nil (default is nil) ---- ----@return table data decoded json -function json.decode(json, options) end - ----Encode a lua table to a JSON string. ----A Lua error is raised for syntax errors. ----@param tbl table lua table to encode ----@param options { encode_empty_table_as_object:string }|nil table with encode options ---- ----string encode_empty_table_as_object: wether to encode an empty table as an JSON object or array (default is object) ---- ----@return string json encoded json -function json.encode(tbl, options) end - -return json \ No newline at end of file diff --git a/annotations/defold_annotations/label.lua b/annotations/defold_annotations/label.lua deleted file mode 100644 index f41b7f7..0000000 --- a/annotations/defold_annotations/label.lua +++ /dev/null @@ -1,28 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Label API documentation ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.label -label = {} - ----Gets the text from a label component ----@param url string|hash|url the label to get the text from ----@return string metrics the label text -function label.get_text(url) end - ----Sets the text of a label component ---- This method uses the message passing that means the value will be set after dispatch messages step. ----More information is available in the Application Lifecycle manual. ----@param url string|hash|url the label that should have a constant set ----@param text string the text -function label.set_text(url, text) end - -return label \ No newline at end of file diff --git a/annotations/defold_annotations/liveupdate.lua b/annotations/defold_annotations/liveupdate.lua deleted file mode 100644 index 94e717a..0000000 --- a/annotations/defold_annotations/liveupdate.lua +++ /dev/null @@ -1,155 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - LiveUpdate API documentation - - Functions and constants to access resources. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.liveupdate -liveupdate = {} - ----Mismatch between between expected bundled resources and actual bundled resources. The manifest expects a resource to be in the bundle, but it was not found in the bundle. This is typically the case when a non-excluded resource was modified between publishing the bundle and publishing the manifest. -liveupdate.LIVEUPDATE_BUNDLED_RESOURCE_MISMATCH = nil - ----Mismatch between running engine version and engine versions supported by manifest. -liveupdate.LIVEUPDATE_ENGINE_VERSION_MISMATCH = nil - ----Failed to parse manifest data buffer. The manifest was probably produced by a different engine version. -liveupdate.LIVEUPDATE_FORMAT_ERROR = nil - ----Argument was invalid -liveupdate.LIVEUPDATE_INVAL = nil - ----The handled resource is invalid. -liveupdate.LIVEUPDATE_INVALID_HEADER = nil - ----The header of the resource is invalid. -liveupdate.LIVEUPDATE_INVALID_RESOURCE = nil - ----I/O operation failed -liveupdate.LIVEUPDATE_IO_ERROR = nil - ----Memory wasn't allocated -liveupdate.LIVEUPDATE_MEM_ERROR = nil - ----LIVEUPDATE_OK -liveupdate.LIVEUPDATE_OK = nil - ----Mismatch between scheme used to load resources. Resources are loaded with a different scheme than from manifest, for example over HTTP or directly from file. This is typically the case when running the game directly from the editor instead of from a bundle. -liveupdate.LIVEUPDATE_SCHEME_MISMATCH = nil - ----Mismatch between manifest expected signature and actual signature. -liveupdate.LIVEUPDATE_SIGNATURE_MISMATCH = nil - ----Unspecified error -liveupdate.LIVEUPDATE_UNKNOWN = nil - ----Mismatch between manifest expected version and actual version. -liveupdate.LIVEUPDATE_VERSION_MISMATCH = nil - ----Adds a resource mount to the resource system. ----The mounts are persisted between sessions. ----After the mount succeeded, the resources are available to load. (i.e. no reboot required) ----@param name string Unique name of the mount ----@param uri string The uri of the mount, including the scheme. Currently supported schemes are 'zip' and 'archive'. ----@param priority integer Priority of mount. Larger priority takes prescedence ----@param callback function Callback after the asynchronous request completed ----@return number result The result of the request -function liveupdate.add_mount(name, uri, priority, callback) end - ----Return a reference to the Manifest that is currently loaded. ----@return number manifest_reference reference to the Manifest that is currently loaded -function liveupdate.get_current_manifest() end - ----Get an array of the current mounts ----This can be used to determine if a new mount is needed or not ----@return array mounts Array of mounts -function liveupdate.get_mounts() end - ----Is any liveupdate data mounted and currently in use? ----This can be used to determine if a new manifest or zip file should be downloaded. ----@return bool bool true if a liveupdate archive (any format) has been loaded -function liveupdate.is_using_liveupdate_data() end - ----Remove a mount the resource system. ----The remaining mounts are persisted between sessions. ----Removing a mount does not affect any loaded resources. ----@param name string Unique name of the mount ----@return number result The result of the call -function liveupdate.remove_mount(name) end - ----Stores a zip file and uses it for live update content. The contents of the ----zip file will be verified against the manifest to ensure file integrity. ----It is possible to opt out of the resource verification using an option passed ----to this function. ----The path is stored in the (internal) live update location. ----@param path string the path to the original file on disc ----@param callback fun(self, status) the callback function ----executed after the storage has completed ---- ----self ----object The current object. ----status ----constant the status of the store operation (See liveupdate.store_manifest) ---- ----@param options table|nil optional table with extra parameters. Supported entries: ---- ----boolean verify: if archive should be verified as well as stored (defaults to true) ---- -function liveupdate.store_archive(path, callback, options) end - ----Create a new manifest from a buffer. The created manifest is verified ----by ensuring that the manifest was signed using the bundled public/private ----key-pair during the bundle process and that the manifest supports the current ----running engine version. Once the manifest is verified it is stored on device. ----The next time the engine starts (or is rebooted) it will look for the stored ----manifest before loading resources. Storing a new manifest allows the ----developer to update the game, modify existing resources, or add new ----resources to the game through LiveUpdate. ----@param manifest_buffer string the binary data that represents the manifest ----@param callback fun(self, status) the callback function ----executed once the engine has attempted to store the manifest. ---- ----self ----object The current object. ----status ----constant the status of the store operation: ---- ---- ----liveupdate.LIVEUPDATE_OK ----liveupdate.LIVEUPDATE_INVALID_RESOURCE ----liveupdate.LIVEUPDATE_VERSION_MISMATCH ----liveupdate.LIVEUPDATE_ENGINE_VERSION_MISMATCH ----liveupdate.LIVEUPDATE_SIGNATURE_MISMATCH ----liveupdate.LIVEUPDATE_BUNDLED_RESOURCE_MISMATCH ----liveupdate.LIVEUPDATE_FORMAT_ERROR ---- -function liveupdate.store_manifest(manifest_buffer, callback) end - ----add a resource to the data archive and runtime index. The resource will be verified ----internally before being added to the data archive. ----@param manifest_reference number The manifest to check against. ----@param data string The resource data that should be stored. ----@param hexdigest string The expected hash for the resource, ----retrieved through collectionproxy.missing_resources. ----@param callback fun(self, hexdigest, status) The callback ----function that is executed once the engine has been attempted to store ----the resource. ---- ----self ----object The current object. ----hexdigest ----string The hexdigest of the resource. ----status ----boolean Whether or not the resource was successfully stored. ---- -function liveupdate.store_resource(manifest_reference, data, hexdigest, callback) end - -return liveupdate \ No newline at end of file diff --git a/annotations/defold_annotations/model.lua b/annotations/defold_annotations/model.lua deleted file mode 100644 index 66b8580..0000000 --- a/annotations/defold_annotations/model.lua +++ /dev/null @@ -1,92 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Model API documentation ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.model -model = {} - ----Cancels all animation on a model component. ----@param url string|hash|url the model for which to cancel the animation -function model.cancel(url) end - ----Gets the id of the game object that corresponds to a model skeleton bone. ----The returned game object can be used for parenting and transform queries. ----This function has complexity O(n), where n is the number of bones in the model skeleton. ----Game objects corresponding to a model skeleton bone can not be individually deleted. ----@param url string|hash|url the model to query ----@param bone_id string|hash id of the corresponding bone ----@return hash id id of the game object -function model.get_go(url, bone_id) end - ----Get the enabled state of a mesh ----@param url string|hash|url the model ----@param mesh_id string|hash|url the id of the mesh ----@return boolean enabled true if the mesh is visible, false otherwise -function model.get_mesh_enabled(url, mesh_id) end - ----Plays an animation on a model component with specified playback ----mode and parameters. ----An optional completion callback function can be provided that will be called when ----the animation has completed playing. If no function is provided, ----a model_animation_done message is sent to the script that started the animation. ---- The callback is not called (or message sent) if the animation is ----cancelled with model.cancel. The callback is called (or message sent) only for ----animations that play with the following playback modes: ----go.PLAYBACK_ONCE_FORWARD ----go.PLAYBACK_ONCE_BACKWARD ----go.PLAYBACK_ONCE_PINGPONG ----@param url string|hash|url the model for which to play the animation ----@param anim_id string|hash id of the animation to play ----@param playback constant playback mode of the animation ---- ----go.PLAYBACK_ONCE_FORWARD ----go.PLAYBACK_ONCE_BACKWARD ----go.PLAYBACK_ONCE_PINGPONG ----go.PLAYBACK_LOOP_FORWARD ----go.PLAYBACK_LOOP_BACKWARD ----go.PLAYBACK_LOOP_PINGPONG ---- ----@param play_properties { blend_duration:number|nil, offset:number|nil, playback_rate:number|nil}|nil optional table with properties ----Play properties table: ---- ----blend_duration ----number Duration of a linear blend between the current and new animation. ----offset ----number The normalized initial value of the animation cursor when the animation starts playing. ----playback_rate ----number The rate with which the animation will be played. Must be positive. ---- ----@param complete_function fun(self, message_id, message, sender)|nil function to call when the animation has completed. ---- ----self ----object The current object. ----message_id ----hash The name of the completion message, "model_animation_done". ----message ----table Information about the completion: ---- ---- ----hash animation_id - the animation that was completed. ----constant playback - the playback mode for the animation. ---- ---- ----sender ----url The invoker of the callback: the model component. ---- -function model.play_anim(url, anim_id, playback, play_properties, complete_function) end - ----Enable or disable visibility of a mesh ----@param url string|hash|url the model ----@param mesh_id string|hash|url the id of the mesh ----@param enabled boolean true if the mesh should be visible, false if it should be hideen -function model.set_mesh_enabled(url, mesh_id, enabled) end - -return model \ No newline at end of file diff --git a/annotations/defold_annotations/msg.lua b/annotations/defold_annotations/msg.lua deleted file mode 100644 index a1b9fb8..0000000 --- a/annotations/defold_annotations/msg.lua +++ /dev/null @@ -1,54 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Messaging API documentation - - Functions for passing messages and constructing URL objects. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.msg -msg = {} - ----Post a message to a receiving URL. The most common case is to send messages ----to a component. If the component part of the receiver is omitted, the message ----is broadcast to all components in the game object. ----The following receiver shorthands are available: ----"." the current game object ----"#" the current component ---- There is a 2 kilobyte limit to the message parameter table size. ----@param receiver string|url|hash The receiver must be a string in URL-format, a URL object or a hashed string. ----@param message_id string|hash The id must be a string or a hashed string. ----@param message table|nil a lua table with message parameters to send. -function msg.post(receiver, message_id, message) end - ----creates a new URL from separate arguments ----@param socket string|hash|nil socket of the URL ----@param path string|hash|nil path of the URL ----@param fragment string|hash|nil fragment of the URL ----@return url url a new URL -function msg.url(socket, path, fragment) end - ----The format of the string must be [socket:][path][#fragment], which is similar to a HTTP URL. ----When addressing instances: ----socket is the name of a valid world (a collection) ----path is the id of the instance, which can either be relative the instance of the calling script or global ----fragment would be the id of the desired component ----In addition, the following shorthands are available: ----"." the current game object ----"#" the current component ----@param urlstring string string to create the url from ----@return url url a new URL -function msg.url(urlstring) end - ----This is equivalent to msg.url(nil) or msg.url("#"), which creates an url to the current ----script component. ----@return url url a new URL -function msg.url() end - -return msg \ No newline at end of file diff --git a/annotations/defold_annotations/particlefx.lua b/annotations/defold_annotations/particlefx.lua deleted file mode 100644 index 752ca90..0000000 --- a/annotations/defold_annotations/particlefx.lua +++ /dev/null @@ -1,85 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Particle effects API documentation - - Functions for controlling particle effect component playback and - shader constants. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.particlefx -particlefx = {} - ----The emitter is not spawning any particles, but has particles that are still alive. -particlefx.EMITTER_STATE_POSTSPAWN = nil - ----The emitter will be in this state when it has been started but before spawning any particles. Normally the emitter is in this state for a short time, depending on if a start delay has been set for this emitter or not. -particlefx.EMITTER_STATE_PRESPAWN = nil - ----The emitter does not have any living particles and will not spawn any particles in this state. -particlefx.EMITTER_STATE_SLEEPING = nil - ----The emitter is spawning particles. -particlefx.EMITTER_STATE_SPAWNING = nil - ----Starts playing a particle FX component. ----Particle FX started this way need to be manually stopped through particlefx.stop(). ----Which particle FX to play is identified by the URL. ---- A particle FX will continue to emit particles even if the game object the particle FX component belonged to is deleted. You can call particlefx.stop() to stop it from emitting more particles. ----@param url string|hash|url the particle fx that should start playing. ----@param emitter_state_function fun(self, id, emitter, state)|nil optional callback function that will be called when an emitter attached to this particlefx changes state. ---- ----self ----object The current object ----id ----hash The id of the particle fx component ----emitter ----hash The id of the emitter ----state ----constant the new state of the emitter: ---- ---- ----particlefx.EMITTER_STATE_SLEEPING ----particlefx.EMITTER_STATE_PRESPAWN ----particlefx.EMITTER_STATE_SPAWNING ----particlefx.EMITTER_STATE_POSTSPAWN ---- -function particlefx.play(url, emitter_state_function) end - ----Resets a shader constant for a particle FX component emitter. ----The constant must be defined in the material assigned to the emitter. ----Resetting a constant through this function implies that the value defined in the material will be used. ----Which particle FX to reset a constant for is identified by the URL. ----@param url string|hash|url the particle FX that should have a constant reset ----@param emitter string|hash the id of the emitter ----@param constant string|hash the name of the constant -function particlefx.reset_constant(url, emitter, constant) end - ----Sets a shader constant for a particle FX component emitter. ----The constant must be defined in the material assigned to the emitter. ----Setting a constant through this function will override the value set for that constant in the material. ----The value will be overridden until particlefx.reset_constant is called. ----Which particle FX to set a constant for is identified by the URL. ----@param url string|hash|url the particle FX that should have a constant set ----@param emitter string|hash the id of the emitter ----@param constant string|hash the name of the constant ----@param value vector4 the value of the constant -function particlefx.set_constant(url, emitter, constant, value) end - ----Stops a particle FX component from playing. ----Stopping a particle FX does not remove already spawned particles. ----Which particle FX to stop is identified by the URL. ----@param url string|hash|url the particle fx that should stop playing ----@param options { clear:boolean|nil }|nil Options when stopping the particle fx. Supported options: ---- ----boolean clear: instantly clear spawned particles ---- -function particlefx.stop(url, options) end - -return particlefx \ No newline at end of file diff --git a/annotations/defold_annotations/physics.lua b/annotations/defold_annotations/physics.lua deleted file mode 100644 index 3fec59f..0000000 --- a/annotations/defold_annotations/physics.lua +++ /dev/null @@ -1,307 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Collision object physics API documentation ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.physics -physics = {} - ----The following properties are available when connecting a joint of JOINT_TYPE_FIXED type: -physics.JOINT_TYPE_FIXED = nil - ----The following properties are available when connecting a joint of JOINT_TYPE_HINGE type: -physics.JOINT_TYPE_HINGE = nil - ----The following properties are available when connecting a joint of JOINT_TYPE_SLIDER type: -physics.JOINT_TYPE_SLIDER = nil - ----The following properties are available when connecting a joint of JOINT_TYPE_SPRING type: -physics.JOINT_TYPE_SPRING = nil - ----The following properties are available when connecting a joint of JOINT_TYPE_WELD type: -physics.JOINT_TYPE_WELD = nil - ----The following properties are available when connecting a joint of JOINT_TYPE_WHEEL type: -physics.JOINT_TYPE_WHEEL = nil - ---- -physics.SHAPE_TYPE_BOX = nil - ---- -physics.SHAPE_TYPE_CAPSULE = nil - ---- -physics.SHAPE_TYPE_HULL = nil - ---- -physics.SHAPE_TYPE_SPHERE = nil - ----Create a physics joint between two collision object components. ----Note: Currently only supported in 2D physics. ----@param joint_type number the joint type ----@param collisionobject_a string|hash|url first collision object ----@param joint_id string|hash id of the joint ----@param position_a vector3 local position where to attach the joint on the first collision object ----@param collisionobject_b string|hash|url second collision object ----@param position_b vector3 local position where to attach the joint on the second collision object ----@param properties table|nil optional joint specific properties table ----See each joint type for possible properties field. The one field that is accepted for all joint types is: ----- boolean collide_connected: Set this flag to true if the attached bodies should collide. -function physics.create_joint(joint_type, collisionobject_a, joint_id, position_a, collisionobject_b, position_b, properties) end - ----Destroy an already physics joint. The joint has to be created before a ----destroy can be issued. ----Note: Currently only supported in 2D physics. ----@param collisionobject string|hash|url collision object where the joint exist ----@param joint_id string|hash id of the joint -function physics.destroy_joint(collisionobject, joint_id) end - ----Get the gravity in runtime. The gravity returned is not global, it will return ----the gravity for the collection that the function is called from. ----Note: For 2D physics the z component will always be zero. ----@return vector3 gravity gravity vector of collection -function physics.get_gravity() end - ----Returns the group name of a collision object as a hash. ----@param url string|hash|url the collision object to return the group of. ----@return hash group hash value of the group. ----local function check_is_enemy() ---- local group = physics.get_group("#collisionobject") ---- return group == hash("enemy") ----end ---- -function physics.get_group(url) end - ----Get a table for properties for a connected joint. The joint has to be created before ----properties can be retrieved. ----Note: Currently only supported in 2D physics. ----@param collisionobject string|hash|url collision object where the joint exist ----@param joint_id string|hash id of the joint ----@return { collide_connected:boolean|nil } properties properties table. See the joint types for what fields are available, the only field available for all types is: ---- ----boolean collide_connected: Set this flag to true if the attached bodies should collide. ---- -function physics.get_joint_properties(collisionobject, joint_id) end - ----Get the reaction force for a joint. The joint has to be created before ----the reaction force can be calculated. ----Note: Currently only supported in 2D physics. ----@param collisionobject string|hash|url collision object where the joint exist ----@param joint_id string|hash id of the joint ----@return vector3 force reaction force for the joint -function physics.get_joint_reaction_force(collisionobject, joint_id) end - ----Get the reaction torque for a joint. The joint has to be created before ----the reaction torque can be calculated. ----Note: Currently only supported in 2D physics. ----@param collisionobject string|hash|url collision object where the joint exist ----@param joint_id string|hash id of the joint ----@return float torque the reaction torque on bodyB in N*m. -function physics.get_joint_reaction_torque(collisionobject, joint_id) end - ----Returns true if the specified group is set in the mask of a collision ----object, false otherwise. ----@param url string|hash|url the collision object to check the mask of. ----@param group string the name of the group to check for. ----@return boolean maskbit boolean value of the maskbit. 'true' if present, 'false' otherwise. ----local function is_invincible() ---- -- check if the collisionobject would collide with the "bullet" group ---- local invincible = physics.get_maskbit("#collisionobject", "bullet") ---- return invincible ----end ---- -function physics.get_maskbit(url, group) end - ----Gets collision shape data from a collision object ----@param url string|hash|url the collision object. ----@param shape string|hash the name of the shape to get data for. ----@return { type:number|nil, diameter:number|nil, dimensions:vector3|nil, height:number|nil } table A table containing meta data about the physics shape ---- ----type ----number The shape type. Supported values: ---- ---- ----physics.SHAPE_TYPE_SPHERE ----physics.SHAPE_TYPE_BOX ----physics.SHAPE_TYPE_CAPSULE Only supported for 3D physics ----physics.SHAPE_TYPE_HULL ---- ----The returned table contains different fields depending on which type the shape is. ----If the shape is a sphere: ---- ----diameter ----number the diameter of the sphere shape ---- ----If the shape is a box: ---- ----dimensions ----vector3 a vmath.vector3 of the box dimensions ---- ----If the shape is a capsule: ---- ----diameter ----number the diameter of the capsule poles ----height ----number the height of the capsule ---- ----local function get_shape_meta() ---- local sphere = physics.get_shape("#collisionobject", "my_sphere_shape") ---- -- returns a table with sphere.diameter ---- return sphere ----end ---- -function physics.get_shape(url, shape) end - ----Ray casts are used to test for intersections against collision objects in the physics world. ----Collision objects of types kinematic, dynamic and static are tested against. Trigger objects ----do not intersect with ray casts. ----Which collision objects to hit is filtered by their collision groups and can be configured ----through groups. ----@param from vector3 the world position of the start of the ray ----@param to vector3 the world position of the end of the ray ----@param groups table a lua table containing the hashed groups for which to test collisions against ----@param options { all:boolean|nil }|nil a lua table containing options for the raycast. ---- ----all ----boolean Set to true to return all ray cast hits. If false, it will only return the closest hit. ---- ----@return physics.raycast_response[]|physics.raycast_response|nil result It returns a list. If missed it returns nil. See ray_cast_response for details on the returned values. -function physics.raycast(from, to, groups, options) end - ----Ray casts are used to test for intersections against collision objects in the physics world. ----Collision objects of types kinematic, dynamic and static are tested against. Trigger objects ----do not intersect with ray casts. ----Which collision objects to hit is filtered by their collision groups and can be configured ----through groups. ----The actual ray cast will be performed during the physics-update. ----If an object is hit, the result will be reported via a ray_cast_response message. ----If there is no object hit, the result will be reported via a ray_cast_missed message. ----@param from vector3 the world position of the start of the ray ----@param to vector3 the world position of the end of the ray ----@param groups table a lua table containing the hashed groups for which to test collisions against ----@param request_id number|nil a number between [0,-255]. It will be sent back in the response for identification, 0 by default -function physics.raycast_async(from, to, groups, request_id) end - ----Set the gravity in runtime. The gravity change is not global, it will only affect ----the collection that the function is called from. ----Note: For 2D physics the z component of the gravity vector will be ignored. ----@param gravity vector3 the new gravity vector -function physics.set_gravity(gravity) end - ----Updates the group property of a collision object to the specified ----string value. The group name should exist i.e. have been used in ----a collision object in the editor. ----@param url string|hash|url the collision object affected. ----@param group string the new group name to be assigned. ----local function change_collision_group() ---- physics.set_group("#collisionobject", "enemy") ----end ---- -function physics.set_group(url, group) end - ----Flips the collision shapes horizontally for a collision object ----@param url string|hash|url the collision object that should flip its shapes ----@param flip boolean true if the collision object should flip its shapes, false if not -function physics.set_hflip(url, flip) end - ----Updates the properties for an already connected joint. The joint has to be created before ----properties can be changed. ----Note: Currently only supported in 2D physics. ----@param collisionobject string|hash|url collision object where the joint exist ----@param joint_id string|hash id of the joint ----@param properties table joint specific properties table ----Note: The collide_connected field cannot be updated/changed after a connection has been made. -function physics.set_joint_properties(collisionobject, joint_id, properties) end - ----sets a physics world event listener. If a function is set, physics messages will no longer be sent. ----@param callback fun(self, event, data)|nil A callback that receives information about all the physics interactions in this physics world. ---- ----self ----object The calling script ----event ----constant The type of event. Can be one of these messages: ---- ---- ----contact_point_event ----collision_event ----trigger_event ----ray_cast_response ----ray_cast_missed ---- ---- ----data ----table The callback value data is a table that contains event-related data. See the documentation for details on the messages. ---- -function physics.set_listener(callback) end - ----Sets or clears the masking of a group (maskbit) in a collision object. ----@param url string|hash|url the collision object to change the mask of. ----@param group string the name of the group (maskbit) to modify in the mask. ----@param maskbit boolean boolean value of the new maskbit. 'true' to enable, 'false' to disable. ----local function make_invincible() ---- -- no longer collide with the "bullet" group ---- physics.set_maskbit("#collisionobject", "bullet", false) ----end ---- -function physics.set_maskbit(url, group, maskbit) end - ----Sets collision shape data for a collision object. Please note that updating data in 3D ----can be quite costly for box and capsules. Because of the physics engine, the cost ----comes from having to recreate the shape objects when certain shapes needs to be updated. ----@param url string|hash|url the collision object. ----@param shape string|hash the name of the shape to get data for. ----@param table { diameter:number|nil, dimensions:vector3|nil, height:number|nil } the shape data to update the shape with. ----See physics.get_shape for a detailed description of each field in the data table. ----local function set_shape_data() ---- -- set capsule shape data ---- local data = {} ---- data.type = physics.SHAPE_TYPE_CAPSULE ---- data.diameter = 10 ---- data.height = 20 ---- physics.set_shape("#collisionobject", "my_capsule_shape", data) ---- ---- -- set sphere shape data ---- data = {} ---- data.type = physics.SHAPE_TYPE_SPHERE ---- data.diameter = 10 ---- physics.set_shape("#collisionobject", "my_sphere_shape", data) ---- ---- -- set box shape data ---- data = {} ---- data.type = physics.SHAPE_TYPE_BOX ---- data.dimensions = vmath.vector3(10, 10, 5) ---- physics.set_shape("#collisionobject", "my_box_shape", data) ----end ---- -function physics.set_shape(url, shape, table) end - ----Flips the collision shapes vertically for a collision object ----@param url string|hash|url the collision object that should flip its shapes ----@param flip boolean true if the collision object should flip its shapes, false if not -function physics.set_vflip(url, flip) end - ----The function recalculates the density of each shape based on the total area of all shapes and the specified mass, then updates the mass of the body accordingly. ----Note: Currently only supported in 2D physics. ----@param collisionobject string|hash|url the collision object whose mass needs to be updated. ----@param mass number the new mass value to set for the collision object. -function physics.update_mass(collisionobject, mass) end - ----Collision objects tend to fall asleep when inactive for a small period of time for ----efficiency reasons. This function wakes them up. ----@param url string|hash|url the collision object to wake. ----function on_input(self, action_id, action) ---- if action_id == hash("test") and action.pressed then ---- physics.wakeup("#collisionobject") ---- end ----end ---- -function physics.wakeup(url) end - -return physics \ No newline at end of file diff --git a/annotations/defold_annotations/profiler.lua b/annotations/defold_annotations/profiler.lua deleted file mode 100644 index ea988f3..0000000 --- a/annotations/defold_annotations/profiler.lua +++ /dev/null @@ -1,126 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Profiler API documentation - - Functions for getting profiling data in runtime. - More detailed profiling and debugging information available in the manuals. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.profiler -profiler = {} - ----pause on current frame -profiler.MODE_PAUSE = nil - ----start recording -profiler.MODE_RECORD = nil - ----continously show latest frame -profiler.MODE_RUN = nil - ----pause at peak frame -profiler.MODE_SHOW_PEAK_FRAME = nil - ----show full profiler ui -profiler.VIEW_MODE_FULL = nil - ----show mimimal profiler ui -profiler.VIEW_MODE_MINIMIZED = nil - ----Creates and shows or hides and destroys the on-sceen profiler ui ----The profiler is a real-time tool that shows the numbers of milliseconds spent ----in each scope per frame as well as counters. The profiler is very useful for ----tracking down performance and resource problems. ----@param enabled boolean true to enable, false to disable -function profiler.enable_ui(enabled) end - ----Get the percent of CPU usage by the application, as reported by the OS. ---- This function is not available on HTML5. ----For some platforms ( Android, Linux and Windows), this information is only available ----by default in the debug version of the engine. It can be enabled in release version as well ----by checking track_cpu under profiler in the game.project file. ----(This means that the engine will sample the CPU usage in intervalls during execution even in release mode.) ----@return number percent of CPU used by the application -function profiler.get_cpu_usage() end - ----Get the amount of memory used (resident/working set) by the application in bytes, as reported by the OS. ---- This function is not available on HTML5. ----The values are gathered from internal OS functions which correspond to the following; ----OS ----Value ---- iOS MacOSAndroid Linux ----Resident memory ---- Windows ----Working set ---- HTML5 ---- Not available ----@return number bytes used by the application -function profiler.get_memory_usage() end - ----Send a text to the profiler ----@param text string the string to send to the profiler -function profiler.log_text(text) end - ----Get the number of recorded frames in the on-screen profiler ui recording buffer ----@return number frame_count the number of recorded frames, zero if on-screen profiler is disabled -function profiler.recorded_frame_count() end - ----Starts a profile scope. ----@param name string The name of the scope -function profiler.scope_begin(name) end - ----End the current profile scope. -function profiler.scope_end() end - ----Set the on-screen profile mode - run, pause, record or show peak frame ----@param mode constant the mode to set the ui profiler in ---- ----profiler.MODE_RUN This is default mode that continously shows the last frame ----profiler.MODE_PAUSE Pauses on the currently displayed frame ----profiler.MODE_SHOW_PEAK_FRAME Pauses on the currently displayed frame but shows a new frame if that frame is slower ----profiler.MODE_RECORD Records all incoming frames to the recording buffer ---- ----To stop recording, switch to a different mode such as MODE_PAUSE or MODE_RUN. ----You can also use the view_recorded_frame function to display a recorded frame. Doing so stops the recording as well. ----Every time you switch to recording mode the recording buffer is cleared. ----The recording buffer is also cleared when setting the MODE_SHOW_PEAK_FRAME mode. -function profiler.set_ui_mode(mode) end - ----Set the on-screen profile view mode - minimized or expanded ----@param mode constant the view mode to set the ui profiler in ---- ----profiler.VIEW_MODE_FULL The default mode which displays all the ui profiler details ----profiler.VIEW_MODE_MINIMIZED Minimized mode which only shows the top header (fps counters and ui profiler mode) ---- -function profiler.set_ui_view_mode(mode) end - ----Shows or hides the time the engine waits for vsync in the on-screen profiler ----Each frame the engine waits for vsync and depending on your vsync settings and how much time ----your game logic takes this time can dwarf the time in the game logic making it hard to ----see details in the on-screen profiler graph and lists. ----Also, by hiding this the FPS times in the header show the time spent each time excuding the ----time spent waiting for vsync. This shows you how long time your game is spending actively ----working each frame. ----This setting also effects the display of recorded frames but does not affect the actual ----recorded frames so it is possible to toggle this on and off when viewing recorded frames. ----By default the vsync wait times is displayed in the profiler. ----@param visible boolean true to include it in the display, false to hide it. -function profiler.set_ui_vsync_wait_visible(visible) end - ----Pauses and displays a frame from the recording buffer in the on-screen profiler ui ----The frame to show can either be an absolute frame or a relative frame to the current frame. ----@param frame_index table a table where you specify one of the following parameters: ---- ----distance The offset from the currently displayed frame (this is truncated between zero and the number of recorded frames) ----frame The frame index in the recording buffer (1 is first recorded frame) ---- -function profiler.view_recorded_frame(frame_index) end - -return profiler \ No newline at end of file diff --git a/annotations/defold_annotations/render.lua b/annotations/defold_annotations/render.lua deleted file mode 100644 index 6040de2..0000000 --- a/annotations/defold_annotations/render.lua +++ /dev/null @@ -1,689 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Rendering API documentation - - Rendering functions, messages and constants. The "render" namespace is - accessible only from render scripts. - The rendering API was originally built on top of OpenGL ES 2.0, and it uses a subset of the - OpenGL computer graphics rendering API for rendering 2D and 3D computer - graphics. Our current target is OpenGLES 3.0 with fallbacks to 2.0 on some platforms. - It is possible to create materials and write shaders that - require features not in OpenGL ES 2.0, but those will not work cross platform. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.render -render = {} - ---- -render.BLEND_CONSTANT_ALPHA = nil - ---- -render.BLEND_CONSTANT_COLOR = nil - ---- -render.BLEND_DST_ALPHA = nil - ---- -render.BLEND_DST_COLOR = nil - ---- -render.BLEND_ONE = nil - ---- -render.BLEND_ONE_MINUS_CONSTANT_ALPHA = nil - ---- -render.BLEND_ONE_MINUS_CONSTANT_COLOR = nil - ---- -render.BLEND_ONE_MINUS_DST_ALPHA = nil - ---- -render.BLEND_ONE_MINUS_DST_COLOR = nil - ---- -render.BLEND_ONE_MINUS_SRC_ALPHA = nil - ---- -render.BLEND_ONE_MINUS_SRC_COLOR = nil - ---- -render.BLEND_SRC_ALPHA = nil - ---- -render.BLEND_SRC_ALPHA_SATURATE = nil - ---- -render.BLEND_SRC_COLOR = nil - ---- -render.BLEND_ZERO = nil - ---- -render.BUFFER_COLOR0_BIT = nil - ---- -render.BUFFER_COLOR1_BIT = nil - ---- -render.BUFFER_COLOR2_BIT = nil - ---- -render.BUFFER_COLOR3_BIT = nil - ---- -render.BUFFER_COLOR_BIT = nil - ---- -render.BUFFER_DEPTH_BIT = nil - ---- -render.BUFFER_STENCIL_BIT = nil - ---- -render.COMPARE_FUNC_ALWAYS = nil - ---- -render.COMPARE_FUNC_EQUAL = nil - ---- -render.COMPARE_FUNC_GEQUAL = nil - ---- -render.COMPARE_FUNC_GREATER = nil - ---- -render.COMPARE_FUNC_LEQUAL = nil - ---- -render.COMPARE_FUNC_LESS = nil - ---- -render.COMPARE_FUNC_NEVER = nil - ---- -render.COMPARE_FUNC_NOTEQUAL = nil - ---- -render.FACE_BACK = nil - ---- -render.FACE_FRONT = nil - ---- -render.FACE_FRONT_AND_BACK = nil - ---- -render.FILTER_LINEAR = nil - ---- -render.FILTER_NEAREST = nil - ---- -render.FORMAT_DEPTH = nil - ---- -render.FORMAT_LUMINANCE = nil - ----May be nil if the format isn't supported -render.FORMAT_R16F = nil - ----May be nil if the format isn't supported -render.FORMAT_R32F = nil - ----May be nil if the format isn't supported -render.FORMAT_RG16F = nil - ----May be nil if the format isn't supported -render.FORMAT_RG32F = nil - ---- -render.FORMAT_RGB = nil - ----May be nil if the format isn't supported -render.FORMAT_RGB16F = nil - ----May be nil if the format isn't supported -render.FORMAT_RGB32F = nil - ---- -render.FORMAT_RGBA = nil - ----May be nil if the format isn't supported -render.FORMAT_RGBA16F = nil - ----May be nil if the format isn't supported -render.FORMAT_RGBA32F = nil - ---- -render.FORMAT_STENCIL = nil - ---- -render.FRUSTUM_PLANES_ALL = nil - ---- -render.FRUSTUM_PLANES_SIDES = nil - ---- -render.RENDER_TARGET_DEFAULT = nil - ---- -render.STATE_BLEND = nil - ---- -render.STATE_CULL_FACE = nil - ---- -render.STATE_DEPTH_TEST = nil - ---- -render.STATE_POLYGON_OFFSET_FILL = nil - ---- -render.STATE_STENCIL_TEST = nil - ---- -render.STENCIL_OP_DECR = nil - ---- -render.STENCIL_OP_DECR_WRAP = nil - ---- -render.STENCIL_OP_INCR = nil - ---- -render.STENCIL_OP_INCR_WRAP = nil - ---- -render.STENCIL_OP_INVERT = nil - ---- -render.STENCIL_OP_KEEP = nil - ---- -render.STENCIL_OP_REPLACE = nil - ---- -render.STENCIL_OP_ZERO = nil - ---- -render.WRAP_CLAMP_TO_BORDER = nil - ---- -render.WRAP_CLAMP_TO_EDGE = nil - ---- -render.WRAP_MIRRORED_REPEAT = nil - ---- -render.WRAP_REPEAT = nil - ----Clear buffers in the currently enabled render target with specified value. If the render target has been created with multiple ----color attachments, all buffers will be cleared with the same value. ----@param buffers table table with keys specifying which buffers to clear and values set to clear values. Available keys are: ---- ----render.BUFFER_COLOR_BIT ----render.BUFFER_DEPTH_BIT ----render.BUFFER_STENCIL_BIT ---- -function render.clear(buffers) end - ----Constant buffers are used to set shader program variables and are optionally passed to the render.draw() function. ----The buffer's constant elements can be indexed like an ordinary Lua table, but you can't iterate over them with pairs() or ipairs(). ----@return constant_buffer buffer new constant buffer -function render.constant_buffer() end - ----Deletes a render target created by a render script. ----You cannot delete a render target resource. ----@param render_target render_target render target to delete -function render.delete_render_target(render_target) end - ----If a material is currently enabled, disable it. ----The name of the material must be specified in the ".render" resource set ----in the "game.project" setting. -function render.disable_material() end - ----Disables a render state. ----@param state constant state to disable ---- ----render.STATE_DEPTH_TEST ----render.STATE_STENCIL_TEST ----render.STATE_BLEND ----render.STATE_ALPHA_TEST ( not available on iOS and Android) ----render.STATE_CULL_FACE ----render.STATE_POLYGON_OFFSET_FILL ---- -function render.disable_state(state) end - ----Disables a texture that has previourly been enabled. ----@param binding number|string|hash texture binding, either by texture unit, string or hash that should be disabled -function render.disable_texture(binding) end - ----Draws all objects that match a specified predicate. An optional constant buffer can be ----provided to override the default constants. If no constants buffer is provided, a default ----system constants buffer is used containing constants as defined in materials and set through ----go.set (or particlefx.set_constant) on visual components. ----@param predicate render_predicate predicate to draw for ----@param options { frustum:matrix4|nil, frustum_planes:number|nil, constants:constant_buffer|nil }|nil optional table with properties: ---- ----frustum ----vmath.matrix4 A frustum matrix used to cull renderable items. (E.g. local frustum = proj * view). default=nil ----frustum_planes ----int Determines which sides of the frustum will be used. Default is render.FRUSTUM_PLANES_SIDES. ---- ---- ----render.FRUSTUM_PLANES_SIDES : The left, right, top and bottom sides of the frustum. ----render.FRUSTUM_PLANES_ALL : All 6 sides of the frustum. ---- ---- ----constants ----constant_buffer optional constants to use while rendering ---- -function render.draw(predicate, options) end - ----Draws all 3d debug graphics such as lines drawn with "draw_line" messages and physics visualization. ----@param options { frustum:matrix4|nil, frustum_planes:number|nil }|nil optional table with properties: ---- ----frustum ----vmath.matrix4 A frustum matrix used to cull renderable items. (E.g. local frustum = proj * view). May be nil. ----frustum_planes ----int Determines which sides of the frustum will be used. Default is render.FRUSTUM_PLANES_SIDES. ---- ---- ----render.FRUSTUM_PLANES_SIDES : The left, right, top and bottom sides of the frustum. ----render.FRUSTUM_PLANES_ALL : All sides of the frustum. ---- -function render.draw_debug3d(options) end - ----If another material was already enabled, it will be automatically disabled ----and the specified material is used instead. ----The name of the material must be specified in the ".render" resource set ----in the "game.project" setting. ----@param material_id string|hash material id to enable -function render.enable_material(material_id) end - ----Enables a particular render state. The state will be enabled until disabled. ----@param state constant state to enable ---- ----render.STATE_DEPTH_TEST ----render.STATE_STENCIL_TEST ----render.STATE_BLEND ----render.STATE_ALPHA_TEST ( not available on iOS and Android) ----render.STATE_CULL_FACE ----render.STATE_POLYGON_OFFSET_FILL ---- -function render.enable_state(state) end - ----Sets the specified texture handle for a render target attachment or a regular texture ----that should be used for rendering. The texture can be bound to either a texture unit ----or to a sampler name by a hash or a string. ----A texture can be bound to multiple units and sampler names at the same time, ----the actual binding will be applied to the shaders when a shader program is bound. ----When mixing binding using both units and sampler names, you might end up in situations ----where two different textures will be applied to the same bind location in the shader. ----In this case, the texture set to the named sampler will take precedence over the unit. ----Note that you can bind multiple sampler names to the same texture, in case you want to reuse ----the same texture for differnt use-cases. It is however recommended that you use the same name ----everywhere for the textures that should be shared across different materials. ----@param binding number|string|hash texture binding, either by texture unit, string or hash for the sampler name that the texture should be bound to ----@param handle_or_name resource_handle|string|hash render target or texture handle that should be bound, or a named resource in the "Render Resource" table in the currently assigned .render file ----@param buffer_type constant|nil optional buffer type from which to enable the texture. Note that this argument only applies to render targets. Defaults to render.BUFFER_COLOR_BIT. These values are supported: ---- ----render.BUFFER_COLOR_BIT ---- ----If The render target has been created as depth and/or stencil textures, these buffer types can be used: ---- ----render.BUFFER_DEPTH_BIT ----render.BUFFER_STENCIL_BIT ---- ----If the render target has been created with multiple color attachments, these buffer types can be used ----to enable those textures as well. Currently 4 color attachments are supported: ---- ----render.BUFFER_COLOR0_BIT ----render.BUFFER_COLOR1_BIT ----render.BUFFER_COLOR2_BIT ----render.BUFFER_COLOR3_BIT ---- -function render.enable_texture(binding, handle_or_name, buffer_type) end - ----Returns the logical window height that is set in the "game.project" settings. ----Note that the actual window pixel size can change, either by device constraints ----or user input. ----@return number height specified window height -function render.get_height() end - ----Returns the specified buffer height from a render target. ----@param render_target render_target render target from which to retrieve the buffer height ----@param buffer_type constant which type of buffer to retrieve the height from ---- ----render.BUFFER_COLOR_BIT ----render.BUFFER_DEPTH_BIT ----render.BUFFER_STENCIL_BIT ---- ----@return number height the height of the render target buffer texture -function render.get_render_target_height(render_target, buffer_type) end - ----Returns the specified buffer width from a render target. ----@param render_target render_target render target from which to retrieve the buffer width ----@param buffer_type constant which type of buffer to retrieve the width from ---- ----render.BUFFER_COLOR_BIT ----render.BUFFER_COLOR[x]_BIT (x: [0..3], if supported!) ----render.BUFFER_DEPTH_BIT ----render.BUFFER_STENCIL_BIT ---- ----@return number width the width of the render target buffer texture -function render.get_render_target_width(render_target, buffer_type) end - ----Returns the logical window width that is set in the "game.project" settings. ----Note that the actual window pixel size can change, either by device constraints ----or user input. ----@return number width specified window width (number) -function render.get_width() end - ----Returns the actual physical window height. ----Note that this value might differ from the logical height that is set in the ----"game.project" settings. ----@return number height actual window height -function render.get_window_height() end - ----Returns the actual physical window width. ----Note that this value might differ from the logical width that is set in the ----"game.project" settings. ----@return number width actual window width -function render.get_window_width() end - ----This function returns a new render predicate for objects with materials matching ----the provided material tags. The provided tags are combined into a bit mask ----for the predicate. If multiple tags are provided, the predicate matches materials ----with all tags ANDed together. ----The current limit to the number of tags that can be defined is 64. ----@param tags (string|hash)[] table of tags that the predicate should match. The tags can be of either hash or string type ----@return render_predicate predicate new predicate -function render.predicate(tags) end - ----Creates a new render target according to the supplied ----specification table. ----The table should contain keys specifying which buffers should be created ----with what parameters. Each buffer key should have a table value consisting ----of parameters. The following parameter keys are available: ----Key ----Values ----format ----render.FORMAT_LUMINANCErender.FORMAT_RGBrender.FORMAT_RGBArender.FORMAT_DEPTHrender.FORMAT_STENCILrender.FORMAT_RGBA32Frender.FORMAT_RGBA16F ----width ----number ----height ----number ----min_filter (optional) ----render.FILTER_LINEARrender.FILTER_NEAREST ----mag_filter (optional) ----render.FILTER_LINEARrender.FILTER_NEAREST ----u_wrap (optional) ----render.WRAP_CLAMP_TO_BORDERrender.WRAP_CLAMP_TO_EDGErender.WRAP_MIRRORED_REPEATrender.WRAP_REPEAT ----v_wrap (optional) ----render.WRAP_CLAMP_TO_BORDERrender.WRAP_CLAMP_TO_EDGErender.WRAP_MIRRORED_REPEATrender.WRAP_REPEAT ----flags (optional) ----render.TEXTURE_BIT (only applicable to depth and stencil buffers) ----The render target can be created to support multiple color attachments. Each attachment can have different format settings and texture filters, ----but attachments must be added in sequence, meaning you cannot create a render target at slot 0 and 3. ----Instead it has to be created with all four buffer types ranging from [0..3] (as denoted by render.BUFFER_COLORX_BIT where 'X' is the attachment you want to create). ----It is not guaranteed that the device running the script can support creating render targets with multiple color attachments. To check if the device can support multiple attachments, ----you can check if the render table contains any of the BUFFER_COLOR1_BIT, BUFFER_COLOR2_BIT or BUFFER_COLOR3_BIT constants: ----function init(self) ---- if render.BUFFER_COLOR1_BIT == nil then ---- -- this devices does not support multiple color attachments ---- end ----end ----@param name string render target name ----@param parameters table table of buffer parameters, see the description for available keys and values ----@return render_target render_target new render target -function render.render_target(name, parameters) end - ----Specifies the arithmetic used when computing pixel values that are written to the frame ----buffer. In RGBA mode, pixels can be drawn using a function that blends the source RGBA ----pixel values with the destination pixel values already in the frame buffer. ----Blending is initially disabled. ----source_factor specifies which method is used to scale the source color components. ----destination_factor specifies which method is used to scale the destination color ----components. ----Source color components are referred to as (Rs,Gs,Bs,As). ----Destination color components are referred to as (Rd,Gd,Bd,Ad). ----The color specified by setting the blendcolor is referred to as (Rc,Gc,Bc,Ac). ----The source scale factor is referred to as (sR,sG,sB,sA). ----The destination scale factor is referred to as (dR,dG,dB,dA). ----The color values have integer values between 0 and (kR,kG,kB,kA), where kc = 2mc - 1 and mc is the number of bitplanes for that color. I.e for 8 bit color depth, color values are between 0 and 255. ----Available factor constants and corresponding scale factors: ----Factor constant ----Scale factor (fR,fG,fB,fA) ----render.BLEND_ZERO ----(0,0,0,0) ----render.BLEND_ONE ----(1,1,1,1) ----render.BLEND_SRC_COLOR ----(Rs/kR,Gs/kG,Bs/kB,As/kA) ----render.BLEND_ONE_MINUS_SRC_COLOR ----(1,1,1,1) - (Rs/kR,Gs/kG,Bs/kB,As/kA) ----render.BLEND_DST_COLOR ----(Rd/kR,Gd/kG,Bd/kB,Ad/kA) ----render.BLEND_ONE_MINUS_DST_COLOR ----(1,1,1,1) - (Rd/kR,Gd/kG,Bd/kB,Ad/kA) ----render.BLEND_SRC_ALPHA ----(As/kA,As/kA,As/kA,As/kA) ----render.BLEND_ONE_MINUS_SRC_ALPHA ----(1,1,1,1) - (As/kA,As/kA,As/kA,As/kA) ----render.BLEND_DST_ALPHA ----(Ad/kA,Ad/kA,Ad/kA,Ad/kA) ----render.BLEND_ONE_MINUS_DST_ALPHA ----(1,1,1,1) - (Ad/kA,Ad/kA,Ad/kA,Ad/kA) ----render.BLEND_CONSTANT_COLOR ----(Rc,Gc,Bc,Ac) ----render.BLEND_ONE_MINUS_CONSTANT_COLOR ----(1,1,1,1) - (Rc,Gc,Bc,Ac) ----render.BLEND_CONSTANT_ALPHA ----(Ac,Ac,Ac,Ac) ----render.BLEND_ONE_MINUS_CONSTANT_ALPHA ----(1,1,1,1) - (Ac,Ac,Ac,Ac) ----render.BLEND_SRC_ALPHA_SATURATE ----(i,i,i,1) where i = min(As, kA - Ad) /kA ----The blended RGBA values of a pixel comes from the following equations: ----Rd = min(kR, Rs * sR + Rd * dR) ----Gd = min(kG, Gs * sG + Gd * dG) ----Bd = min(kB, Bs * sB + Bd * dB) ----Ad = min(kA, As * sA + Ad * dA) ----Blend function (render.BLEND_SRC_ALPHA, render.BLEND_ONE_MINUS_SRC_ALPHA) is useful for ----drawing with transparency when the drawn objects are sorted from farthest to nearest. ----It is also useful for drawing antialiased points and lines in arbitrary order. ----@param source_factor constant source factor ----@param destination_factor constant destination factor -function render.set_blend_func(source_factor, destination_factor) end - ----Sets the current render camera to be used for rendering. If a render camera ----has been set by the render script, the renderer will be using its projection and view matrix ----during rendering. If a projection and/or view matrix has been set by the render script, ----they will not be used until the current render camera has been reset by calling render.set_camera(). ----If the 'use_frustum' flag in the options table has been set to true, the renderer will automatically use the ----camera frustum for frustum culling regardless of what frustum is being passed into the render.draw() function. ----Note that the frustum plane option in render.draw can still be used together with the camera. ----@param camera url|resource_handle|nil camera id to use, or nil to reset ----@param options { use_frustum:boolean|nil }|nil optional table with properties: ---- ----use_frustum ----boolean If true, the renderer will use the cameras view-projection matrix for frustum culling (default: false) ---- -function render.set_camera(camera, options) end - ----Specifies whether the individual color components in the frame buffer is enabled for writing (true) or disabled (false). For example, if blue is false, nothing is written to the blue component of any pixel in any of the color buffers, regardless of the drawing operation attempted. Note that writing are either enabled or disabled for entire color components, not the individual bits of a component. ----The component masks are all initially true. ----@param red boolean red mask ----@param green boolean green mask ----@param blue boolean blue mask ----@param alpha boolean alpha mask -function render.set_color_mask(red, green, blue, alpha) end - ----Specifies whether front- or back-facing polygons can be culled ----when polygon culling is enabled. Polygon culling is initially disabled. ----If mode is render.FACE_FRONT_AND_BACK, no polygons are drawn, but other ----primitives such as points and lines are drawn. The initial value for ----face_type is render.FACE_BACK. ----@param face_type constant face type ---- ----render.FACE_FRONT ----render.FACE_BACK ----render.FACE_FRONT_AND_BACK ---- -function render.set_cull_face(face_type) end - ----Specifies the function that should be used to compare each incoming pixel ----depth value with the value present in the depth buffer. ----The comparison is performed only if depth testing is enabled and specifies ----the conditions under which a pixel will be drawn. ----Function constants: ----render.COMPARE_FUNC_NEVER (never passes) ----render.COMPARE_FUNC_LESS (passes if the incoming depth value is less than the stored value) ----render.COMPARE_FUNC_LEQUAL (passes if the incoming depth value is less than or equal to the stored value) ----render.COMPARE_FUNC_GREATER (passes if the incoming depth value is greater than the stored value) ----render.COMPARE_FUNC_GEQUAL (passes if the incoming depth value is greater than or equal to the stored value) ----render.COMPARE_FUNC_EQUAL (passes if the incoming depth value is equal to the stored value) ----render.COMPARE_FUNC_NOTEQUAL (passes if the incoming depth value is not equal to the stored value) ----render.COMPARE_FUNC_ALWAYS (always passes) ----The depth function is initially set to render.COMPARE_FUNC_LESS. ----@param func constant depth test function, see the description for available values -function render.set_depth_func(func) end - ----Specifies whether the depth buffer is enabled for writing. The supplied mask governs ----if depth buffer writing is enabled (true) or disabled (false). ----The mask is initially true. ----@param depth boolean depth mask -function render.set_depth_mask(depth) end - ----Sets the scale and units used to calculate depth values. ----If render.STATE_POLYGON_OFFSET_FILL is enabled, each fragment's depth value ----is offset from its interpolated value (depending on the depth value of the ----appropriate vertices). Polygon offset can be used when drawing decals, rendering ----hidden-line images etc. ----factor specifies a scale factor that is used to create a variable depth ----offset for each polygon. The initial value is 0. ----units is multiplied by an implementation-specific value to create a ----constant depth offset. The initial value is 0. ----The value of the offset is computed as factor × DZ + r × units ----DZ is a measurement of the depth slope of the polygon which is the change in z (depth) ----values divided by the change in either x or y coordinates, as you traverse a polygon. ----The depth values are in window coordinates, clamped to the range [0, 1]. ----r is the smallest value that is guaranteed to produce a resolvable difference. ----It's value is an implementation-specific constant. ----The offset is added before the depth test is performed and before the ----value is written into the depth buffer. ----@param factor number polygon offset factor ----@param units number polygon offset units -function render.set_polygon_offset(factor, units) end - ----Sets the projection matrix to use when rendering. ----@param matrix matrix4 projection matrix -function render.set_projection(matrix) end - ----Sets a render target. Subsequent draw operations will be to the ----render target until it is replaced by a subsequent call to set_render_target. ----This function supports render targets created by a render script, or a render target resource. ----@param render_target render_target render target to set. render.RENDER_TARGET_DEFAULT to set the default render target ----@param options { transient:number[]|nil }|nil optional table with behaviour parameters ---- ----transient ----table Transient frame buffer types are only valid while the render target is active, i.e becomes undefined when a new target is set by a subsequent call to set_render_target. ---- Default is all non-transient. Be aware that some hardware uses a combined depth stencil buffer and when this is the case both are considered non-transient if exclusively selected! ---- A buffer type defined that doesn't exist in the render target is silently ignored. ---- ---- ----render.BUFFER_COLOR_BIT ----render.BUFFER_DEPTH_BIT ----render.BUFFER_STENCIL_BIT ---- -function render.set_render_target(render_target, options) end - ----Sets the render target size for a render target created from ----either a render script, or from a render target resource. ----@param render_target render_target render target to set size for ----@param width number new render target width ----@param height number new render target height -function render.set_render_target_size(render_target, width, height) end - ----Stenciling is similar to depth-buffering as it enables and disables drawing on a ----per-pixel basis. First, GL drawing primitives are drawn into the stencil planes. ----Second, geometry and images are rendered but using the stencil planes to mask out ----where to draw. ----The stencil test discards a pixel based on the outcome of a comparison between the ----reference value ref and the corresponding value in the stencil buffer. ----func specifies the comparison function. See the table below for values. ----The initial value is render.COMPARE_FUNC_ALWAYS. ----ref specifies the reference value for the stencil test. The value is clamped to ----the range [0, 2n-1], where n is the number of bitplanes in the stencil buffer. ----The initial value is 0. ----mask is ANDed with both the reference value and the stored stencil value when the test ----is done. The initial value is all 1's. ----Function constant: ----render.COMPARE_FUNC_NEVER (never passes) ----render.COMPARE_FUNC_LESS (passes if (ref & mask) < (stencil & mask)) ----render.COMPARE_FUNC_LEQUAL (passes if (ref & mask) <= (stencil & mask)) ----render.COMPARE_FUNC_GREATER (passes if (ref & mask) > (stencil & mask)) ----render.COMPARE_FUNC_GEQUAL (passes if (ref & mask) >= (stencil & mask)) ----render.COMPARE_FUNC_EQUAL (passes if (ref & mask) = (stencil & mask)) ----render.COMPARE_FUNC_NOTEQUAL (passes if (ref & mask) != (stencil & mask)) ----render.COMPARE_FUNC_ALWAYS (always passes) ----@param func constant stencil test function, see the description for available values ----@param ref number reference value for the stencil test ----@param mask number mask that is ANDed with both the reference value and the stored stencil value when the test is done -function render.set_stencil_func(func, ref, mask) end - ----The stencil mask controls the writing of individual bits in the stencil buffer. ----The least significant n bits of the parameter mask, where n is the number of ----bits in the stencil buffer, specify the mask. ----Where a 1 bit appears in the mask, the corresponding ----bit in the stencil buffer can be written. Where a 0 bit appears in the mask, ----the corresponding bit in the stencil buffer is never written. ----The mask is initially all 1's. ----@param mask number stencil mask -function render.set_stencil_mask(mask) end - ----The stencil test discards a pixel based on the outcome of a comparison between the ----reference value ref and the corresponding value in the stencil buffer. ----To control the test, call render.set_stencil_func. ----This function takes three arguments that control what happens to the stored stencil ----value while stenciling is enabled. If the stencil test fails, no change is made to the ----pixel's color or depth buffers, and sfail specifies what happens to the stencil buffer ----contents. ----Operator constants: ----render.STENCIL_OP_KEEP (keeps the current value) ----render.STENCIL_OP_ZERO (sets the stencil buffer value to 0) ----render.STENCIL_OP_REPLACE (sets the stencil buffer value to ref, as specified by render.set_stencil_func) ----render.STENCIL_OP_INCR (increments the stencil buffer value and clamp to the maximum representable unsigned value) ----render.STENCIL_OP_INCR_WRAP (increments the stencil buffer value and wrap to zero when incrementing the maximum representable unsigned value) ----render.STENCIL_OP_DECR (decrements the current stencil buffer value and clamp to 0) ----render.STENCIL_OP_DECR_WRAP (decrements the current stencil buffer value and wrap to the maximum representable unsigned value when decrementing zero) ----render.STENCIL_OP_INVERT (bitwise inverts the current stencil buffer value) ----dppass and dpfail specify the stencil buffer actions depending on whether subsequent ----depth buffer tests succeed (dppass) or fail (dpfail). ----The initial value for all operators is render.STENCIL_OP_KEEP. ----@param sfail constant action to take when the stencil test fails ----@param dpfail constant the stencil action when the stencil test passes ----@param dppass constant the stencil action when both the stencil test and the depth test pass, or when the stencil test passes and either there is no depth buffer or depth testing is not enabled -function render.set_stencil_op(sfail, dpfail, dppass) end - ----Sets the view matrix to use when rendering. ----@param matrix matrix4 view matrix to set -function render.set_view(matrix) end - ----Set the render viewport to the specified rectangle. ----@param x number left corner ----@param y number bottom corner ----@param width number viewport width ----@param height number viewport height -function render.set_viewport(x, y, width, height) end - -return render \ No newline at end of file diff --git a/annotations/defold_annotations/resource.lua b/annotations/defold_annotations/resource.lua deleted file mode 100644 index 9732207..0000000 --- a/annotations/defold_annotations/resource.lua +++ /dev/null @@ -1,760 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Resource API documentation - - Functions and constants to access resources. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.resource -resource = {} - ----BASIS_UASTC compression type -resource.COMPRESSION_TYPE_BASIS_UASTC = nil - ----COMPRESSION_TYPE_DEFAULT compression type -resource.COMPRESSION_TYPE_DEFAULT = nil - ----luminance type texture format -resource.TEXTURE_FORMAT_LUMINANCE = nil - ----R16F type texture format -resource.TEXTURE_FORMAT_R16F = nil - ----R32F type texture format -resource.TEXTURE_FORMAT_R32F = nil - ----RG16F type texture format -resource.TEXTURE_FORMAT_RG16F = nil - ----RG32F type texture format -resource.TEXTURE_FORMAT_RG32F = nil - ----RGB type texture format -resource.TEXTURE_FORMAT_RGB = nil - ----RGB16F type texture format -resource.TEXTURE_FORMAT_RGB16F = nil - ----RGB32F type texture format -resource.TEXTURE_FORMAT_RGB32F = nil - ----RGBA type texture format -resource.TEXTURE_FORMAT_RGBA = nil - ----RGBA16F type texture format -resource.TEXTURE_FORMAT_RGBA16F = nil - ----RGBA32F type texture format -resource.TEXTURE_FORMAT_RGBA32F = nil - ----RGBA_ASTC_4x4 type texture format -resource.TEXTURE_FORMAT_RGBA_ASTC_4x4 = nil - ----RGBA_BC3 type texture format -resource.TEXTURE_FORMAT_RGBA_BC3 = nil - ----RGBA_BC7 type texture format -resource.TEXTURE_FORMAT_RGBA_BC7 = nil - ----RGBA_ETC2 type texture format -resource.TEXTURE_FORMAT_RGBA_ETC2 = nil - ----RGBA_PVRTC_2BPPV1 type texture format -resource.TEXTURE_FORMAT_RGBA_PVRTC_2BPPV1 = nil - ----RGBA_PVRTC_4BPPV1 type texture format -resource.TEXTURE_FORMAT_RGBA_PVRTC_4BPPV1 = nil - ----RGB_BC1 type texture format -resource.TEXTURE_FORMAT_RGB_BC1 = nil - ----RGB_ETC1 type texture format -resource.TEXTURE_FORMAT_RGB_ETC1 = nil - ----RGB_PVRTC_2BPPV1 type texture format -resource.TEXTURE_FORMAT_RGB_PVRTC_2BPPV1 = nil - ----RGB_PVRTC_4BPPV1 type texture format -resource.TEXTURE_FORMAT_RGB_PVRTC_4BPPV1 = nil - ----RG_BC5 type texture format -resource.TEXTURE_FORMAT_RG_BC5 = nil - ----R_BC4 type texture format -resource.TEXTURE_FORMAT_R_BC4 = nil - ----2D texture type -resource.TEXTURE_TYPE_2D = nil - ----2D Array texture type -resource.TEXTURE_TYPE_2D_ARRAY = nil - ----Cube map texture type -resource.TEXTURE_TYPE_CUBE_MAP = nil - ----Constructor-like function with two purposes: ----Load the specified resource as part of loading the script ----Return a hash to the run-time version of the resource ---- This function can only be called within go.property function calls. ----@param path string|nil optional resource path string to the resource ----@return hash path a path hash to the binary version of the resource -function resource.atlas(path) end - ----Constructor-like function with two purposes: ----Load the specified resource as part of loading the script ----Return a hash to the run-time version of the resource ---- This function can only be called within go.property function calls. ----@param path string|nil optional resource path string to the resource ----@return hash path a path hash to the binary version of the resource -function resource.buffer(path) end - ----This function creates a new atlas resource that can be used in the same way as any atlas created during build time. ----The path used for creating the atlas must be unique, trying to create a resource at a path that is already ----registered will trigger an error. If the intention is to instead modify an existing atlas, use the resource.set_atlas ----function. Also note that the path to the new atlas resource must have a '.texturesetc' extension, ----meaning "/path/my_atlas" is not a valid path but "/path/my_atlas.texturesetc" is. ----When creating the atlas, at least one geometry and one animation is required, and an error will be ----raised if these requirements are not met. A reference to the resource will be held by the collection ----that created the resource and will automatically be released when that collection is destroyed. ----Note that releasing a resource essentially means decreasing the reference count of that resource, ----and not necessarily that it will be deleted. ----@param path string The path to the resource. ----@param table resource.atlas A table containing info about how to create the atlas. Supported entries: ---- ---- ---- ----texture ----string | hash the path to the texture resource, e.g "/main/my_texture.texturec" ---- ---- ---- ---- ----animations ----table a list of the animations in the atlas. Supports the following fields: ---- ---- ---- ---- ----id ----string the id of the animation, used in e.g sprite.play_animation ---- ---- ---- ---- ----width ----integer the width of the animation ---- ---- ---- ---- ----height ----integer the height of the animation ---- ---- ---- ---- ----frame_start ----integer index to the first geometry of the animation. Indices are lua based and must be in the range of 1 .. in atlas. ---- ---- ---- ---- ----frame_end ----integer index to the last geometry of the animation (non-inclusive). Indices are lua based and must be in the range of 1 .. in atlas. ---- ---- ---- ---- ----playback ----constant optional playback mode of the animation, the default value is go.PLAYBACK_ONCE_FORWARD ---- ---- ---- ---- ----fps ----integer optional fps of the animation, the default value is 30 ---- ---- ---- ---- ----flip_vertical ----boolean optional flip the animation vertically, the default value is false ---- ---- ---- ---- ----flip_horizontal ----boolean optional flip the animation horizontally, the default value is false ---- ---- ---- ---- ----geometries ----table A list of the geometries that should map to the texture data. Supports the following fields: ---- ---- ---- ---- ----id ----string The name of the geometry. Used when matching animations between multiple atlases ---- ---- ---- ---- ----vertices ----table a list of the vertices in texture space of the geometry in the form {px0, py0, px1, py1, ..., pxn, pyn} ---- ---- ---- ---- ----uvs ----table a list of the uv coordinates in texture space of the geometry in the form of {u0, v0, u1, v1, ..., un, vn} ---- ---- ---- ---- ----indices ----table a list of the indices of the geometry in the form {i0, i1, i2, ..., in}. Each tripe in the list represents a triangle. ---- ---- ---- ----@return hash path Returns the atlas resource path -function resource.create_atlas(path, table) end - ----This function creates a new buffer resource that can be used in the same way as any buffer created during build time. ----The function requires a valid buffer created from either buffer.create or another pre-existing buffer resource. ----By default, the new resource will take ownership of the buffer lua reference, meaning the buffer will not automatically be removed ----when the lua reference to the buffer is garbage collected. This behaviour can be overruled by specifying 'transfer_ownership = false' ----in the argument table. If the new buffer resource is created from a buffer object that is created by another resource, ----the buffer object will be copied and the new resource will effectively own a copy of the buffer instead. ----Note that the path to the new resource must have the '.bufferc' extension, "/path/my_buffer" is not a valid path but "/path/my_buffer.bufferc" is. ----The path must also be unique, attempting to create a buffer with the same name as an existing resource will raise an error. ----@param path string The path to the resource. ----@param table { buffer:buffer_data, transfer_ownership:boolean|nil }|nil A table containing info about how to create the buffer. Supported entries: ---- ---- ---- ----buffer ----buffer the buffer to bind to this resource ---- ---- ---- ---- ----transfer_ownership ----boolean optional flag to determine wether or not the resource should take over ownership of the buffer object (default true) ---- ---- ---- ----@return hash path Returns the buffer resource path -function resource.create_buffer(path, table) end - ----Creates a new texture resource that can be used in the same way as any texture created during build time. ----The path used for creating the texture must be unique, trying to create a resource at a path that is already ----registered will trigger an error. If the intention is to instead modify an existing texture, use the resource.set_texture ----function. Also note that the path to the new texture resource must have a '.texturec' extension, ----meaning "/path/my_texture" is not a valid path but "/path/my_texture.texturec" is. ----If the texture is created without a buffer, the pixel data will be blank. ----@param path string The path to the resource. ----@param table { type:number, width:number, height:number, format:number, max_mipmaps:number|nil, compression_type:number|nil} A table containing info about how to create the texture. Supported entries: ---- ----type ----number The texture type. Supported values: ---- ---- ----resource.TEXTURE_TYPE_2D ----resource.TEXTURE_TYPE_CUBE_MAP ---- ---- ----width ----number The width of the texture (in pixels). Must be larger than 0. ----height ----number The width of the texture (in pixels). Must be larger than 0. ----format ----number The texture format, note that some of these formats might not be supported by the running device. Supported values: ---- ---- ----resource.TEXTURE_FORMAT_LUMINANCE ----resource.TEXTURE_FORMAT_RGB ----resource.TEXTURE_FORMAT_RGBA ---- ----These constants might not be available on the device: ---- ----resource.TEXTURE_FORMAT_RGB_PVRTC_2BPPV1 ----resource.TEXTURE_FORMAT_RGB_PVRTC_4BPPV1 ----resource.TEXTURE_FORMAT_RGBA_PVRTC_2BPPV1 ----resource.TEXTURE_FORMAT_RGBA_PVRTC_4BPPV1 ----resource.TEXTURE_FORMAT_RGB_ETC1 ----resource.TEXTURE_FORMAT_RGBA_ETC2 ----resource.TEXTURE_FORMAT_RGBA_ASTC_4x4 ----resource.TEXTURE_FORMAT_RGB_BC1 ----resource.TEXTURE_FORMAT_RGBA_BC3 ----resource.TEXTURE_FORMAT_R_BC4 ----resource.TEXTURE_FORMAT_RG_BC5 ----resource.TEXTURE_FORMAT_RGBA_BC7 ----resource.TEXTURE_FORMAT_RGB16F ----resource.TEXTURE_FORMAT_RGB32F ----resource.TEXTURE_FORMAT_RGBA16F ----resource.TEXTURE_FORMAT_RGBA32F ----resource.TEXTURE_FORMAT_R16F ----resource.TEXTURE_FORMAT_RG16F ----resource.TEXTURE_FORMAT_R32F ----resource.TEXTURE_FORMAT_RG32F ---- ----You can test if the device supports these values by checking if a specific enum is nil or not: ----if resource.TEXTURE_FORMAT_RGBA16F ~= nil then ---- -- it is safe to use this format ----end ---- ---- ---- ----max_mipmaps ----number optional max number of mipmaps. Defaults to zero, i.e no mipmap support ----compression_type ----number optional specify the compression type for the data in the buffer object that holds the texture data. Will only be used when a compressed buffer has been passed into the function. ----Creating an empty texture with no buffer data is not supported as a core feature. Defaults to resource.COMPRESSION_TYPE_DEFAULT, i.e no compression. Supported values: ---- ---- ----COMPRESSION_TYPE_DEFAULT ----COMPRESSION_TYPE_BASIS_UASTC ---- ----@param buffer buffer_data optional buffer of precreated pixel data ----@return hash path The path to the resource. -function resource.create_texture(path, table, buffer) end - ----Creates a new texture resource that can be used in the same way as any texture created during build time. ----The path used for creating the texture must be unique, trying to create a resource at a path that is already ----registered will trigger an error. If the intention is to instead modify an existing texture, use the resource.set_texture ----function. Also note that the path to the new texture resource must have a '.texturec' extension, ----meaning "/path/my_texture" is not a valid path but "/path/my_texture.texturec" is. ----If the texture is created without a buffer, the pixel data will be blank. ----The difference between the async version and resource.create_texture is that the texture data will be uploaded ----in a graphics worker thread. The function will return a resource immediately that contains a 1x1 blank texture which can be used ----immediately after the function call. When the new texture has been uploaded, the initial blank texture will be deleted and replaced with the ----new texture. Be careful when using the initial texture handle handle as it will not be valid after the upload has finished. ----@param path string The path to the resource. ----@param table { type:number, width:number, height:number, format:number, max_mipmaps:number|nil, compression_type:number|nil} ----A table containing info about how to create the texture. Supported entries: ----type ----number The texture type. Supported values: ---- ---- ----resource.TEXTURE_TYPE_2D ----resource.TEXTURE_TYPE_CUBE_MAP ---- ---- ----width ----number The width of the texture (in pixels). Must be larger than 0. ----height ----number The width of the texture (in pixels). Must be larger than 0. ----format ----number The texture format, note that some of these formats might not be supported by the running device. Supported values: ---- ---- ----resource.TEXTURE_FORMAT_LUMINANCE ----resource.TEXTURE_FORMAT_RGB ----resource.TEXTURE_FORMAT_RGBA ---- ----These constants might not be available on the device: ---- ----resource.TEXTURE_FORMAT_RGB_PVRTC_2BPPV1 ----resource.TEXTURE_FORMAT_RGB_PVRTC_4BPPV1 ----resource.TEXTURE_FORMAT_RGBA_PVRTC_2BPPV1 ----resource.TEXTURE_FORMAT_RGBA_PVRTC_4BPPV1 ----resource.TEXTURE_FORMAT_RGB_ETC1 ----resource.TEXTURE_FORMAT_RGBA_ETC2 ----resource.TEXTURE_FORMAT_RGBA_ASTC_4x4 ----resource.TEXTURE_FORMAT_RGB_BC1 ----resource.TEXTURE_FORMAT_RGBA_BC3 ----resource.TEXTURE_FORMAT_R_BC4 ----resource.TEXTURE_FORMAT_RG_BC5 ----resource.TEXTURE_FORMAT_RGBA_BC7 ----resource.TEXTURE_FORMAT_RGB16F ----resource.TEXTURE_FORMAT_RGB32F ----resource.TEXTURE_FORMAT_RGBA16F ----resource.TEXTURE_FORMAT_RGBA32F ----resource.TEXTURE_FORMAT_R16F ----resource.TEXTURE_FORMAT_RG16F ----resource.TEXTURE_FORMAT_R32F ----resource.TEXTURE_FORMAT_RG32F ---- ----You can test if the device supports these values by checking if a specific enum is nil or not: ----if resource.TEXTURE_FORMAT_RGBA16F ~= nil then ---- -- it is safe to use this format ----end ---- ---- ---- ----max_mipmaps ----number optional max number of mipmaps. Defaults to zero, i.e no mipmap support ----compression_type ----number optional specify the compression type for the data in the buffer object that holds the texture data. Will only be used when a compressed buffer has been passed into the function. ----Creating an empty texture with no buffer data is not supported as a core feature. Defaults to resource.COMPRESSION_TYPE_DEFAULT, i.e no compression. Supported values: ---- ---- ----COMPRESSION_TYPE_DEFAULT ----COMPRESSION_TYPE_BASIS_UASTC ---- ----@param buffer buffer_data optional buffer of precreated pixel data ----@return hash path The path to the resource. ----@return resource_handle request_id The request id for the async request. -function resource.create_texture_async(path, table, buffer) end - ----Constructor-like function with two purposes: ----Load the specified resource as part of loading the script ----Return a hash to the run-time version of the resource ---- This function can only be called within go.property function calls. ----@param path string|nil optional resource path string to the resource ----@return hash path a path hash to the binary version of the resource -function resource.font(path) end - ----Returns the atlas data for an atlas ----@param path hash|string The path to the atlas resource ----@return resource.atlas data A table with the following entries: ---- ----texture ----geometries ----animations ---- ----See resource.set_atlas for a detailed description of each field -function resource.get_atlas(path) end - ----gets the buffer from a resource ----@param path hash|string The path to the resource ----@return buffer_data buffer The resource buffer -function resource.get_buffer(path) end - ----Gets render target info from a render target resource path or a render target handle ----@param path hash|string|resource_handle The path to the resource or a render target handle ----@return { handle:resource_handle, attachments:{ handle:resource_handle, width:number, height:number, depth:number, mipmaps:number, type:number, buffer_type:number }[] } table A table containing info about the render target: ---- ----handle ----handle the opaque handle to the texture resource ----'attachments' ----table a table of attachments, where each attachment contains the following entries: ----handle ----handle the opaque handle to the texture resource ----width ----integer width of the texture ----height ----integer height of the texture ----depth ----integer depth of the texture (i.e 1 for a 2D texture and 6 for a cube map) ----mipmaps ----integer number of mipmaps of the texture ----type ----number The texture type. Supported values: ---- ---- ----resource.TEXTURE_TYPE_2D ----resource.TEXTURE_TYPE_CUBE_MAP ----resource.TEXTURE_TYPE_2D_ARRAY ---- ---- ----buffer_type ----number The attachment buffer type. Supported values: ---- ---- ----resource.BUFFER_TYPE_COLOR0 ----resource.BUFFER_TYPE_COLOR1 ----resource.BUFFER_TYPE_COLOR2 ----resource.BUFFER_TYPE_COLOR3 ----resource.BUFFER_TYPE_DEPTH ----resource.BUFFER_TYPE_STENCIL ---- -function resource.get_render_target_info(path) end - ----Gets the text metrics from a font ----@param url hash the font to get the (unscaled) metrics from ----@param text string text to measure ----@param options { width:number|nil, leading:number|nil, tracking:number|nil, line_break:boolean|nil}|nil A table containing parameters for the text. Supported entries: ---- ----width ----integer The width of the text field. Not used if line_break is false. ----leading ----number The leading (default 1.0) ----tracking ----number The tracking (default 0.0) ----line_break ----boolean If the calculation should consider line breaks (default false) ---- ----@return { width:number, height:number, max_ascent:number, max_descent:number } metrics a table with the following fields: ---- ----width ----height ----max_ascent ----max_descent ---- -function resource.get_text_metrics(url, text, options) end - ----Gets texture info from a texture resource path or a texture handle ----@param path hash|string|resource_handle The path to the resource or a texture handle ----@return { handle:resource_handle, width:number, height:number, depth:number, mipmaps:number, type:number } table A table containing info about the texture: ---- ----handle ----handle the opaque handle to the texture resource ----width ----integer width of the texture ----height ----integer height of the texture ----depth ----integer depth of the texture (i.e 1 for a 2D texture and 6 for a cube map) ----mipmaps ----integer number of mipmaps of the texture ----type ----number The texture type. Supported values: ---- ---- ----resource.TEXTURE_TYPE_2D ----resource.TEXTURE_TYPE_CUBE_MAP ----resource.TEXTURE_TYPE_2D_ARRAY ---- -function resource.get_texture_info(path) end - ----Loads the resource data for a specific resource. ----@param path string The path to the resource ----@return buffer_data buffer Returns the buffer stored on disc -function resource.load(path) end - ----Constructor-like function with two purposes: ----Load the specified resource as part of loading the script ----Return a hash to the run-time version of the resource ---- This function can only be called within go.property function calls. ----@param path string|nil optional resource path string to the resource ----@return hash path a path hash to the binary version of the resource -function resource.material(path) end - ----Release a resource. ---- This is a potentially dangerous operation, releasing resources currently being used can cause unexpected behaviour. ----@param path hash|string The path to the resource. -function resource.release(path) end - ----Sets the resource data for a specific resource ----@param path string|hash The path to the resource ----@param buffer buffer_data The buffer of precreated data, suitable for the intended resource type -function resource.set(path, buffer) end - ----Sets the data for a specific atlas resource. Setting new atlas data is specified by passing in ----a texture path for the backing texture of the atlas, a list of geometries and a list of animations ----that map to the entries in the geometry list. The geometry entries are represented by three lists: ----vertices, uvs and indices that together represent triangles that are used in other parts of the ----engine to produce render objects from. ----Vertex and uv coordinates for the geometries are expected to be ----in pixel coordinates where 0,0 is the top left corner of the texture. ----There is no automatic padding or margin support when setting custom data, ----which could potentially cause filtering artifacts if used with a material sampler that has linear filtering. ----If that is an issue, you need to calculate padding and margins manually before passing in the geometry data to ----this function. ----@param path hash|string The path to the atlas resource ----@param table resource.atlas A table containing info about the atlas. Supported entries: ---- ---- ---- ----texture ----string | hash the path to the texture resource, e.g "/main/my_texture.texturec" ---- ---- ---- ---- ----animations ----table a list of the animations in the atlas. Supports the following fields: ---- ---- ---- ---- ----id ----string the id of the animation, used in e.g sprite.play_animation ---- ---- ---- ---- ----width ----integer the width of the animation ---- ---- ---- ---- ----height ----integer the height of the animation ---- ---- ---- ---- ----frame_start ----integer index to the first geometry of the animation. Indices are lua based and must be in the range of 1 .. in atlas. ---- ---- ---- ---- ----frame_end ----integer index to the last geometry of the animation (non-inclusive). Indices are lua based and must be in the range of 1 .. in atlas. ---- ---- ---- ---- ----playback ----constant optional playback mode of the animation, the default value is go.PLAYBACK_ONCE_FORWARD ---- ---- ---- ---- ----fps ----integer optional fps of the animation, the default value is 30 ---- ---- ---- ---- ----flip_vertical ----boolean optional flip the animation vertically, the default value is false ---- ---- ---- ---- ----flip_horizontal ----boolean optional flip the animation horizontally, the default value is false ---- ---- ---- ---- ----geometries ----table A list of the geometries that should map to the texture data. Supports the following fields: ---- ---- ---- ---- ----vertices ----table a list of the vertices in texture space of the geometry in the form {px0, py0, px1, py1, ..., pxn, pyn} ---- ---- ---- ---- ----uvs ----table a list of the uv coordinates in texture space of the geometry in the form of {u0, v0, u1, v1, ..., un, vn} ---- ---- ---- ---- ----indices ----table a list of the indices of the geometry in the form {i0, i1, i2, ..., in}. Each tripe in the list represents a triangle. ---- ---- ---- -function resource.set_atlas(path, table) end - ----Sets the buffer of a resource. By default, setting the resource buffer will either copy the data from the incoming buffer object ----to the buffer stored in the destination resource, or make a new buffer object if the sizes between the source buffer and the destination buffer ----stored in the resource differs. In some cases, e.g performance reasons, it might be beneficial to just set the buffer object on the resource without copying or cloning. ----To achieve this, set the transfer_ownership flag to true in the argument table. Transferring ownership from a lua buffer to a resource with this function ----works exactly the same as resource.create_buffer: the destination resource will take ownership of the buffer held by the lua reference, i.e the buffer will not automatically be removed ----when the lua reference to the buffer is garbage collected. ----Note: When setting a buffer with transfer_ownership = true, the currently bound buffer in the resource will be destroyed. ----@param path hash|string The path to the resource ----@param buffer buffer_data The resource buffer ----@param table { transfer_ownership: boolean|nil }|nil A table containing info about how to set the buffer. Supported entries: ---- ---- ---- ----transfer_ownership ----boolean optional flag to determine wether or not the resource should take over ownership of the buffer object (default false) ---- ---- ---- -function resource.set_buffer(path, buffer, table) end - ----Update internal sound resource (wavc/oggc) with new data ----@param path hash|string The path to the resource ----@param buffer string A lua string containing the binary sound data -function resource.set_sound(path, buffer) end - ----Sets the pixel data for a specific texture. ----@param path hash|string The path to the resource ----@param table { type:number, width:number, height:number, format:number, x:number|nil, y:number|nil, mipmap:number|nil, compression_type:number|nil} A table containing info about the texture. Supported entries: ---- ----type ----number The texture type. Supported values: ---- ---- ----resource.TEXTURE_TYPE_2D ----resource.TEXTURE_TYPE_CUBE_MAP ---- ---- ----width ----number The width of the texture (in pixels) ----height ----number The width of the texture (in pixels) ----format ----number The texture format, note that some of these formats are platform specific. Supported values: ---- ---- ----resource.TEXTURE_FORMAT_LUMINANCE ----resource.TEXTURE_FORMAT_RGB ----resource.TEXTURE_FORMAT_RGBA ---- ----These constants might not be available on the device: ----- resource.TEXTURE_FORMAT_RGB_PVRTC_2BPPV1 ----- resource.TEXTURE_FORMAT_RGB_PVRTC_4BPPV1 ----- resource.TEXTURE_FORMAT_RGBA_PVRTC_2BPPV1 ----- resource.TEXTURE_FORMAT_RGBA_PVRTC_4BPPV1 ----- resource.TEXTURE_FORMAT_RGB_ETC1 ----- resource.TEXTURE_FORMAT_RGBA_ETC2 ----- resource.TEXTURE_FORMAT_RGBA_ASTC_4x4 ----- resource.TEXTURE_FORMAT_RGB_BC1 ----- resource.TEXTURE_FORMAT_RGBA_BC3 ----- resource.TEXTURE_FORMAT_R_BC4 ----- resource.TEXTURE_FORMAT_RG_BC5 ----- resource.TEXTURE_FORMAT_RGBA_BC7 ----- resource.TEXTURE_FORMAT_RGB16F ----- resource.TEXTURE_FORMAT_RGB32F ----- resource.TEXTURE_FORMAT_RGBA16F ----- resource.TEXTURE_FORMAT_RGBA32F ----- resource.TEXTURE_FORMAT_R16F ----- resource.TEXTURE_FORMAT_RG16F ----- resource.TEXTURE_FORMAT_R32F ----- resource.TEXTURE_FORMAT_RG32F ----You can test if the device supports these values by checking if a specific enum is nil or not: ----if resource.TEXTURE_FORMAT_RGBA16F ~= nil then ---- -- it is safe to use this format ----end ---- ---- ---- ----x ----number optional x offset of the texture (in pixels) ----y ----number optional y offset of the texture (in pixels) ----mipmap ----number optional mipmap to upload the data to ----compression_type ----number optional specify the compression type for the data in the buffer object that holds the texture data. Defaults to resource.COMPRESSION_TYPE_DEFAULT, i.e no compression. Supported values: ---- ---- ----COMPRESSION_TYPE_DEFAULT ----COMPRESSION_TYPE_BASIS_UASTC ---- ----@param buffer buffer_data The buffer of precreated pixel data ---- To update a cube map texture you need to pass in six times the amount of data via the buffer, since a cube map has six sides! -function resource.set_texture(path, table, buffer) end - ----Constructor-like function with two purposes: ----Load the specified resource as part of loading the script ----Return a hash to the run-time version of the resource ---- This function can only be called within go.property function calls. ----@param path string|nil optional resource path string to the resource ----@return hash path a path hash to the binary version of the resource -function resource.texture(path) end - ----Constructor-like function with two purposes: ----Load the specified resource as part of loading the script ----Return a hash to the run-time version of the resource ---- This function can only be called within go.property function calls. ----@param path string|nil optional resource path string to the resource ----@return hash path a path hash to the binary version of the resource -function resource.tile_source(path) end - -return resource \ No newline at end of file diff --git a/annotations/defold_annotations/socket.lua b/annotations/defold_annotations/socket.lua deleted file mode 100644 index 6eae421..0000000 --- a/annotations/defold_annotations/socket.lua +++ /dev/null @@ -1,173 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - LuaSocket API documentation - - LuaSocket is a Lua extension library that provides - support for the TCP and UDP transport layers. Defold provides the "socket" namespace in - runtime, which contain the core C functionality. Additional LuaSocket support modules for - SMTP, HTTP, FTP etc are not part of the core included, but can be easily added to a project - and used. - Note the included helper module "socket.lua" in "builtins/scripts/socket.lua". Require this - module to add some additional functions and shortcuts to the namespace: - require "builtins.scripts.socket" - LuaSocket is Copyright © 2004-2007 Diego Nehab. All rights reserved. - LuaSocket is free software, released under the MIT license (same license as the Lua core). ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.socket -socket = {} - ----This constant contains the maximum number of sockets that the select function can handle. -socket._SETSIZE = nil - ----This constant has a string describing the current LuaSocket version. -socket._VERSION = nil - ----This function is a shortcut that creates and returns a TCP client object connected to a remote ----address at a given port. Optionally, the user can also specify the local address and port to ----bind (locaddr and locport), or restrict the socket family to "inet" or "inet6". ----Without specifying family to connect, whether a tcp or tcp6 connection is created depends on ----your system configuration. ----@param address string the address to connect to. ----@param port number the port to connect to. ----@param locaddr string|nil optional local address to bind to. ----@param locport number|nil optional local port to bind to. ----@param family string|nil optional socket family to use, "inet" or "inet6". ----@return socket_client|nil tcp_client a new IPv6 TCP client object, or nil in case of error. ----@return string|nil error the error message, or nil if no error occurred. -function socket.connect(address, port, locaddr, locport, family) end - ----This function converts a host name to IPv4 or IPv6 address. ----The supplied address can be an IPv4 or IPv6 address or host name. ----The function returns a table with all information returned by the resolver: ----{ ---- [1] = { ---- family = family-name-1, ---- addr = address-1 ---- }, ---- ... ---- [n] = { ---- family = family-name-n, ---- addr = address-n ---- } ----} ----Here, family contains the string "inet" for IPv4 addresses, and "inet6" for IPv6 addresses. ----In case of error, the function returns nil followed by an error message. ----@param address string a hostname or an IPv4 or IPv6 address. ----@return table|nil resolved a table with all information returned by the resolver, or if an error occurs, nil. ----@return string|nil error the error message, or nil if no error occurred. -function socket.dns.getaddrinfo(address) end - ----Returns the standard host name for the machine as a string. ----@return string hostname the host name for the machine. -function socket.dns.gethostname() end - ----This function converts an address to host name. ----The supplied address can be an IPv4 or IPv6 address or host name. ----The function returns a table with all information returned by the resolver: ----{ ---- [1] = host-name-1, ---- ... ---- [n] = host-name-n, ----} ----@param address string a hostname or an IPv4 or IPv6 address. ----@return table|nil resolved a table with all information returned by the resolver, or if an error occurs, nil. ----@return string|nil error the error message, or nil if no error occurred. -function socket.dns.getnameinfo(address) end - ----This function converts from an IPv4 address to host name. ----The address can be an IPv4 address or a host name. ----@param address string an IPv4 address or host name. ----@return string|nil hostname the canonic host name of the given address, or nil in case of an error. ----@return table|string resolved a table with all information returned by the resolver, or if an error occurs, the error message string. -function socket.dns.tohostname(address) end - ----This function converts a host name to IPv4 address. ----The address can be an IP address or a host name. ----@param address string a hostname or an IP address. ----@return string|nil ip_address the first IP address found for the hostname, or nil in case of an error. ----@return table|string resolved a table with all information returned by the resolver, or if an error occurs, the error message string. -function socket.dns.toip(address) end - ----Returns the time in seconds, relative to the system epoch (Unix epoch time since January 1, 1970 (UTC) or Windows file time since January 1, 1601 (UTC)). ----You should use the values returned by this function for relative measurements only. ----@return number seconds the number of seconds elapsed. -function socket.gettime() end - ----This function creates and returns a clean try function that allows for cleanup before the exception is raised. ----The finalizer function will be called in protected mode (see protect). ----@param finalizer function a function that will be called before the try throws the exception. ----@return function try the customized try function. -function socket.newtry(finalizer) end - ----Converts a function that throws exceptions into a safe function. This function only catches exceptions thrown by try functions. It does not catch normal Lua errors. ---- Beware that if your function performs some illegal operation that raises an error, the protected function will catch the error and return it as a string. This is because try functions uses errors as the mechanism to throw exceptions. ----@param func function a function that calls a try function (or assert, or error) to throw exceptions. ----@return fun(function) safe_func an equivalent function that instead of throwing exceptions, returns nil followed by an error message. -function socket.protect(func) end - ----The function returns a list with the sockets ready for reading, a list with the sockets ready for writing and an error message. The error message is "timeout" if a timeout condition was met and nil otherwise. The returned tables are doubly keyed both by integers and also by the sockets themselves, to simplify the test if a specific socket has changed status. ----Recvt and sendt parameters can be empty tables or nil. Non-socket values (or values with non-numeric indices) in these arrays will be silently ignored. ----The returned tables are doubly keyed both by integers and also by the sockets themselves, to simplify the test if a specific socket has changed status. ---- This function can monitor a limited number of sockets, as defined by the constant socket._SETSIZE. This number may be as high as 1024 or as low as 64 by default, depending on the system. It is usually possible to change this at compile time. Invoking select with a larger number of sockets will raise an error. ---- A known bug in WinSock causes select to fail on non-blocking TCP sockets. The function may return a socket as writable even though the socket is not ready for sending. ---- Calling select with a server socket in the receive parameter before a call to accept does not guarantee accept will return immediately. Use the settimeout method or accept might block forever. ---- If you close a socket and pass it to select, it will be ignored. ----(Using select with non-socket objects: Any object that implements getfd and dirty can be used with select, allowing objects from other libraries to be used within a socket.select driven loop.) ----@param recvt table array with the sockets to test for characters available for reading. ----@param sendt table array with sockets that are watched to see if it is OK to immediately write on them. ----@param timeout number|nil the maximum amount of time (in seconds) to wait for a change in status. Nil, negative or omitted timeout value allows the function to block indefinitely. ----@return table sockets_r a list with the sockets ready for reading. ----@return table sockets_w a list with the sockets ready for writing. ----@return string|nil error an error message. "timeout" if a timeout condition was met, otherwise nil. -function socket.select(recvt, sendt, timeout) end - ----This function drops a number of arguments and returns the remaining. ----It is useful to avoid creation of dummy variables: ----D is the number of arguments to drop. Ret1 to retN are the arguments. ----The function returns retD+1 to retN. ----@param d number the number of arguments to drop. ----@param ret1 any|nil argument 1. ----@param ret2 any|nil argument 2. ----@param retN any|nil argument N. ----@return any|nil retD+1 argument D+1. ----@return any|nil retD+2 argument D+2. ----@return any|nil retN argument N. -function socket.skip(d, ret1, ret2, retN) end - ----Freezes the program execution during a given amount of time. ----@param time number the number of seconds to sleep for. -function socket.sleep(time) end - ----Creates and returns an IPv4 TCP master object. A master object can be transformed into a server object with the method listen (after a call to bind) or into a client object with the method connect. The only other method supported by a master object is the close method. ----@return socket_master|nil tcp_master a new IPv4 TCP master object, or nil in case of error. ----@return string|nil error the error message, or nil if no error occurred. -function socket.tcp() end - ----Creates and returns an IPv6 TCP master object. A master object can be transformed into a server object with the method listen (after a call to bind) or into a client object with the method connect. The only other method supported by a master object is the close method. ----Note: The TCP object returned will have the option "ipv6-v6only" set to true. ----@return socket_master|nil tcp_master a new IPv6 TCP master object, or nil in case of error. ----@return string|nil error the error message, or nil if no error occurred. -function socket.tcp6() end - ----Creates and returns an unconnected IPv4 UDP object. Unconnected objects support the sendto, receive, receivefrom, getoption, getsockname, setoption, settimeout, setpeername, setsockname, and close methods. The setpeername method is used to connect the object. ----@return socket_unconnected|nil udp_unconnected a new unconnected IPv4 UDP object, or nil in case of error. ----@return string|nil error the error message, or nil if no error occurred. -function socket.udp() end - ----Creates and returns an unconnected IPv6 UDP object. Unconnected objects support the sendto, receive, receivefrom, getoption, getsockname, setoption, settimeout, setpeername, setsockname, and close methods. The setpeername method is used to connect the object. ----Note: The UDP object returned will have the option "ipv6-v6only" set to true. ----@return socket_unconnected|nil udp_unconnected a new unconnected IPv6 UDP object, or nil in case of error. ----@return string|nil error the error message, or nil if no error occurred. -function socket.udp6() end - - - -return socket \ No newline at end of file diff --git a/annotations/defold_annotations/sound.lua b/annotations/defold_annotations/sound.lua deleted file mode 100644 index d25c055..0000000 --- a/annotations/defold_annotations/sound.lua +++ /dev/null @@ -1,160 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Sound API documentation ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.sound -sound = {} - ----Get mixer group gain ---- Note that gain is in linear scale, between 0 and 1. ----To get the dB value from the gain, use the formula 20 * log(gain). ----Inversely, to find the linear value from a dB value, use the formula ----10db/20. ----@param group string|hash group name ----@return number gain gain in linear scale -function sound.get_group_gain(group) end - ----Get a mixer group name as a string. ---- This function is to be used for debugging and ----development tooling only. The function does a reverse hash lookup, which does not ----return a proper string value when the game is built in release mode. ----@param group string|hash group name ----@return string name group name -function sound.get_group_name(group) end - ----Get a table of all mixer group names (hashes). ----@return hash[] groups table of mixer group names -function sound.get_groups() end - ----Get peak value from mixer group. ---- Note that gain is in linear scale, between 0 and 1. ----To get the dB value from the gain, use the formula 20 * log(gain). ----Inversely, to find the linear value from a dB value, use the formula ----10db/20. ----Also note that the returned value might be an approximation and in particular ----the effective window might be larger than specified. ----@param group string|hash group name ----@param window number window length in seconds ----@return number peak_l peak value for left channel ----@return number peak_r peak value for right channel -function sound.get_peak(group, window) end - ----Get RMS (Root Mean Square) value from mixer group. This value is the ----square root of the mean (average) value of the squared function of ----the instantaneous values. ----For instance: for a sinewave signal with a peak gain of -1.94 dB (0.8 linear), ----the RMS is 0.8 × 1/sqrt(2) which is about 0.566. ---- Note the returned value might be an approximation and in particular ----the effective window might be larger than specified. ----@param group string|hash group name ----@param window number window length in seconds ----@return number rms_l RMS value for left channel ----@return number rms_r RMS value for right channel -function sound.get_rms(group, window) end - ----Checks if background music is playing, e.g. from iTunes. ---- On non mobile platforms, ----this function always return false. ---- On Android you can only get a correct reading ----of this state if your game is not playing any sounds itself. This is a limitation ----in the Android SDK. If your game is playing any sounds, even with a gain of zero, this ----function will return false. ----The best time to call this function is: ----In the init function of your main collection script before any sounds are triggered ----In a window listener callback when the window.WINDOW_EVENT_FOCUS_GAINED event is received ----Both those times will give you a correct reading of the state even when your application is ----swapped out and in while playing sounds and it works equally well on Android and iOS. ----@return boolean playing true if music is playing, otherwise false. -function sound.is_music_playing() end - ----Checks if a phone call is active. If there is an active phone call all ----other sounds will be muted until the phone call is finished. ---- On non mobile platforms, ----this function always return false. ----@return boolean call_active true if there is an active phone call, false otherwise. -function sound.is_phone_call_active() end - ----Pause all active voices ----@param url string|hash|url the sound that should pause ----@param pause bool true if the sound should pause -function sound.pause(url, pause) end - ----Make the sound component play its sound. Multiple voices are supported. The limit is set to 32 voices per sound component. ---- Note that gain is in linear scale, between 0 and 1. ----To get the dB value from the gain, use the formula 20 * log(gain). ----Inversely, to find the linear value from a dB value, use the formula ----10db/20. ---- A sound will continue to play even if the game object the sound component belonged to is deleted. You can call sound.stop() to stop the sound. ----@param url string|hash|url the sound that should play ----@param play_properties { delay:number|nil, gain:number|nil, pan:number|nil, speed:number|nil }|nil ----optional table with properties: ----delay ----number delay in seconds before the sound starts playing, default is 0. ----gain ----number sound gain between 0 and 1, default is 1. The final gain of the sound will be a combination of this gain, the group gain and the master gain. ----pan ----number sound pan between -1 and 1, default is 0. The final pan of the sound will be an addition of this pan and the sound pan. ----speed ----number sound speed where 1.0 is normal speed, 0.5 is half speed and 2.0 is double speed. The final speed of the sound will be a multiplication of this speed and the sound speed. ---- ----@param complete_function fun(self, message_id, message, sender)|nil function to call when the sound has finished playing or stopped manually via sound.stop. ---- ----self ----object The current object. ----message_id ----hash The name of the completion message, which can be either "sound_done" if the sound has finished playing, or "sound_stopped" if it was stopped manually. ----message ----table Information about the completion: ---- ---- ----number play_id - the sequential play identifier that was given by the sound.play function. ---- ---- ----sender ----url The invoker of the callback: the sound component. ---- ----@return number play_id The identifier for the sound voice -function sound.play(url, play_properties, complete_function) end - ----Set gain on all active playing voices of a sound. ---- Note that gain is in linear scale, between 0 and 1. ----To get the dB value from the gain, use the formula 20 * log(gain). ----Inversely, to find the linear value from a dB value, use the formula ----10db/20. ----@param url string|hash|url the sound to set the gain of ----@param gain number|nil sound gain between 0 and 1. The final gain of the sound will be a combination of this gain, the group gain and the master gain. -function sound.set_gain(url, gain) end - ----Set mixer group gain ---- Note that gain is in linear scale, between 0 and 1. ----To get the dB value from the gain, use the formula 20 * log(gain). ----Inversely, to find the linear value from a dB value, use the formula ----10db/20. ----@param group string|hash group name ----@param gain number gain in linear scale -function sound.set_group_gain(group, gain) end - ----Set panning on all active playing voices of a sound. ----The valid range is from -1.0 to 1.0, representing -45 degrees left, to +45 degrees right. ----@param url string|hash|url the sound to set the panning value to ----@param pan number|nil sound panning between -1.0 and 1.0 -function sound.set_pan(url, pan) end - ----Stop playing all active voices or just one voice if play_id provided ----@param url string|hash|url the sound component that should stop ----@param stop_properties { play_id:number }|nil ----optional table with properties: ----play_id ----number the sequential play identifier that should be stopped (was given by the sound.play() function) ---- -function sound.stop(url, stop_properties) end - -return sound \ No newline at end of file diff --git a/annotations/defold_annotations/sprite.lua b/annotations/defold_annotations/sprite.lua deleted file mode 100644 index f7b5aa0..0000000 --- a/annotations/defold_annotations/sprite.lua +++ /dev/null @@ -1,62 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Sprite API documentation ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.sprite -sprite = {} - ----Play an animation on a sprite component from its tile set ----An optional completion callback function can be provided that will be called when ----the animation has completed playing. If no function is provided, ----a animation_done message is sent to the script that started the animation. ----@param url string|hash|url the sprite that should play the animation ----@param id string|hash hashed id of the animation to play ----@param complete_function fun(self, message_id, message, sender)|nil function to call when the animation has completed. ---- ----self ----object The current object. ----message_id ----hash The name of the completion message, "animation_done". ----message ----table Information about the completion: ---- ---- ----number current_tile - the current tile of the sprite. ----hash id - id of the animation that was completed. ---- ---- ----sender ----url The invoker of the callback: the sprite component. ---- ----@param play_properties table|nil optional table with properties: ---- ----offset ----number the normalized initial value of the animation cursor when the animation starts playing. ----playback_rate ----number the rate with which the animation will be played. Must be positive. ---- -function sprite.play_flipbook(url, id, complete_function, play_properties) end - ----Sets horizontal flipping of the provided sprite's animations. ----The sprite is identified by its URL. ----If the currently playing animation is flipped by default, flipping it again will make it appear like the original texture. ----@param url string|hash|url the sprite that should flip its animations ----@param flip boolean true if the sprite should flip its animations, false if not -function sprite.set_hflip(url, flip) end - ----Sets vertical flipping of the provided sprite's animations. ----The sprite is identified by its URL. ----If the currently playing animation is flipped by default, flipping it again will make it appear like the original texture. ----@param url string|hash|url the sprite that should flip its animations ----@param flip boolean true if the sprite should flip its animations, false if not -function sprite.set_vflip(url, flip) end - -return sprite \ No newline at end of file diff --git a/annotations/defold_annotations/sys.lua b/annotations/defold_annotations/sys.lua deleted file mode 100644 index 313cf4e..0000000 --- a/annotations/defold_annotations/sys.lua +++ /dev/null @@ -1,314 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - System API documentation - - Functions and messages for using system resources, controlling the engine, - error handling and debugging. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.sys -sys = {} - ----network connected through other, non cellular, connection -sys.NETWORK_CONNECTED = nil - ----network connected through mobile cellular -sys.NETWORK_CONNECTED_CELLULAR = nil - ----no network connection found -sys.NETWORK_DISCONNECTED = nil - ----an asyncronous request is unable to read the resource -sys.REQUEST_STATUS_ERROR_IO_ERROR = nil - ----an asyncronous request is unable to locate the resource -sys.REQUEST_STATUS_ERROR_NOT_FOUND = nil - ----an asyncronous request has finished successfully -sys.REQUEST_STATUS_FINISHED = nil - ----deserializes buffer into a lua table ----@param buffer string buffer to deserialize from ----@return table table lua table with deserialized data -function sys.deserialize(buffer) end - ----Check if a path exists ----Good for checking if a file exists before loading a large file ----@param path string path to check ----@return bool result true if the path exists, false otherwise -function sys.exists(path) end - ----Terminates the game application and reports the specified code to the OS. ----@param code number exit code to report to the OS, 0 means clean exit -function sys.exit(code) end - ----Returns a table with application information for the requested app. ---- On iOS, the app_string is an url scheme for the app that is queried. Your ----game needs to list the schemes that are queried in an LSApplicationQueriesSchemes array ----in a custom "Info.plist". ---- On Android, the app_string is the package identifier for the app. ----@param app_string string platform specific string with application package or query, see above for details. ----@return { installed:boolean } app_info table with application information in the following fields: ---- ----installed ----boolean true if the application is installed, false otherwise. ---- -function sys.get_application_info(app_string) end - ----The path from which the application is run. ----@return string path path to application executable -function sys.get_application_path() end - ----Get integer config value from the game.project configuration file with optional default value ----@param key string key to get value for. The syntax is SECTION.KEY ----@param default_value integer|nil (optional) default value to return if the value does not exist ----@return integer value config value as an integer. default_value if the config key does not exist. 0 if no default value was supplied. -function sys.get_config_int(key, default_value) end - ----Get number config value from the game.project configuration file with optional default value ----@param key string key to get value for. The syntax is SECTION.KEY ----@param default_value number|nil (optional) default value to return if the value does not exist ----@return number value config value as an number. default_value if the config key does not exist. 0 if no default value was supplied. -function sys.get_config_number(key, default_value) end - ----Get string config value from the game.project configuration file with optional default value ----@param key string key to get value for. The syntax is SECTION.KEY ----@param default_value string|nil (optional) default value to return if the value does not exist ----@return string value config value as a string. default_value if the config key does not exist. nil if no default value was supplied. -function sys.get_config_string(key, default_value) end - ---- Returns the current network connectivity status ----on mobile platforms. ----On desktop, this function always return sys.NETWORK_CONNECTED. ----@return constant status network connectivity status: ---- ----sys.NETWORK_DISCONNECTED (no network connection is found) ----sys.NETWORK_CONNECTED_CELLULAR (connected through mobile cellular) ----sys.NETWORK_CONNECTED (otherwise, Wifi) ---- -function sys.get_connectivity() end - ----Returns a table with engine information. ----@return { version:string, version_sha1:string, is_debug:boolean } engine_info table with engine information in the following fields: ---- ----version ----string The current Defold engine version, i.e. "1.2.96" ----version_sha1 ----string The SHA1 for the current engine build, i.e. "0060183cce2e29dbd09c85ece83cbb72068ee050" ----is_debug ----boolean If the engine is a debug or release version ---- -function sys.get_engine_info() end - ----Create a path to the host device for unit testing ----Useful for saving logs etc during development ----@param filename string file to read from ----@return string host_path the path prefixed with the proper host mount -function sys.get_host_path(filename) end - ----Returns an array of tables with information on network interfaces. ----@return { name:string, address:string|nil, mac:string|nil, up:boolean, running:boolean } ifaddrs an array of tables. Each table entry contain the following fields: ---- ----name ----string Interface name ----address ----string IP address. might be nil if not available. ----mac ----string Hardware MAC address. might be nil if not available. ----up ----boolean true if the interface is up (available to transmit and receive data), false otherwise. ----running ----boolean true if the interface is running, false otherwise. ---- -function sys.get_ifaddrs() end - ----The save-file path is operating system specific and is typically located under the user's home directory. ----@param application_id string user defined id of the application, which helps define the location of the save-file ----@param file_name string file-name to get path for ----@return string path path to save-file -function sys.get_save_file(application_id, file_name) end - ----Returns a table with system information. ----@param options { ignore_secure:boolean|nil }|nil optional options table ----- ignore_secure boolean this flag ignores values might be secured by OS e.g. device_ident ----@return { device_model:string|nil, manufacturer:string|nil, system_name:string, system_version:string, api_version:string, language:string, device_language:string, territory:string, gmt_offset:number, device_ident:string|nil, user_agent:string|nil } sys_info table with system information in the following fields: ---- ----device_model ----string Only available on iOS and Android. ----manufacturer ----string Only available on iOS and Android. ----system_name ----string The system name: "Darwin", "Linux", "Windows", "HTML5", "Android" or "iPhone OS" ----system_version ----string The system OS version. ----api_version ----string The API version on the system. ----language ----string Two character ISO-639 format, i.e. "en". ----device_language ----string Two character ISO-639 format (i.e. "sr") and, if applicable, followed by a dash (-) and an ISO 15924 script code (i.e. "sr-Cyrl" or "sr-Latn"). Reflects the device preferred language. ----territory ----string Two character ISO-3166 format, i.e. "US". ----gmt_offset ----number The current offset from GMT (Greenwich Mean Time), in minutes. ----device_ident ----string This value secured by OS. "identifierForVendor" on iOS. "android_id" on Android. On Android, you need to add READ_PHONE_STATE permission to be able to get this data. We don't use this permission in Defold. ----user_agent ----string The HTTP user agent, i.e. "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_3) AppleWebKit/602.4.8 (KHTML, like Gecko) Version/10.0.3 Safari/602.4.8" ---- -function sys.get_sys_info(options) end - ----If the file exists, it must have been created by sys.save to be loaded. ----@param filename string file to read from ----@return table loaded lua table, which is empty if the file could not be found -function sys.load(filename) end - ----The sys.load_buffer function will first try to load the resource ----from any of the mounted resource locations and return the data if ----any matching entries found. If not, the path will be tried ----as is from the primary disk on the device. ----In order for the engine to include custom resources in the build process, you need ----to specify them in the "custom_resources" key in your "game.project" settings file. ----You can specify single resource files or directories. If a directory is included ----in the resource list, all files and directories in that directory is recursively ----included: ----For example "main/data/,assets/level_data.json". ----@param path string the path to load the buffer from ----@return buffer_data buffer the buffer with data -function sys.load_buffer(path) end - ----The sys.load_buffer function will first try to load the resource ----from any of the mounted resource locations and return the data if ----any matching entries found. If not, the path will be tried ----as is from the primary disk on the device. ----In order for the engine to include custom resources in the build process, you need ----to specify them in the "custom_resources" key in your "game.project" settings file. ----You can specify single resource files or directories. If a directory is included ----in the resource list, all files and directories in that directory is recursively ----included: ----For example "main/data/,assets/level_data.json". ----Note that issuing multiple requests of the same resource will yield ----individual buffers per request. There is no implic caching of the buffers ----based on request path. ----@param path string the path to load the buffer from ----@param status_callback fun(self, request_id, result) A status callback that will be invoked when a request has been handled, or an error occured. The result is a table containing: ---- ----status ----number The status of the request, supported values are: ---- ---- ----resource.REQUEST_STATUS_FINISHED ----resource.REQUEST_STATUS_ERROR_IO_ERROR ----resource.REQUEST_STATUS_ERROR_NOT_FOUND ---- ---- ----buffer ----buffer If the request was successfull, this will contain the request payload in a buffer object, and nil otherwise. Make sure to check the status before doing anything with the buffer value! ---- ----@return resource_handle handle a handle to the request -function sys.load_buffer_async(path, status_callback) end - ----Loads a custom resource. Specify the full filename of the resource that you want ----to load. When loaded, the file data is returned as a string. ----If loading fails, the function returns nil plus the error message. ----In order for the engine to include custom resources in the build process, you need ----to specify them in the "custom_resources" key in your "game.project" settings file. ----You can specify single resource files or directories. If a directory is included ----in the resource list, all files and directories in that directory is recursively ----included: ----For example "main/data/,assets/level_data.json". ----@param filename string resource to load, full path ----@return string|nil data loaded data, or nil if the resource could not be loaded ----@return string|nil error the error message, or nil if no error occurred -function sys.load_resource(filename) end - ----Open URL in default application, typically a browser ----@param url string url to open ----@param attributes { target:string|nil, name:string|nil }|nil table with attributes ----target ----- string : Optional. Specifies the target attribute or the name of the window. The following values are supported: ----- _self - (default value) URL replaces the current page. ----- _blank - URL is loaded into a new window, or tab. ----- _parent - URL is loaded into the parent frame. ----- _top - URL replaces any framesets that may be loaded. ----- name - The name of the window (Note: the name does not specify the title of the new window). ----@return boolean success a boolean indicating if the url could be opened or not -function sys.open_url(url, attributes) end - ----Reboots the game engine with a specified set of arguments. ----Arguments will be translated into command line arguments. Calling reboot ----function is equivalent to starting the engine with the same arguments. ----On startup the engine reads configuration from "game.project" in the ----project root. ----@param arg1 string|nil argument 1 ----@param arg2 string|nil argument 2 ----@param arg3 string|nil argument 3 ----@param arg4 string|nil argument 4 ----@param arg5 string|nil argument 5 ----@param arg6 string|nil argument 6 -function sys.reboot(arg1, arg2, arg3, arg4, arg5, arg6) end - ----The table can later be loaded by sys.load. ----Use sys.get_save_file to obtain a valid location for the file. ----Internally, this function uses a workspace buffer sized output file sized 512kb. ----This size reflects the output file size which must not exceed this limit. ----Additionally, the total number of rows that any one table may contain is limited to 65536 ----(i.e. a 16 bit range). When tables are used to represent arrays, the values of ----keys are permitted to fall within a 32 bit range, supporting sparse arrays, however ----the limit on the total number of rows remains in effect. ----@param filename string file to write to ----@param table table lua table to save ----@return boolean success a boolean indicating if the table could be saved or not -function sys.save(filename, table) end - ----The buffer can later deserialized by sys.deserialize. ----This method has all the same limitations as sys.save. ----@param table table lua table to serialize ----@return string buffer serialized data buffer -function sys.serialize(table) end - ----Sets the host that is used to check for network connectivity against. ----@param host string hostname to check against -function sys.set_connectivity_host(host) end - ----Set the Lua error handler function. ----The error handler is a function which is called whenever a lua runtime error occurs. ----@param error_handler fun(source, message, traceback) the function to be called on error ---- ----source ----string The runtime context of the error. Currently, this is always "lua". ----message ----string The source file, line number and error message. ----traceback ----string The stack traceback. ---- -function sys.set_error_handler(error_handler) end - ----Set game update-frequency (frame cap). This option is equivalent to display.update_frequency in ----the "game.project" settings but set in run-time. If Vsync checked in "game.project", the rate will ----be clamped to a swap interval that matches any detected main monitor refresh rate. If Vsync is ----unchecked the engine will try to respect the rate in software using timers. There is no ----guarantee that the frame cap will be achieved depending on platform specifics and hardware settings. ----@param frequency number target frequency. 60 for 60 fps -function sys.set_update_frequency(frequency) end - ----Set the vsync swap interval. The interval with which to swap the front and back buffers ----in sync with vertical blanks (v-blank), the hardware event where the screen image is updated ----with data from the front buffer. A value of 1 swaps the buffers at every v-blank, a value of ----2 swaps the buffers every other v-blank and so on. A value of 0 disables waiting for v-blank ----before swapping the buffers. Default value is 1. ----When setting the swap interval to 0 and having vsync disabled in ----"game.project", the engine will try to respect the set frame cap value from ----"game.project" in software instead. ----This setting may be overridden by driver settings. ----@param swap_interval number target swap interval. -function sys.set_vsync_swap_interval(swap_interval) end - -return sys \ No newline at end of file diff --git a/annotations/defold_annotations/tilemap.lua b/annotations/defold_annotations/tilemap.lua deleted file mode 100644 index cff05cd..0000000 --- a/annotations/defold_annotations/tilemap.lua +++ /dev/null @@ -1,90 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Tilemap API documentation - - Functions and messages used to manipulate tile map components. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.tilemap -tilemap = {} - ----flip tile horizontally -tilemap.H_FLIP = nil - ----rotate tile 180 degrees clockwise -tilemap.ROTATE_180 = nil - ----rotate tile 270 degrees clockwise -tilemap.ROTATE_270 = nil - ----rotate tile 90 degrees clockwise -tilemap.ROTATE_90 = nil - ----flip tile vertically -tilemap.V_FLIP = nil - ----Get the bounds for a tile map. This function returns multiple values: ----The lower left corner index x and y coordinates (1-indexed), ----the tile map width and the tile map height. ----The resulting values take all tile map layers into account, meaning that ----the bounds are calculated as if all layers were collapsed into one. ----@param url string|hash|url the tile map ----@return number x x coordinate of the bottom left corner ----@return number y y coordinate of the bottom left corner ----@return number w number of columns (width) in the tile map ----@return number h number of rows (height) in the tile map -function tilemap.get_bounds(url) end - ----Get the tile set at the specified position in the tilemap. ----The position is identified by the tile index starting at origin ----with index 1, 1. (see tilemap.set_tile()) ----Which tile map and layer to query is identified by the URL and the ----layer name parameters. ----@param url string|hash|url the tile map ----@param layer string|hash name of the layer for the tile ----@param x number x-coordinate of the tile ----@param y number y-coordinate of the tile ----@return number tile index of the tile -function tilemap.get_tile(url, layer, x, y) end - ----Replace a tile in a tile map with a new tile. ----The coordinates of the tiles are indexed so that the "first" tile just ----above and to the right of origin has coordinates 1,1. ----Tiles to the left of and below origin are indexed 0, -1, -2 and so forth. ----+-------+-------+------+------+ ----| 0,3 | 1,3 | 2,3 | 3,3 | ----+-------+-------+------+------+ ----| 0,2 | 1,2 | 2,2 | 3,2 | ----+-------+-------+------+------+ ----| 0,1 | 1,1 | 2,1 | 3,1 | ----+-------O-------+------+------+ ----| 0,0 | 1,0 | 2,0 | 3,0 | ----+-------+-------+------+------+ ----The coordinates must be within the bounds of the tile map as it were created. ----That is, it is not possible to extend the size of a tile map by setting tiles outside the edges. ----To clear a tile, set the tile to number 0. Which tile map and layer to manipulate is identified by the URL and the layer name parameters. ----Transform bitmask is arithmetic sum of one or both FLIP constants (tilemap.H_FLIP, tilemap.V_FLIP) and/or one of ROTATION constants ----(tilemap.ROTATE_90, tilemap.ROTATE_180, tilemap.ROTATE_270). ----Flip always applies before rotation (clockwise). ----@param url string|hash|url the tile map ----@param layer string|hash name of the layer for the tile ----@param x number x-coordinate of the tile ----@param y number y-coordinate of the tile ----@param tile number index of new tile to set. 0 resets the cell ----@param transform_bitmask number|nil optional flip and/or rotation should be applied to the tile -function tilemap.set_tile(url, layer, x, y, tile, transform_bitmask) end - ----Sets the visibility of the tilemap layer ----@param url string|hash|url the tile map ----@param layer string|hash name of the layer for the tile ----@param visible boolean should the layer be visible -function tilemap.set_visible(url, layer, visible) end - -return tilemap \ No newline at end of file diff --git a/annotations/defold_annotations/timer.lua b/annotations/defold_annotations/timer.lua deleted file mode 100644 index d752ffe..0000000 --- a/annotations/defold_annotations/timer.lua +++ /dev/null @@ -1,68 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Timer API documentation - - Timers allow you to set a delay and a callback to be called when the timer completes. - The timers created with this API are updated with the collection timer where they - are created. If you pause or speed up the collection (using set_time_step) it will - also affect the new timer. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.timer -timer = {} - ----Indicates an invalid timer handle -timer.INVALID_TIMER_HANDLE = nil - ----You may cancel a timer from inside a timer callback. ----Cancelling a timer that is already executed or cancelled is safe. ----@param handle hash the timer handle returned by timer.delay() ----@return boolean true if the timer was active, false if the timer is already cancelled / complete -function timer.cancel(handle) end - ----Adds a timer and returns a unique handle. ----You may create more timers from inside a timer callback. ----Using a delay of 0 will result in a timer that triggers at the next frame just before ----script update functions. ----If you want a timer that triggers on each frame, set delay to 0.0f and repeat to true. ----Timers created within a script will automatically die when the script is deleted. ----@param delay number time interval in seconds ----@param repeating boolean true = repeat timer until cancel, false = one-shot timer ----@param callback fun(self, handle, time_elapsed) timer callback function ---- ----self ----object The current object ----handle ----number The handle of the timer ----time_elapsed ----number The elapsed time - on first trigger it is time since timer.delay call, otherwise time since last trigger ---- ----@return hash handle identifier for the create timer, returns timer.INVALID_TIMER_HANDLE if the timer can not be created -function timer.delay(delay, repeating, callback) end - ----Get information about timer. ----@param handle hash the timer handle returned by timer.delay() ----@return { time_remaining:number, delay:number, repeating:boolean }|nil data table or nil if timer is cancelled/completed. table with data in the following fields: ---- ----time_remaining ----number Time remaining until the next time a timer.delay() fires. ----delay ----number Time interval. ----repeating ----boolean true = repeat timer until cancel, false = one-shot timer. ---- -function timer.get_info(handle) end - ----Manual triggering a callback for a timer. ----@param handle hash the timer handle returned by timer.delay() ----@return boolean true if the timer was active, false if the timer is already cancelled / complete -function timer.trigger(handle) end - -return timer \ No newline at end of file diff --git a/annotations/defold_annotations/types.lua b/annotations/defold_annotations/types.lua deleted file mode 100644 index f3a8f27..0000000 --- a/annotations/defold_annotations/types.lua +++ /dev/null @@ -1,140 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Known classes and aliases used in the Defold API ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class matrix4 ----@field c0 vector4 ----@field c1 vector4 ----@field c2 vector4 ----@field c3 vector4 ----@field m00 number ----@field m01 number ----@field m02 number ----@field m03 number ----@field m10 number ----@field m11 number ----@field m12 number ----@field m13 number ----@field m20 number ----@field m21 number ----@field m22 number ----@field m23 number ----@field m30 number ----@field m31 number ----@field m32 number ----@field m33 number - ----@class on_input.action ----@field dx number|nil The change in x value of a pointer device, if present. ----@field dy number|nil The change in y value of a pointer device, if present. ----@field gamepad integer|nil The change in screen space y value of a pointer device, if present. ----@field pressed boolean|nil If the input was pressed this frame. This is not present for mouse movement. ----@field released boolean|nil If the input was released this frame. This is not present for mouse movement. ----@field repeated boolean|nil If the input was repeated this frame. This is similar to how a key on a keyboard is repeated when you hold it down. This is not present for mouse movement. ----@field screen_dx number|nil The change in screen space x value of a pointer device, if present. ----@field screen_dy number|nil The index of the gamepad device that provided the input. ----@field screen_x number|nil The screen space x value of a pointer device, if present. ----@field screen_y number|nil The screen space y value of a pointer device, if present. ----@field touch [on_input.touch]|nil List of touch input, one element per finger, if present. ----@field value number|nil The amount of input given by the user. This is usually 1 for buttons and 0-1 for analogue inputs. This is not present for mouse movement. ----@field x number|nil The x value of a pointer device, if present. ----@field y number|nil The y value of a pointer device, if present. - ----@class on_input.touch ----@field acc_x number|nil Accelerometer x value (if present). ----@field acc_y number|nil Accelerometer y value (if present). ----@field acc_z number|nil Accelerometer z value (if present). ----@field dx number The change in x value. ----@field dy number The change in y value. ----@field id number A number identifying the touch input during its duration. ----@field pressed boolean True if the finger was pressed this frame. ----@field released boolean True if the finger was released this frame. ----@field tap_count integer Number of taps, one for single, two for double-tap, etc ----@field x number The x touch location. ----@field y number The y touch location. - ----@class physics.raycast_response ----@field fraction number The fraction of the hit measured along the ray, where 0 is the start of the ray and 1 is the end ----@field group hash The collision group of the hit collision object as a hashed name ----@field id hash The instance id of the hit collision object ----@field normal vector3 The normal of the surface of the collision object where it was hit ----@field position vector3 The world position of the hit ----@field request_id number The id supplied when the ray cast was requested - ----@class resource.animation ----@field flip_horizontal boolean|nil Optional flip the animation horizontally, the default value is false ----@field flip_vertical boolean|nil Optional flip the animation vertically, the default value is false ----@field fps integer|nil Optional fps of the animation, the default value is 30 ----@field frame_end integer Index to the last geometry of the animation (non-inclusive). Indices are lua based and must be in the range of 1 .. in atlas. ----@field frame_start integer Index to the first geometry of the animation. Indices are lua based and must be in the range of 1 .. in atlas. ----@field height integer The height of the animation ----@field id string The id of the animation, used in e.g sprite.play_animation ----@field playback constant|nil Optional playback mode of the animation, the default value is go.PLAYBACK_ONCE_FORWARD ----@field width integer The width of the animation - ----@class resource.atlas ----@field animations resource.animation[] A list of the animations in the atlas ----@field geometries resource.geometry[] A list of the geometries that should map to the texture data ----@field texture string|hash The path to the texture resource, e.g "/main/my_texture.texturec" - ----@class resource.geometry ----@field id string The name of the geometry. Used when matching animations between multiple atlases ----@field indices number[] A list of the indices of the geometry in the form { i0, i1, i2, ..., in }. Each tripe in the list represents a triangle. ----@field uvs number[] A list of the uv coordinates in texture space of the geometry in the form of { u0, v0, u1, v1, ..., un, vn } ----@field vertices number[] A list of the vertices in texture space of the geometry in the form { px0, py0, px1, py1, ..., pxn, pyn } - ----@class socket.dns -socket.dns = {} - ----@class url ----@field fragment hash ----@field path hash ----@field socket hash - ----@class vector3 ----@field x number ----@field y number ----@field z number ----@operator add(vector3): vector3 ----@operator mul(number): vector3 ----@operator sub(vector3): vector3 ----@operator unm: vector3 - ----@class vector4 ----@field w number ----@field x number ----@field y number ----@field z number ----@operator add(vector4): vector4 ----@operator mul(number): vector4 ----@operator sub(vector4): vector4 ----@operator unm: vector4 - ----@alias array table ----@alias b2Body userdata ----@alias b2BodyType number ----@alias b2World userdata ----@alias bool boolean ----@alias buffer_data userdata ----@alias buffer_stream userdata ----@alias constant userdata ----@alias constant_buffer userdata ----@alias float number ----@alias hash userdata ----@alias node userdata ----@alias quaternion vector4 ----@alias render_predicate userdata ----@alias render_target userdata ----@alias resource_data userdata ----@alias resource_handle number|userdata ----@alias socket_client userdata ----@alias socket_master userdata ----@alias socket_unconnected userdata \ No newline at end of file diff --git a/annotations/defold_annotations/vmath.lua b/annotations/defold_annotations/vmath.lua deleted file mode 100644 index 078caf1..0000000 --- a/annotations/defold_annotations/vmath.lua +++ /dev/null @@ -1,404 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Vector math API documentation - - Functions for mathematical operations on vectors, matrices and quaternions. - The vector types (vmath.vector3 and vmath.vector4) supports addition and subtraction - with vectors of the same type. Vectors can be negated and multiplied (scaled) or divided by numbers. - The quaternion type (vmath.quat) supports multiplication with other quaternions. - The matrix type (vmath.matrix4) can be multiplied with numbers, other matrices - and vmath.vector4 values. - All types performs equality comparison by each component value. - The following components are available for the various types: - vector3 - x, y and z. Example: v.y - vector4 - x, y, z, and w. Example: v.w - quaternion - x, y, z, and w. Example: q.w - matrix4 - m00 to m33 where the first number is the row (starting from 0) and the second - number is the column. Columns can be accessed with c0 to c3, returning a vector4. - Example: m.m21 which is equal to m.c1.z - vector - indexed by number 1 to the vector length. Example: v[3] ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.vmath -vmath = {} - ----Calculates the conjugate of a quaternion. The result is a ----quaternion with the same magnitudes but with the sign of ----the imaginary (vector) parts changed: ----q* = [w, -v] ----@param q1 quaternion quaternion of which to calculate the conjugate ----@return quaternion q the conjugate -function vmath.conj(q1) end - ----Given two linearly independent vectors P and Q, the cross product, ----P × Q, is a vector that is perpendicular to both P and Q and ----therefore normal to the plane containing them. ----If the two vectors have the same direction (or have the exact ----opposite direction from one another, i.e. are not linearly independent) ----or if either one has zero length, then their cross product is zero. ----@param v1 vector3 first vector ----@param v2 vector3 second vector ----@return vector3 v a new vector representing the cross product -function vmath.cross(v1, v2) end - ----The returned value is a scalar defined as: ----P ⋅ Q = |P| |Q| cos θ ----where θ is the angle between the vectors P and Q. ----If the dot product is positive then the angle between the vectors is below 90 degrees. ----If the dot product is zero the vectors are perpendicular (at right-angles to each other). ----If the dot product is negative then the angle between the vectors is more than 90 degrees. ----@param v1 vector3|vector4 first vector ----@param v2 vector3|vector4 second vector ----@return number n dot product -function vmath.dot(v1, v2) end - ----The resulting matrix is the inverse of the supplied matrix. ---- For ortho-normal matrices, e.g. regular object transformation, ----use vmath.ortho_inv() instead. ----The specialized inverse for ortho-normalized matrices is much faster ----than the general inverse. ----@param m1 matrix4 matrix to invert ----@return matrix4 m inverse of the supplied matrix -function vmath.inv(m1) end - ----Returns the length of the supplied vector or quaternion. ----If you are comparing the lengths of vectors or quaternions, you should compare ----the length squared instead as it is slightly more efficient to calculate ----(it eliminates a square root calculation). ----@param v vector3|vector4|quaternion value of which to calculate the length ----@return number n length -function vmath.length(v) end - ----Returns the squared length of the supplied vector or quaternion. ----@param v vector3|vector4|quaternion value of which to calculate the squared length ----@return number n squared length -function vmath.length_sqr(v) end - ----Linearly interpolate between two quaternions. Linear ----interpolation of rotations are only useful for small ----rotations. For interpolations of arbitrary rotations, ----vmath.slerp yields much better results. ---- The function does not clamp t between 0 and 1. ----@param t number interpolation parameter, 0-1 ----@param q1 quaternion quaternion to lerp from ----@param q2 quaternion quaternion to lerp to ----@return quaternion q the lerped quaternion -function vmath.lerp(t, q1, q2) end - ----Linearly interpolate between two vectors. The function ----treats the vectors as positions and interpolates between ----the positions in a straight line. Lerp is useful to describe ----transitions from one place to another over time. ---- The function does not clamp t between 0 and 1. ----@param t number interpolation parameter, 0-1 ----@param v1 vector3|vector4 vector to lerp from ----@param v2 vector3|vector4 vector to lerp to ----@return vector3|vector4 v the lerped vector -function vmath.lerp(t, v1, v2) end - ----Linearly interpolate between two values. Lerp is useful ----to describe transitions from one value to another over time. ---- The function does not clamp t between 0 and 1. ----@param t number interpolation parameter, 0-1 ----@param n1 number number to lerp from ----@param n2 number number to lerp to ----@return number n the lerped number -function vmath.lerp(t, n1, n2) end - ----The resulting identity matrix describes a transform with ----no translation or rotation. ----@return matrix4 m identity matrix -function vmath.matrix4() end - ----Creates a new matrix with all components set to the ----corresponding values from the supplied matrix. I.e. ----the function creates a copy of the given matrix. ----@param m1 matrix4 existing matrix ----@return matrix4 m matrix which is a copy of the specified matrix -function vmath.matrix4(m1) end - ----The resulting matrix describes a rotation around the axis by the specified angle. ----@param v vector3 axis ----@param angle number angle in radians ----@return matrix4 m matrix represented by axis and angle -function vmath.matrix4_axis_angle(v, angle) end - ----The resulting matrix describes the same rotation as the quaternion, but does not have any translation (also like the quaternion). ----@param q quaternion quaternion to create matrix from ----@return matrix4 m matrix represented by quaternion -function vmath.matrix4_from_quat(q) end - ----Constructs a frustum matrix from the given values. The left, right, ----top and bottom coordinates of the view cone are expressed as distances ----from the center of the near clipping plane. The near and far coordinates ----are expressed as distances from the tip of the view frustum cone. ----@param left number coordinate for left clipping plane ----@param right number coordinate for right clipping plane ----@param bottom number coordinate for bottom clipping plane ----@param top number coordinate for top clipping plane ----@param near number coordinate for near clipping plane ----@param far number coordinate for far clipping plane ----@return matrix4 m matrix representing the frustum -function vmath.matrix4_frustum(left, right, bottom, top, near, far) end - ----The resulting matrix is created from the supplied look-at parameters. ----This is useful for constructing a view matrix for a camera or ----rendering in general. ----@param eye vector3 eye position ----@param look_at vector3 look-at position ----@param up vector3 up vector ----@return matrix4 m look-at matrix -function vmath.matrix4_look_at(eye, look_at, up) end - ----Creates an orthographic projection matrix. ----This is useful to construct a projection matrix for a camera or rendering in general. ----@param left number coordinate for left clipping plane ----@param right number coordinate for right clipping plane ----@param bottom number coordinate for bottom clipping plane ----@param top number coordinate for top clipping plane ----@param near number coordinate for near clipping plane ----@param far number coordinate for far clipping plane ----@return matrix4 m orthographic projection matrix -function vmath.matrix4_orthographic(left, right, bottom, top, near, far) end - ----Creates a perspective projection matrix. ----This is useful to construct a projection matrix for a camera or rendering in general. ----@param fov number angle of the full vertical field of view in radians ----@param aspect number aspect ratio ----@param near number coordinate for near clipping plane ----@param far number coordinate for far clipping plane ----@return matrix4 m perspective projection matrix -function vmath.matrix4_perspective(fov, aspect, near, far) end - ----The resulting matrix describes a rotation around the x-axis ----by the specified angle. ----@param angle number angle in radians around x-axis ----@return matrix4 m matrix from rotation around x-axis -function vmath.matrix4_rotation_x(angle) end - ----The resulting matrix describes a rotation around the y-axis ----by the specified angle. ----@param angle number angle in radians around y-axis ----@return matrix4 m matrix from rotation around y-axis -function vmath.matrix4_rotation_y(angle) end - ----The resulting matrix describes a rotation around the z-axis ----by the specified angle. ----@param angle number angle in radians around z-axis ----@return matrix4 m matrix from rotation around z-axis -function vmath.matrix4_rotation_z(angle) end - ----The resulting matrix describes a translation of a point ----in euclidean space. ----@param position vector3|vector4 position vector to create matrix from ----@return matrix4 m matrix from the supplied position vector -function vmath.matrix4_translation(position) end - ----Performs an element wise multiplication between two vectors of the same type ----The returned value is a vector defined as (e.g. for a vector3): ----v = vmath.mul_per_elem(a, b) = vmath.vector3(a.x * b.x, a.y * b.y, a.z * b.z) ----@param v1 vector3|vector4 first vector ----@param v2 vector3|vector4 second vector ----@return vector3|vector4 v multiplied vector -function vmath.mul_per_elem(v1, v2) end - ----Normalizes a vector, i.e. returns a new vector with the same ----direction as the input vector, but with length 1. ---- The length of the vector must be above 0, otherwise a ----division-by-zero will occur. ----@param v1 vector3|vector4|quaternion vector to normalize ----@return vector3|vector4|quaternion v new normalized vector -function vmath.normalize(v1) end - ----The resulting matrix is the inverse of the supplied matrix. ----The supplied matrix has to be an ortho-normal matrix, e.g. ----describe a regular object transformation. ---- For matrices that are not ortho-normal ----use the general inverse vmath.inv() instead. ----@param m1 matrix4 ortho-normalized matrix to invert ----@return matrix4 m inverse of the supplied matrix -function vmath.ortho_inv(m1) end - ----Calculates the extent the projection of the first vector onto the second. ----The returned value is a scalar p defined as: ----p = |P| cos θ / |Q| ----where θ is the angle between the vectors P and Q. ----@param v1 vector3 vector to be projected on the second ----@param v2 vector3 vector onto which the first will be projected, must not have zero length ----@return number n the projected extent of the first vector onto the second -function vmath.project(v1, v2) end - ----Creates a new identity quaternion. The identity ----quaternion is equal to: ----vmath.quat(0, 0, 0, 1) ----@return quaternion q new identity quaternion -function vmath.quat() end - ----Creates a new quaternion with the components set ----according to the supplied parameter values. ----@param x number x coordinate ----@param y number y coordinate ----@param z number z coordinate ----@param w number w coordinate ----@return quaternion q new quaternion -function vmath.quat(x, y, z, w) end - ----Creates a new quaternion with all components set to the ----corresponding values from the supplied quaternion. I.e. ----This function creates a copy of the given quaternion. ----@param q1 quaternion existing quaternion ----@return quaternion q new quaternion -function vmath.quat(q1) end - ----The resulting quaternion describes a rotation of angle ----radians around the axis described by the unit vector v. ----@param v vector3 axis ----@param angle number angle ----@return quaternion q quaternion representing the axis-angle rotation -function vmath.quat_axis_angle(v, angle) end - ----The resulting quaternion describes the rotation from the ----identity quaternion (no rotation) to the coordinate system ----as described by the given x, y and z base unit vectors. ----@param x vector3 x base vector ----@param y vector3 y base vector ----@param z vector3 z base vector ----@return quaternion q quaternion representing the rotation of the specified base vectors -function vmath.quat_basis(x, y, z) end - ----The resulting quaternion describes the rotation that, ----if applied to the first vector, would rotate the first ----vector to the second. The two vectors must be unit ----vectors (of length 1). ---- The result is undefined if the two vectors point in opposite directions ----@param v1 vector3 first unit vector, before rotation ----@param v2 vector3 second unit vector, after rotation ----@return quaternion q quaternion representing the rotation from first to second vector -function vmath.quat_from_to(v1, v2) end - ----The resulting quaternion describes a rotation of angle ----radians around the x-axis. ----@param angle number angle in radians around x-axis ----@return quaternion q quaternion representing the rotation around the x-axis -function vmath.quat_rotation_x(angle) end - ----The resulting quaternion describes a rotation of angle ----radians around the y-axis. ----@param angle number angle in radians around y-axis ----@return quaternion q quaternion representing the rotation around the y-axis -function vmath.quat_rotation_y(angle) end - ----The resulting quaternion describes a rotation of angle ----radians around the z-axis. ----@param angle number angle in radians around z-axis ----@return quaternion q quaternion representing the rotation around the z-axis -function vmath.quat_rotation_z(angle) end - ----Returns a new vector from the supplied vector that is ----rotated by the rotation described by the supplied ----quaternion. ----@param q quaternion quaternion ----@param v1 vector3 vector to rotate ----@return vector3 v the rotated vector -function vmath.rotate(q, v1) end - ----Slerp travels the torque-minimal path maintaining constant ----velocity, which means it travels along the straightest path along ----the rounded surface of a sphere. Slerp is useful for interpolation ----of rotations. ----Slerp travels the torque-minimal path, which means it travels ----along the straightest path the rounded surface of a sphere. ---- The function does not clamp t between 0 and 1. ----@param t number interpolation parameter, 0-1 ----@param q1 quaternion quaternion to slerp from ----@param q2 quaternion quaternion to slerp to ----@return quaternion q the slerped quaternion -function vmath.slerp(t, q1, q2) end - ----Spherically interpolates between two vectors. The difference to ----lerp is that slerp treats the vectors as directions instead of ----positions in space. ----The direction of the returned vector is interpolated by the angle ----and the magnitude is interpolated between the magnitudes of the ----from and to vectors. ---- Slerp is computationally more expensive than lerp. ----The function does not clamp t between 0 and 1. ----@param t number interpolation parameter, 0-1 ----@param v1 vector3|vector4 vector to slerp from ----@param v2 vector3|vector4 vector to slerp to ----@return vector3|vector4 v the slerped vector -function vmath.slerp(t, v1, v2) end - ----Creates a vector of arbitrary size. The vector is initialized ----with numeric values from a table. ---- The table values are converted to floating point ----values. If a value cannot be converted, a 0 is stored in that ----value position in the vector. ----@param t table table of numbers ----@return vector4|vector3 v new vector -function vmath.vector(t) end - ----Creates a new vector with all components set to the ----corresponding values from the supplied vector. I.e. ----This function creates a copy of the given vector. ----@param v1 vector3 existing vector ----@return vector3 v new vector -function vmath.vector3(v1) end - ----Creates a new vector with the components set to the ----supplied values. ----@param x number x coordinate ----@param y number y coordinate ----@param z number z coordinate ----@return vector3 v new vector -function vmath.vector3(x, y, z) end - ----Creates a new zero vector with all components set to 0. ----@return vector3 v new zero vector -function vmath.vector3() end - ----Creates a new vector with all components set to the ----supplied scalar value. ----@param n number scalar value to splat ----@return vector3 v new vector -function vmath.vector3(n) end - ----Creates a new vector with the components set to the ----supplied values. ----@param x number x coordinate ----@param y number y coordinate ----@param z number z coordinate ----@param w number w coordinate ----@return vector4 v new vector -function vmath.vector4(x, y, z, w) end - ----Creates a new vector with all components set to the ----supplied scalar value. ----@param n number scalar value to splat ----@return vector4 v new vector -function vmath.vector4(n) end - ----Creates a new zero vector with all components set to 0. ----@return vector4 v new zero vector -function vmath.vector4() end - ----Creates a new vector with all components set to the ----corresponding values from the supplied vector. I.e. ----This function creates a copy of the given vector. ----@param v1 vector4 existing vector ----@return vector4 v new vector -function vmath.vector4(v1) end - -return vmath \ No newline at end of file diff --git a/annotations/defold_annotations/window.lua b/annotations/defold_annotations/window.lua deleted file mode 100644 index c2d9109..0000000 --- a/annotations/defold_annotations/window.lua +++ /dev/null @@ -1,110 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Window API documentation - - Functions and constants to access the window, window event listeners - and screen dimming. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.window -window = {} - ----Dimming mode is used to control whether or not a mobile device should dim the screen after a period without user interaction. -window.DIMMING_OFF = nil - ----Dimming mode is used to control whether or not a mobile device should dim the screen after a period without user interaction. -window.DIMMING_ON = nil - ----Dimming mode is used to control whether or not a mobile device should dim the screen after a period without user interaction. ----This mode indicates that the dim mode can't be determined, or that the platform doesn't support dimming. -window.DIMMING_UNKNOWN = nil - ---- This event is sent to a window event listener when the game window or app screen is ----restored after being iconified. -window.WINDOW_EVENT_DEICONIFIED = nil - ----This event is sent to a window event listener when the game window or app screen has ----gained focus. ----This event is also sent at game startup and the engine gives focus to the game. -window.WINDOW_EVENT_FOCUS_GAINED = nil - ----This event is sent to a window event listener when the game window or app screen has lost focus. -window.WINDOW_EVENT_FOCUS_LOST = nil - ---- This event is sent to a window event listener when the game window or app screen is ----iconified (reduced to an application icon in a toolbar, application tray or similar). -window.WINDOW_EVENT_ICONFIED = nil - ----This event is sent to a window event listener when the game window or app screen is resized. ----The new size is passed along in the data field to the event listener. -window.WINDOW_EVENT_RESIZED = nil - ---- Returns the current dimming mode set on a mobile device. ----The dimming mode specifies whether or not a mobile device should dim the screen after a period without user interaction. ----On platforms that does not support dimming, window.DIMMING_UNKNOWN is always returned. ----@return constant mode The mode for screen dimming ---- ----window.DIMMING_UNKNOWN ----window.DIMMING_ON ----window.DIMMING_OFF ---- -function window.get_dim_mode() end - ----This returns the current lock state of the mouse cursor ----@return boolean state The lock state -function window.get_mouse_lock() end - ----This returns the current window size (width and height). ----@return number width The window width ----@return number height The window height -function window.get_size() end - ---- Sets the dimming mode on a mobile device. ----The dimming mode specifies whether or not a mobile device should dim the screen after a period without user interaction. The dimming mode will only affect the mobile device while the game is in focus on the device, but not when the game is running in the background. ----This function has no effect on platforms that does not support dimming. ----@param mode constant The mode for screen dimming ---- ----window.DIMMING_ON ----window.DIMMING_OFF ---- -function window.set_dim_mode(mode) end - ----Sets a window event listener. ----@param callback fun(self, event, data)|nil A callback which receives info about window events. Pass an empty function or nil if you no longer wish to receive callbacks. ---- ----self ----object The calling script ----event ----constant The type of event. Can be one of these: ---- ---- ----window.WINDOW_EVENT_FOCUS_LOST ----window.WINDOW_EVENT_FOCUS_GAINED ----window.WINDOW_EVENT_RESIZED ----window.WINDOW_EVENT_ICONIFIED ----window.WINDOW_EVENT_DEICONIFIED ---- ---- ----data ----table The callback value data is a table which currently holds these values ---- ---- ----number width: The width of a resize event. nil otherwise. ----number height: The height of a resize event. nil otherwise. ---- -function window.set_listener(callback) end - ----Set the locking state for current mouse cursor on a PC platform. ----This function locks or unlocks the mouse cursor to the center point of the window. While the cursor is locked, ----mouse position updates will still be sent to the scripts as usual. ----@param flag boolean The lock state for the mouse cursor -function window.set_mouse_lock(flag) end - -return window \ No newline at end of file diff --git a/annotations/defold_annotations/zlib.lua b/annotations/defold_annotations/zlib.lua deleted file mode 100644 index 5d297aa..0000000 --- a/annotations/defold_annotations/zlib.lua +++ /dev/null @@ -1,28 +0,0 @@ ---[[ - Generated with github.com/astrochili/defold-annotations - Defold 1.8.1 - - Zlib compression API documentation - - Functions for compression and decompression of string buffers. ---]] - ----@diagnostic disable: lowercase-global ----@diagnostic disable: missing-return ----@diagnostic disable: duplicate-doc-param ----@diagnostic disable: duplicate-set-field - ----@class defold_api.zlib -zlib = {} - ----A lua error is raised is on error ----@param buf string buffer to deflate ----@return string buf deflated buffer -function zlib.deflate(buf) end - ----A lua error is raised is on error ----@param buf string buffer to inflate ----@return string buf inflated buffer -function zlib.inflate(buf) end - -return zlib \ No newline at end of file