Contains data used to animate everything in the engine.
</brief_description>
<description>
An Animation resource contains data used to animate everything in the engine. Animations are divided into tracks, and each track must be linked to a node. The state of that node can be changed through time, by adding timed keys (signals) to the track. [html br/] Animations are just data containers, and must be added to odes such as an [AnimationPlayer] or [AnimationTreePlayer] to be played back.
</description>
<methods>
<methodname="add_track">
<argumentindex="0"name="type"type="int">
</argument>
<argumentindex="1"name="arg1"type="int">
</argument>
<description>
Add a track to the Animation. The track type must be specified as any of the values in te TYPE_* enumeration.
</description>
</method>
<methodname="remove_track">
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Remove a track by specifying the track index.
</description>
</method>
<methodname="get_track_count"qualifiers="const">
<returntype="int">
</return>
<description>
Return the amount of tracks in the animation.
</description>
</method>
<methodname="track_get_type"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Get the type of a track.
</description>
</method>
<methodname="track_get_path"qualifiers="const">
<returntype="NodePath">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Get the path of a track. for more information on the path format, see [method track_set_path]
</description>
</method>
<methodname="track_set_path">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="path"type="NodePath">
</argument>
<description>
Set the path of a track. Paths must be valid scene-tree paths to a node, and must be specified starting from the parent node of the node that will reproduce the animation. Tracks that control properties or bones must append their name after the path, separated by ":". Example: "character/skeleton:ankle" or "character/mesh:transform/local:"
Set the total length of the animation (in seconds). Note that length is not delimited by the last key, as this one may be before or after the end to ensure correct interpolation and looping.
</description>
</method>
<methodname="get_length"qualifiers="const">
<returntype="real">
</return>
<description>
Return the total length of the animation (in seconds).
</description>
</method>
<methodname="set_loop">
<argumentindex="0"name="enabled"type="bool">
</argument>
<description>
Set a flag indicating that the animation must loop. This is uses for correct interpolation of animation cycles, and for hinting the player that it must restart the animation once it's over.
</description>
</method>
<methodname="has_loop"qualifiers="const">
<returntype="bool">
</return>
<description>
Return wether the animation has the loop flag set.
</description>
</method>
</methods>
<constants>
<constantname="INTERPOLATION_CUBIC"value="2">
</constant>
<constantname="TYPE_TRANSFORM"value="0">
Transform tracks are used to change node local transforms or skeleton pose bones. Transitions are Interpolated.
</constant>
<constantname="TYPE_BLEND"value="4">
</constant>
<constantname="TYPE_PROPERTY"value="2">
TODO will be changed and bleh
</constant>
<constantname="TYPE_VALUE"value="1">
Value tracks set values in node properties, but only those which can be Interpolated.
An animation player is used for general purpose playback of [Animation] resources. It contains a dictionary of animations (referenced by name) and custom blend times between their transitions. Additionally, animations can be played and blended in diferent channels.
Return the playback position (in seconds) in an animation channel (or channel 0 if none is provided)
</description>
</method>
<methodname="find_animation"qualifiers="const">
<returntype="String">
</return>
<argumentindex="0"name="animation"type="Object">
</argument>
<description>
</description>
</method>
<methodname="clear_caches">
<description>
The animation player creates caches for faster access to the nodes it will animate. However, if a specific node is removed, it may not notice it, so clear_caches will force the player to search for the nodes again.
Provides a base class for different kinds of buttons.
</brief_description>
<description>
BaseButton is the abstract base class for buttons, so it shouldn't be used directly (It doesnt display anything). Other types of buttons inherit from it.
</description>
<methods>
<methodname="set_pressed">
<argumentindex="0"name="pressed"type="bool">
</argument>
<description>
Set the button to pressed state (only if toggle_mode is active).
</description>
</method>
<methodname="is_pressed"qualifiers="const">
<returntype="bool">
</return>
<description>
Return when the button is pressed (only if toggle_mode is active).
</description>
</method>
<methodname="set_toggle_mode">
<argumentindex="0"name="enabled"type="bool">
</argument>
<description>
Set the button toggle_mode property. Toggle mode makes the button flip state between pressed and unpressed each time its area is clicked.
</description>
</method>
<methodname="is_toggle_mode"qualifiers="const">
<returntype="bool">
</return>
<description>
Return the toggle_mode property (see [method set_toggle_mode]).
</description>
</method>
<methodname="set_disabled">
<argumentindex="0"name="disabled"type="bool">
</argument>
<description>
Set the button into disabled state. When a button is disabled, it can't be clicked or toggled.
</description>
</method>
<methodname="is_disabled"qualifiers="const">
<returntype="bool">
</return>
<description>
Return wether the button is in disabled state (see [method set_disabled]).
</description>
</method>
<methodname="set_click_on_press">
<argumentindex="0"name="enable"type="bool">
</argument>
<description>
Set the button click_on_press mode. This mode generates click signals when a mousebutton or key is just pressed (by default signals are generated when the button/keys are released and both press and release occur in the visual area of the Button).
Return the state of the click_on_press property (see [method set_click_on_press]).
</description>
</method>
</methods>
<signals>
<signalname="toggled">
<argumentindex="0"name="pressed"type="bool">
</argument>
<description>
This signal is emitted when the button was just toggled between pressed and normal states (only if toggle_mode is active). The new state is contained in the [html i]pressed[html /i] argument.
</description>
</signal>
<signalname="pressed">
<description>
This signal is emitted every time the button is pressed or toggled.
Button is just the standard themed button: [html image src="images/button_example.png"/] It can contain a text and an icon, and will display them according to the current theme.
</description>
<methods>
<methodname="set_text">
<argumentindex="0"name="text"type="String">
</argument>
<description>
Set the button text, which will be displayed inside the button area.
</description>
</method>
<methodname="get_text"qualifiers="const">
<returntype="String">
</return>
<description>
Return the button text.
</description>
</method>
<methodname="set_icon">
<argumentindex="0"name="texture"type="Object">
</argument>
<description>
Set the button icon, which will be displayed to the left of the text.
</description>
</method>
<methodname="get_icon"qualifiers="const">
<returntype="Object">
</return>
<description>
Return the button icon.
</description>
</method>
<methodname="set_flat">
<argumentindex="0"name="enabled"type="bool">
</argument>
<description>
Set the [html i]flat[html /i] property of a Button. Flat buttons don't display decoration unless hoevered or pressed.
</description>
</method>
<methodname="set_clip_text">
<argumentindex="0"name="enabled"type="bool">
</argument>
<description>
Set the [html i]clip_text[html /i] property of a Button. When this property is enabled, text that is too large to fit the button is clipped, when disabled (default) the Button will always be wide enough to hold the text.
</description>
</method>
<methodname="get_clip_text"qualifiers="const">
<returntype="bool">
</return>
<description>
Return the state of the [html i]clip_text[html /i] property (see [method set_clip_text])
</description>
</method>
<methodname="is_flat"qualifiers="const">
<returntype="bool">
</return>
<description>
Return the state of the [html i]flat[html /i] property (see [method set_flat])
Camera is a special node that displays what is visible from its current location. Cameras register themselves in the nearest [Viewport] node (when ascending the tree). Only one camera can be active per viewport. If no viewport is available ascending the tree, the Camera will register in the global viewport. In other words, a Camera just provides [html i]3D[html /i] display capabilities to a [Viewport], and, without one, a [Scene] registered in that [Viewport] (or higher viewports) can't be displayed.
Return a normal vector in worldspace, that is the result of projecting a point on the [Viewport] rectangle by the camera proyection. This is useful for casting rays in the form of (origin,normal) for object intersection or picking.
Return a 3D position in worldspace, that is the result of projecting a point on the [Viewport] rectangle by the camera proyection. This is useful for casting rays in the form of (origin,normal) for object intersection or picking.
Return how a 3D point in worldpsace maps to a 2D coordinate in the [Viewport] rectangle.
</description>
</method>
<methodname="set_perspective">
<argumentindex="0"name="fov"type="real">
</argument>
<argumentindex="1"name="z_near"type="real">
</argument>
<argumentindex="2"name="z_far"type="real">
</argument>
<description>
Set the camera projection to perspective mode, by specifying a [html i]FOV[html /i] angle in degrees (FOV means Field of View), and the [html i]near[html /i] and [html i]far[html /i] clip planes in worldspace units.
</description>
</method>
<methodname="set_orthogonal">
<argumentindex="0"name="size"type="real">
</argument>
<argumentindex="1"name="z_near"type="real">
</argument>
<argumentindex="2"name="z_far"type="real">
</argument>
<description>
Set the camera projection to orthogonal mode, by specifying a rectangle and the [html i]near[html /i] and [html i]far[html /i] clip planes in worldspace units. (As a hint, 2D games often use this projection, with values specified in pixels)
</description>
</method>
<methodname="make_current">
<description>
Make this camera the current Camera for the [Viewport] (see class description). If the Camera Node is outside the scene tree, it will attempt to become current once it's added.
</description>
</method>
<methodname="clear_current">
<description>
</description>
</method>
<methodname="is_current"qualifiers="const">
<returntype="bool">
</return>
<description>
Return wether the Camera is the current one in the [Viewport], or plans to become current (if outside the scene tree).
Control is the base class Node for all the GUI components.
</brief_description>
<description>
Control is the base class Node for all the GUI components. Every GUI component inherits from it, directly or indirectly. Control Nodes contain positions relative to their parent control nodes. In this way, sections of the scene tree made of contiguous Control Nodes, become user interfaces.[html br/] 	Controls contain a [html i]canvas item[html /i] RID from the visual server, and can draw to it when receiving a NOTIFICATION_DRAW.[html br/] 	TODO: Explain margins and anchors[html br/] 	TODO: explain focus[html br/]
</description>
<methods>
<methodname="accept_event">
<description>
</description>
</method>
<methodname="get_minimum_size"qualifiers="const">
<returntype="Vector2">
</return>
<description>
Return the minimum size this Control can shrink to. A control will never be displayed or resized smaller than its minimum size.
</description>
</method>
<methodname="is_window"qualifiers="const">
<returntype="bool">
</return>
<description>
Return wether this control is a [html i]window[html /i]. Controls are considered windows when their parent [Node] is not a Control.
</description>
</method>
<methodname="get_window"qualifiers="const">
<returntype="Object">
</return>
<description>
Return the [html i]window[html /i] for this control, ascending the scene tree (see [method is_window]).
</description>
</method>
<methodname="set_anchor">
<argumentindex="0"name="margin"type="int">
</argument>
<argumentindex="1"name="anchor_mode"type="int">
</argument>
<description>
Change the anchor (ANCHOR_BEGIN, ANCHOR_END, ANCHOR_RATIO) type for a margin (MARGIN_LEFT, MARGIN_TOP, MARGIN_RIGHT, MARGIN_BOTTOM). Changing the anchor mode converts the current margin offset from the previos anchor mode to the new one, so margin offsets ([method set_margin]) must be done after setting anchors, or at the same time ([method set_anchor_and_margin]).
</description>
</method>
<methodname="get_anchor"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="margin"type="int">
</argument>
<description>
Return the anchor type (ANCHOR_BEGIN, ANCHOR_END, ANCHOR_RATIO) for a given margin (MARGIN_LEFT, MARGIN_TOP, MARGIN_RIGHT, MARGIN_BOTTOM).
</description>
</method>
<methodname="set_margin">
<argumentindex="0"name="margin"type="int">
</argument>
<argumentindex="1"name="offset"type="real">
</argument>
<description>
Set a margin offset. Margin can be one of (MARGIN_LEFT, MARGIN_TOP, MARGIN_RIGHT, MARGIN_BOTTOM). Offset value being set depends on the anchor mode.
</description>
</method>
<methodname="set_anchor_and_margin">
<argumentindex="0"name="margin"type="int">
</argument>
<argumentindex="1"name="anchor_mode"type="int">
</argument>
<argumentindex="2"name="offset"type="real">
</argument>
<description>
Change the anchor (ANCHOR_BEGIN, ANCHOR_END, ANCHOR_RATIO) type for a margin (MARGIN_LEFT, MARGIN_TOP, MARGIN_RIGHT, MARGIN_BOTTOM), and also set its offset. This is a helper (see [method set_anchor] and [method set_margin]).
</description>
</method>
<methodname="set_begin">
<argumentindex="0"name="pos"type="Vector2">
</argument>
<description>
Sets MARGIN_LEFT and MARGIN_TOP at the same time. This is a helper (see [method set_margin]).
</description>
</method>
<methodname="set_end">
<argumentindex="0"name="pos"type="Vector2">
</argument>
<description>
Sets MARGIN_RIGHT and MARGIN_BOTTOM at the same time. This is a helper (see [method set_margin]).
</description>
</method>
<methodname="set_pos">
<argumentindex="0"name="pos"type="Vector2">
</argument>
<description>
Move the Control to a new position, relative to the top-left corner of the parent Control, changing all margins if needed and without changing current anchor mode. This is a helper (see [method set_margin]).
</description>
</method>
<methodname="set_size">
<argumentindex="0"name="size"type="Vector2">
</argument>
<description>
Changes MARGIN_RIGHT and MARGIN_BOTTOM to fit a given size. This is a helper (see [method set_margin]).
</description>
</method>
<methodname="set_global_pos">
<argumentindex="0"name="pos"type="Vector2">
</argument>
<description>
Move the Control to a new position, relative to the top-left corner of the [html i]window[html /i] Control, and without changing current anchor mode. (see [method set_margin]).
</description>
</method>
<methodname="get_margin"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="margin"type="int">
</argument>
<description>
Return a margin offset. Margin can be one of (MARGIN_LEFT, MARGIN_TOP, MARGIN_RIGHT, MARGIN_BOTTOM). Offset value being returned depends on the anchor mode.
</description>
</method>
<methodname="get_begin"qualifiers="const">
<returntype="Vector2">
</return>
<description>
</description>
</method>
<methodname="get_end"qualifiers="const">
<returntype="Vector2">
</return>
<description>
Returns MARGIN_LEFT and MARGIN_TOP at the same time. This is a helper (see [method set_margin]).
</description>
</method>
<methodname="get_pos"qualifiers="const">
<returntype="Vector2">
</return>
<description>
Returns the Control position, relative to the top-left corner of the parent Control and independly of the anchor mode.
</description>
</method>
<methodname="get_size"qualifiers="const">
<returntype="Vector2">
</return>
<description>
Returns the size of the Control, computed from all margins, however the size returned will [html b]never be smaller than the minimum size reported by [method get_minimum_size][html /b]. This means that even if end position of the Control rectangle is smaller than the begin position, the Control will still display and interact correctly. (see description, [method get_minimum_size], [method set_margin], [method set_anchor]).
</description>
</method>
<methodname="get_global_pos"qualifiers="const">
<returntype="Vector2">
</return>
<description>
Returns the Control position, relative to the top-left corner of the parent Control and independent of the anchor mode.
</description>
</method>
<methodname="get_rect"qualifiers="const">
<returntype="Rect2">
</return>
<description>
Return position and size of the Control, relative to the top-left corner of the parent Control. This is a helper (see [method get_pos],[method get_size]).
</description>
</method>
<methodname="get_global_rect"qualifiers="const">
<returntype="Rect2">
</return>
<description>
Return position and size of the Control, relative to the top-left corner of the [html i]window[html /i] Control. This is a helper (see [method get_global_pos],[method get_size]).
</description>
</method>
<methodname="set_area_as_parent_rect">
<description>
Change all margins and anchors, so this Control always takes up the same area as the parent Control. This is a helper (see [method set_anchor],[method set_margin]).
Display a Control as modal. Control must be a subwindow (see [method set_as_subwindow]). Modal controls capture the input signals until closed or the area outside them is accessed. When a modal control loses focus, or the ESC key is pressed, they automatically hide. Modal controls are used extensively for popup dialogs and menus.
</description>
</method>
<methodname="set_focus_mode">
<argumentindex="0"name="mode"type="int">
</argument>
<description>
Set the focus access mode for the control (FOCUS_NONE, FOCUS_CLICK, FOCUS_ALL). Only one Control can be focused at the same time, and it will receive keyboard signals.
</description>
</method>
<methodname="has_focus"qualifiers="const">
<returntype="bool">
</return>
<description>
Return wether the Control is the current focused control (see [method set_focus_mode]).
</description>
</method>
<methodname="grab_focus">
<description>
Steal the focus from another control and become the focused control (see [method set_focus_mode]).
</description>
</method>
<methodname="set_theme">
<argumentindex="0"name="theme"type="Object">
</argument>
<description>
Override whole the [Theme] for this Control and all its children controls.
</description>
</method>
<methodname="get_theme"qualifiers="const">
<returntype="Object">
</return>
<description>
Return a [Theme] override, if one exists (see [method set_theme]).
</description>
</method>
<methodname="add_icon_override">
<argumentindex="0"name="name"type="String">
</argument>
<argumentindex="1"name="texture"type="Object">
</argument>
<description>
Override a single icon ([Texture]) in the theme of this Control. If texture is empty, override is cleared.
</description>
</method>
<methodname="add_style_override">
<argumentindex="0"name="name"type="String">
</argument>
<argumentindex="1"name="stylebox"type="Object">
</argument>
<description>
Override a single stylebox ([Stylebox]) in the theme of this Control. If stylebox is empty, override is cleared.
</description>
</method>
<methodname="add_font_override">
<argumentindex="0"name="name"type="String">
</argument>
<argumentindex="1"name="font"type="Object">
</argument>
<description>
Override a single font (font) in the theme of this Control. If font is empty, override is cleared.
</description>
</method>
<methodname="add_color_override">
<argumentindex="0"name="name"type="String">
</argument>
<argumentindex="1"name="color"type="Color">
</argument>
<description>
</description>
</method>
<methodname="add_constant_override">
<argumentindex="0"name="name"type="String">
</argument>
<argumentindex="1"name="constant"type="int">
</argument>
<description>
Override a single constant (integer) in the theme of this Control. If constant equals Theme.INVALID_CONSTANT, override is cleared.
GridMap is a 3D Tile map, using [html i]3D Cells[html /i] instead of tiles. On each cell, a mesh and a collision volume can be placed from a [MeshLibrary]. GridMap is used for designing worlds quickly. Despite that GridMaps can contain up to hundreds millions of cells, they are very optimized, and only use resources for the cells that contain items.
</description>
<methods>
<methodname="set_theme">
<argumentindex="0"name="theme"type="Object">
</argument>
<description>
Set a MeshLibrary. Cell indices refer to items in the theme.
</description>
</method>
<methodname="get_theme"qualifiers="const">
<returntype="Object">
</return>
<description>
Get the current MeshLibrary (if exists).
</description>
</method>
<methodname="set_cell_size">
<argumentindex="0"name="size"type="real">
</argument>
<description>
Set the size of a cell, in worldpsace units. All cells in a GridMap are the same size.
</description>
</method>
<methodname="get_cell_size"qualifiers="const">
<returntype="real">
</return>
<description>
Return the current cell size.
</description>
</method>
<methodname="set_octant_size">
<argumentindex="0"name="size"type="int">
</argument>
<description>
</description>
</method>
<methodname="get_octant_size"qualifiers="const">
<returntype="int">
</return>
<description>
</description>
</method>
<methodname="set_width">
<argumentindex="0"name="width"type="int">
</argument>
<description>
Set the width of the GridMap. Width is the amount of cells i the direction of the X coordinate.
</description>
</method>
<methodname="get_width"qualifiers="const">
<returntype="int">
</return>
<description>
Get the width of the GridMap. Width is the amount of cells i the direction of the X coordinate.
</description>
</method>
<methodname="set_height">
<argumentindex="0"name="height"type="int">
</argument>
<description>
Set the height of the GridMap. Height is the amount of cells i the direction of the Y coordinate.
</description>
</method>
<methodname="get_height"qualifiers="const">
<returntype="int">
</return>
<description>
Get the height of the GridMap. Height is the amount of cells i the direction of the Y coordinate.
</description>
</method>
<methodname="set_depth">
<argumentindex="0"name="depth"type="int">
</argument>
<description>
Set the depth of the GridMap. Depth is the amount of cells i the direction of the Z coordinate.
</description>
</method>
<methodname="get_depth"qualifiers="const">
<returntype="int">
</return>
<description>
Get the depth of the GridMap. Depth is the amount of cells i the direction of the Z coordinate.
A DirectionalLight is a type of [Light] node that emits light constantly in one direction (the negative z axis of the node). It is used lights with strong intensity that are located far away from the scene to model sunlight or moonlight. The worldpace location of the DirectionalLight transform (origin) is ignored, only the basis is used do determine light direction.
FixedMaterial is a simple type of material [Resource], which contains a fixed amount of paramters. It is the only type of material supported in fixed-pipeline devices and APIs. It is also an often a better alternative to [ShaderMaterial] for most simple use cases.
</description>
<methods>
<methodname="set_shader">
<argumentindex="0"name="shader"type="Object">
</argument>
<description>
</description>
</method>
<methodname="get_shader"qualifiers="const">
<returntype="Object">
</return>
<description>
</description>
</method>
<methodname="set_parameter">
<argumentindex="0"name="param"type="int">
</argument>
<argumentindex="1"name="value"type="var">
</argument>
<description>
Set a parameter, parameters are defined in the PARAM_* enum. The type of each parameter may change, so it's best to check the enum.
</description>
</method>
<methodname="get_parameter"qualifiers="const">
<argumentindex="0"name="param"type="int">
</argument>
<description>
Return a parameter, parameters are defined in the PARAM_* enum. The type of each parameter may change, so it's best to check the enum.
</description>
</method>
<methodname="set_texture">
<argumentindex="0"name="param"type="int">
</argument>
<argumentindex="1"name="texture"type="Object">
</argument>
<description>
Set a texture. Textures change parameters per texel and are mapped to the model depending on the texcoord mode (see [method set_texcoord_mode]).
</description>
</method>
<methodname="get_texture"qualifiers="const">
<returntype="Object">
</return>
<argumentindex="0"name="param"type="int">
</argument>
<description>
Return a texture. Textures change parameters per texel and are mapped to the model depending on the texcoord mode (see [method set_texcoord_mode]).
</description>
</method>
<methodname="set_texgen_mode">
<argumentindex="0"name="mode"type="int">
</argument>
<description>
Set the texture coordinate generation mode. Materials have a unique, texgen mode which can generate texture coordinates on the fly. Texgen mode must be one of the values from the TEXGEN_* enum. TEXGEN can be selected as a texture coordinate mode (see [method set_texcoord_mode]).
</description>
</method>
<methodname="get_texgen_mode"qualifiers="const">
<returntype="int">
</return>
<description>
Return the texture coordinate generation mode. Materials have a unique, texgen mode which can generate texture coordinates on the fly. Texgen mode must be one of the values from the TEXGEN_* enum. TEXGEN can be selected as a texture coordinate mode (see [method set_texcoord_mode]).
</description>
</method>
<methodname="set_texcoord_mode">
<argumentindex="0"name="param"type="int">
</argument>
<argumentindex="1"name="mode"type="int">
</argument>
<description>
Set the texture coordinate mode. Each texture param (from the PARAM_* enum) has one. It defines how the textures are mapped to the object.
Font contains an unicode compatible character set, as well as the ability to draw it with variable width, ascent, descent and kerning. For creating fonts from TTF files (or other font formats), see the editor support for fonts. TODO check wikipedia for graph of ascent/baseline/descent/height/etc.
</description>
<methods>
<methodname="set_height">
<argumentindex="0"name="px"type="real">
</argument>
<description>
Set the total font height (ascent plus descent) in pixels.
</description>
</method>
<methodname="get_height"qualifiers="const">
<returntype="real">
</return>
<description>
Return the total font height (ascent plus descent) in pixels.
</description>
</method>
<methodname="set_ascent">
<argumentindex="0"name="px"type="real">
</argument>
<description>
Set the font ascent (number of pixels above the baseline).
</description>
</method>
<methodname="get_ascent"qualifiers="const">
<returntype="real">
</return>
<description>
Return the font ascent (number of pixels above the baseline).
</description>
</method>
<methodname="get_descent"qualifiers="const">
<returntype="real">
</return>
<description>
Return the font descent (number of pixels below the baseline).
</description>
</method>
<methodname="add_kerning_pair">
<argumentindex="0"name="char_a"type="int">
</argument>
<argumentindex="1"name="char_b"type="int">
</argument>
<argumentindex="2"name="kerning"type="int">
</argument>
<description>
Add a kerning pair to the [Font] as a difference. Kerning pairs are special cases where a typeface advance is determined by the next character.
</description>
</method>
<methodname="get_kerning_pair"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="arg0"type="int">
</argument>
<argumentindex="1"name="arg1"type="int">
</argument>
<description>
Return a kerning pair as a difference. Kerning pairs are special cases where a typeface advance is determined by the next character.
Add a character to the font, where "character" is the unicode value, "texture" is the texture index, "rect" is the region in the texture (in pixels!), "align" is the (optional) alignment for the character and "advance" is the (optional) advance.
Draw "string" into a canvas item using the font at a given "pos" position, with "modulate" color, and optionally clipping the width. "pos" specifies te baseline, not the top. To draw from the top, [html i]ascent[html /i] must be added to the Y axis.
Draw character "char" into a canvas item using the font at a given "pos" position, with "modulate" color, and optionally kerning if "next" is apassed. clipping the width. "pos" specifies te baseline, not the top. To draw from the top, [html i]ascent[html /i] must be added to the Y axis. The width used by the character is returned, making this function useful for drawing strings character by character.
Contains global variables accessible from everywhere.
</brief_description>
<description>
Contains global variables accessible from everywhere. Use the normal [Object] API, such as "Globals.get(variable)", "Globals.set(variable,value)" or "Globals.has(variable)" to access them. Variables stored in engine.cfg are also loaded into globals, making this object very useful for reading custom game configuration options.
IP contains some support functions for the IPv4 protocol. TCP/IP support is in different classes (see [TCP_Client], [TCP_Server]). IP provides hostname resolution support, both blocking and threaded.
</description>
<methods>
<methodname="resolve_hostname">
<returntype="String">
</return>
<argumentindex="0"name="host"type="String">
</argument>
<description>
Resolve a given hostname, blocking. Resolved hostname is returned as an IP.
</description>
</method>
<methodname="resolve_hostname_queue_item">
<returntype="int">
</return>
<argumentindex="0"name="host"type="String">
</argument>
<description>
Create a queue item for resolving a given hostname. The queue ID is returned, or RESOLVER_INVALID_ID on error.
Label is a control that displays formatted text, optionally autowrapping it to the [Control] area. It inherits from range to be able to scroll wrapped text vertically.
</description>
<methods>
<methodname="set_align">
<argumentindex="0"name="align"type="int">
</argument>
<description>
Set the alignmend mode to any of the ALIGN_* enumeration values.
</description>
</method>
<methodname="get_align"qualifiers="const">
<returntype="int">
</return>
<description>
Return the alignmend mode (any of the ALIGN_* enumeration values).
</description>
</method>
<methodname="set_text">
<argumentindex="0"name="text"type="String">
</argument>
<description>
Set the label text. Text can contain newlines.
</description>
</method>
<methodname="get_text"qualifiers="const">
<returntype="String">
</return>
<description>
Return the label text. Text can contain newlines.
</description>
</method>
<methodname="set_autowrap">
<argumentindex="0"name="enable"type="bool">
</argument>
<description>
Set [html i]autowrap[html /i] mode. When enabled, autowrap will fit text to the control width, breaking sentences when they exceed the available horizontal space. When disabled, the label minimum width becomes the width of the longest row, and the minimum height large enough to fit all rows.
</description>
</method>
<methodname="has_autowrap"qualifiers="const">
<returntype="bool">
</return>
<description>
Return the state of the [html i]autowrap[html /i] mode (see [method set_autowrap]).
Provides a base class for different kinds of light nodes.
</brief_description>
<description>
Light is the abstract base class for light nodes, so it shouldn't be used directly (It can't be instanced). Other types of light nodes inherit from it. Light contains the common variables and parameters used for lighting.
Main loop is the abstract main loop base class. All other main loop classes are derived from it. Upon application start, a [MainLoop] has to be provided to OS, else the application will exit. This happens automatically (and a [SceneMainLoop] is created), unless a main [Script] is supplied, which may or not create and return a [MainLoop].
Abstract base [Resource] for coloring and shading geometry.
</brief_description>
<description>
Material is a base [Resource] used for coloring and shading geometry. All materials inherit from it and almost all [VisualInstance] derived nodes carry a Material. A few flags and parameters are shared between all material types and are configured here.
</description>
<methods>
<methodname="set_flag">
<argumentindex="0"name="flag"type="int">
</argument>
<argumentindex="1"name="enable"type="bool">
</argument>
<description>
Set a [Material] flag, which toggles on or off a behavior when rendering. See enumeration FLAG_* for a list.
</description>
</method>
<methodname="get_flag"qualifiers="const">
<returntype="bool">
</return>
<argumentindex="0"name="flag"type="int">
</argument>
<description>
Return a [Material] flag, which toggles on or off a behavior when rendering. See enumeration FLAG_* for a list.
</description>
</method>
<methodname="set_hint">
<argumentindex="0"name="hint"type="int">
</argument>
<argumentindex="1"name="enable"type="bool">
</argument>
<description>
</description>
</method>
<methodname="get_hint"qualifiers="const">
<returntype="bool">
</return>
<argumentindex="0"name="hint"type="int">
</argument>
<description>
</description>
</method>
<methodname="set_blend_mode">
<argumentindex="0"name="mode"type="int">
</argument>
<description>
Set blend mode for the material, which can be one of BLEND_MODE_MIX (default), BLEND_MODE_ADD, BLEND_MODE_SUB. Keep in mind that only BLEND_MODE_MIX ensures that the material [html i]may[html /i] be opaque, any other blend mode will render with alpha blending enabled in raster-based [VisualServer] implementations.
</description>
</method>
<methodname="get_blend_mode"qualifiers="const">
<returntype="int">
</return>
<description>
Return blend mode for the material, which can be one of BLEND_MODE_MIX (default), BLEND_MODE_ADD, BLEND_MODE_SUB. Keep in mind that only BLEND_MODE_MIX ensures that the material [html i]may[html /i] be opaque, any other blend mode will render with alpha blending enabled in raster-based [VisualServer] implementations.
</description>
</method>
<methodname="set_shade_model">
<argumentindex="0"name="model"type="int">
</argument>
<description>
</description>
</method>
<methodname="get_shade_model"qualifiers="const">
<returntype="int">
</return>
<description>
</description>
</method>
<methodname="set_line_width">
<argumentindex="0"name="width"type="real">
</argument>
<description>
Set the line width for geometry drawn with FLAG_WIREFRAME enabled, or LINE primitives. Note that not all hardware or VisualServer backends support this (like DirectX).
</description>
</method>
<methodname="get_line_width"qualifiers="const">
<returntype="real">
</return>
<description>
Return the line width for geometry drawn with FLAG_WIREFRAME enabled, or LINE primitives. Note that not all hardware or VisualServer backends support this (like DirectX).
</description>
</method>
<methodname="set_shader_param">
<argumentindex="0"name="param"type="String">
</argument>
<argumentindex="1"name="arg1"type="var">
</argument>
<description>
</description>
</method>
<methodname="get_shader_param"qualifiers="const">
<argumentindex="0"name="arg0"type="String">
</argument>
<description>
</description>
</method>
</methods>
<constants>
<constantname="SHADE_MODEL_FRESNEL"value="2">
</constant>
<constantname="SHADE_MODEL_LAMBERT"value="0">
</constant>
<constantname="HINT_DECAL"value="0">
</constant>
<constantname="FLAG_WIREFRAME"value="5">
Triangle geometry is drawn as lines if this flag is enabled.
A [Resource] that contains vertex-array based geometry.
</brief_description>
<description>
Mesh is a type of [Resource] that contains vertex-array based geometry, divided in [html i]surfaces[html /i]. Each surface contains a completely separate array and a material used to draw it. Design wise, a mesh with multiple surfaces is prefered to a single surface, because objects created in 3D editing software commonly contain multiple materials.
Create a new surface ([method get_surface_count] will become surf_idx for this.[html br/] 			Surfaces are created to be rendered using a "primitive", which may be PRIMITIVE_POINTS, PRIMITIVE_LINES, PRIMITIVE_LINE_STRIP, PRIMITIVE_LINE_LOOP, PRIMITIVE_TRIANGLES, PRIMITIVE_TRIANGLE_STRIP, PRIMITIVE_TRIANGLE_FAN. (As a note, when using indices, it is recommended to only use just points, lines or triangles).[html br/] 			The format of a surface determines which arrays it will allocate and hold, so "format" is a combination of ARRAY_FORMAT_* mask constants ORed together. ARRAY_FORMAT_VERTEX must be always present. "array_len" determines the amount of vertices in the array (not primitives!). if ARRAY_FORMAT_INDEX is in the format mask, then it means that an index array will be allocated and "index_array_len" must be passed.
Return the amount of surfaces that the [Mesh] holds.
</description>
</method>
<methodname="surface_remove">
<argumentindex="0"name="surf_idx"type="int">
</argument>
<description>
Remove a surface at position surf_idx, shifting greater surfaces one surf_idx slot down.
</description>
</method>
<methodname="surface_set_array">
<returntype="int">
</return>
<argumentindex="0"name="surf_idx"type="int">
</argument>
<argumentindex="1"name="array"type="int">
</argument>
<argumentindex="2"name="data"type="var">
</argument>
<description>
Set a surface array, array must be defined in the format (see [method add_surface]), and which array being set in "data" must be indicated passing a value from the ARRAY_* enum (NOT THE ARRAY_FORMAT_ enum!!). A Mesh can't be displayed (error will be reported) if an array that is present in the format was not set.
Return a surface array, array must be defined in the format (see [method add_surface]), and which array being returned must be indicated passing a value from the ARRAY_* enum (NOT THE ARRAY_FORMAT_ enum!!) (see [method add_surface]).
MeshInstance is a [Node] that takes a [Mesh] resource and adds it to the current [Scenario] by creating an instance of it. This is the class most often used to get 3D geometry rendered and can be used to instance a sigle [Mesh] in many places. This allows to reuse geometry and save on resources. When a [Mesh] has to be instanced more than thousands of times at close proximity, consider using a [MultiMesh] in a [MultiMeshInstance] instead.
</description>
<methods>
<methodname="set_mesh">
<argumentindex="0"name="mesh"type="Object">
</argument>
<description>
Set the [Mesh] resource for the instance.
</description>
</method>
<methodname="get_mesh"qualifiers="const">
<returntype="Object">
</return>
<description>
Return the current [Mesh] resource for the instance.
</description>
</method>
<methodname="get_aabb"qualifiers="const">
<returntype="AABB">
</return>
<description>
Return the AABB of the mesh, in local coordinates.
</description>
</method>
<methodname="create_trimesh_collision">
<description>
This helper creates a [StaticBody] child [Node] using the mesh geometry as collision. It's mainly used for testing.
MultiMesh provides low level mesh instancing. If the amount of [Mesh] instances needed goes from hundreds to thousands (and most need to be visible at close proximity) creating such a large amount of [MeshInstance] nodes may affect performance by using too much CPU or video memory. [html br/]For this case a MultiMesh becomes very useful, as it can draw thousands of instances with little API overhead.[html br/] As a drawback, if the instances are too far away of each other, performance may be reduced as every sigle instance will always rendered (they are spatially indexed as one, for the whole object).[html br/] Since instances may have any behavior, the AABB used for visibility must be provided by the user, or generated with [method generate_aabb].
</description>
<methods>
<methodname="set_mesh">
<argumentindex="0"name="arg0"type="Object">
</argument>
<description>
Set the [Mesh] resource to be drawn in multiple instances.
</description>
</method>
<methodname="get_mesh"qualifiers="const">
<returntype="Object">
</return>
<description>
Return the [Mesh] resource drawn as multiple instances.
</description>
</method>
<methodname="set_instance_count">
<argumentindex="0"name="arg0"type="int">
</argument>
<description>
Set the amount of instnces that is going to be drawn. Changing this number will erase all the existing instance transform and color data.
Set the visibility AABB. If not provided, MultiMesh will not be visible.
</description>
</method>
<methodname="get_aabb"qualifiers="const">
<returntype="AABB">
</return>
<description>
Return the visibility AABB.
</description>
</method>
<methodname="generate_aabb">
<description>
Generate a new visibility AABB, using mesh AABB and instance transforms. Since instance information is stored in the [VisualServer], this function is VERY SLOW and must NOT be used often.
MultiMeshInstance is a [Node] that takes a [MultiMesh] resource and adds it to the current [Scenario] by creating an instance of it (yes, this is an instance of instances).
</description>
<methods>
<methodname="set_multimesh">
<argumentindex="0"name="multimesh"type="Object">
</argument>
<description>
Set the [MultiMesh] to be instance.
</description>
</method>
<methodname="get_multimesh"qualifiers="const">
<returntype="Object">
</return>
<description>
Return the [MultiMesh] that is used for instancing.
Base class for all the "Scene" elements.
</brief_description>
<description>
Nodes can be set as children of other nodes, resulting in a tree arrangement. Any tree of nodes is called a "Scene".[html br/] Scenes can be saved to disk, and then instanced into other scenes. This allows for very high flexibility in the architecture and data model of the projects. Scenes become "active" and part of the "Scene Tree" once they are added as children of a [RootNode].[html br/][html br/] 	As an illustrative example, a Scene (tree of nodes): 	[html div align="center"][html img src="images/scene.png"/][html /div] 	This scene will was edited separatedly, then is added as part of a game (by instancing it), becoming part of a "Scene Tree": 	[html div align="center"][html img src="images/scene_tree.png"/][html /div] 	In short, nodes are an effective all-in-one way to create and organize assets, gameplay and game data. 	When a Node is freed (deleted), it will delete all its children 	nodes. 	TODO: explain better process/signal/group call ordering
</description>
<methods>
<methodname="set_name">
<argumentindex="0"name="name"type="String">
</argument>
<description>
Set the name of the [Node]. Name must be unique within parent, and setting an already existing name will cause for the node to be automatically renamed.
</description>
</method>
<methodname="get_name"qualifiers="const">
<returntype="String">
</return>
<description>
Return the name of the [Node]. Name is be unique within parent.
</description>
</method>
<methodname="add_child">
<argumentindex="0"name="node"type="Node">
</argument>
<description>
Add a child [Node]. Nodes can have as many children as they want, but every child must have a unique name. Children nodes are automatically deleted when the parent node is deleted, so deleting a whole scene is performed by deleting its topmost node.
</description>
</method>
<methodname="remove_child">
<argumentindex="0"name="node"type="Node">
</argument>
<description>
Remove a child [Node]. Node is NOT deleted and will have to be deleted manually.
</description>
</method>
<methodname="get_child_count"qualifiers="const">
<returntype="int">
</return>
<description>
Return the amount of children nodes.
</description>
</method>
<methodname="get_child"qualifiers="const">
<returntype="Object">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Return a children node by it's index (see [method get_child_count]). This method is often used for iterating all children of a node.
</description>
</method>
<methodname="has_node"qualifiers="const">
<returntype="bool">
</return>
<argumentindex="0"name="path"type="NodePath">
</argument>
<description>
</description>
</method>
<methodname="get_node"qualifiers="const">
<returntype="Object">
</return>
<argumentindex="0"name="path"type="NodePath">
</argument>
<description>
Fetch a node. "path" must be valid (or else error will occur) and can be either the name of a child node, a relative path (from the current node to another node), or an absolute path to a node.[html br/] Examples ofa paths are: get_node("Sword") , get_node("../Swamp/Alligator") , get_node("/MyGame"). [html br/]Note: fetching absolute paths only works when the node is inside the scene tree (see [method is_inside_tree]).
</description>
</method>
<methodname="get_parent"qualifiers="const">
<returntype="Object">
</return>
<description>
Return the parent [Node] of the current [Node], or an empty Object if the node lacks a parent.
</description>
</method>
<methodname="is_inside_scene"qualifiers="const">
<returntype="bool">
</return>
<description>
</description>
</method>
<methodname="is_a_parent_of"qualifiers="const">
<returntype="bool">
</return>
<argumentindex="0"name="node"type="Node">
</argument>
<description>
Return [html i]true[html /i] if the "node" argument is a direct or indirect child of the current node, otherwise return [html i]false[html /i].
</description>
</method>
<methodname="is_greater_than"qualifiers="const">
<returntype="bool">
</return>
<argumentindex="0"name="node"type="Node">
</argument>
<description>
Return [html i]true[html /i] if "node" occurs later in the scene hierarchy than the current node, otherwise return [html i]false[html /i].
</description>
</method>
<methodname="get_path"qualifiers="const">
<returntype="NodePath">
</return>
<description>
Return the absolute path of the current node. This only works if the curent node is inside the scene tree (see [method is_inside_tree]).
</description>
</method>
<methodname="get_path_to"qualifiers="const">
<returntype="NodePath">
</return>
<argumentindex="0"name="node"type="Node">
</argument>
<description>
Return the relative path from the current node to the specified node in "node" argument. Both nodes must be in the same scene, or else the function will fail.
</description>
</method>
<methodname="add_to_group">
<argumentindex="0"name="group"type="String">
</argument>
<argumentindex="1"name="arg1"type="bool">
</argument>
<description>
Add a node to a group. Groups are helpers to name and organize group of nodes, like for example: "Enemies""Collectables", etc. A [Node] can be in any number of groups. Nodes can be assigned a group at any time, but will not be added to it until they are inside the scene tree (see [method is_inside_tree]).
</description>
</method>
<methodname="remove_from_group">
<argumentindex="0"name="group"type="String">
</argument>
<description>
Remove a node from a group.
</description>
</method>
<methodname="move_child">
<argumentindex="0"name="child_node"type="Node">
</argument>
<argumentindex="1"name="to_pos"type="int">
</argument>
<description>
Move a child node to a different position (order) amongst the other children. Since calls, signals, etc are performed by tree order, changing the order of chilren nodes may be useful.
</description>
</method>
<methodname="raise">
<description>
Move this node to the top of the array of nodes of the parent node. This is often useful on GUIs ([Control]), because their order of drawing fully depends on their order in the tree.
</description>
</method>
<methodname="set_owner">
<argumentindex="0"name="arg0"type="Object">
</argument>
<description>
Set the node owner. A node can have any other node as owner (as long as a valid parent, grandparent, etc ascending in the tree). When saving a node (using SceneSaver) all the nodes it owns will be saved with it. This allows to create complex SceneTrees, with instancing and subinstancing.
</description>
</method>
<methodname="get_owner"qualifiers="const">
<returntype="Object">
</return>
<description>
Get the node owner (see [method set_node_owner]).
</description>
</method>
<methodname="remove_and_skip">
<description>
Remove a node and set all its children as childrens of the parent node (if exists). All even subscriptions that pass by the removed node will be unsubscribed.
</description>
</method>
<methodname="get_index"qualifiers="const">
<returntype="int">
</return>
<description>
Get the node index in the parent (assuming it has a parent).
</description>
</method>
<methodname="print_tree">
<description>
Print the screne to stdout. Used mainly for debugging purposes.
</description>
</method>
<methodname="set_filename">
<argumentindex="0"name="filename"type="String">
</argument>
<description>
A node can contain a filename. This filename should not be changed by the user, unless writing editors and tools. When a scene is instanced from a file, it topmost node contains the filename from where it was loaded.
</description>
</method>
<methodname="get_filename"qualifiers="const">
<returntype="String">
</return>
<description>
Return a filename that may be containedA node can contained by the node. When a scene is instanced from a file, it topmost node contains the filename from where it was loaded (see [method set_filename]).
</description>
</method>
<methodname="propagate_notification">
<argumentindex="0"name="what"type="int">
</argument>
<description>
Notify the current node and all its chldren recursively by calling notification() in all of them.
</description>
</method>
<methodname="set_process">
<argumentindex="0"name="enable"type="bool">
</argument>
<description>
Enables or disables node processing. When a node is being processed, it will receive a NOTIFICATION_PROCESS on every frame. It is common to check how much time was elapsed since the previous frame by calling [method get_process_time]. If the application is set to run at 60 fps, NOTIFICATION_PROCESS will be received 60 times per second (even if the visuals are running at faster or lower fps). Because of this, nodes that wish to do processing are recommended to use [method set_idle_process] instead, unless strong syncronization is requiered (for example, to modify the behavior of physics objects).
</description>
</method>
<methodname="get_process_time"qualifiers="const">
<returntype="real">
</return>
<description>
Return the amount of time elapsed (in seconds) between two succesive NOTIFICATION_PROCESS notifications.
</description>
</method>
<methodname="is_processing"qualifiers="const">
<returntype="bool">
</return>
<description>
Return wether processing is enabled in the current node.
</description>
</method>
<methodname="set_idle_process">
<argumentindex="0"name="enable"type="bool">
</argument>
<description>
Enables or disables node idle processing. When a node is being idle-processed, it will receive a NOTIFICATION_IDLE_PROCESS when idle. It is common to check how much time was elapsed since the previous idle time by calling [method get_idle_process_time]. Idle processing is commonly syncronized to [VisualServer] being done rendering a frame, so this type of processing is syncronized to the visible frames per second. To syncronize with the desired frames per second, see [method set_process] instead.
OmniDirectional Light, such as a lightbulb or a candle.
</brief_description>
<description>
An OmniDirectional light is a type of [Light] node that emits lights in all directions. The light is attenuated through the distance and this attenuation can be configured by changing the energy, radius and attenuation parameters of [Light]. TODO: Image of an omnilight.
Button control that provides selectable options when pressed.
</brief_description>
<description>
OptionButton is a type button that provides a selectable list of items when pressed. The item selected becomes the "current" item and is displayed as the button text.
Add an item, with text "label" and (optionally) id. If no "id" is passed, "id" becomes the item index. New items are appended at the end.
</description>
</method>
<methodname="add_icon_item">
<argumentindex="0"name="texture"type="Object">
</argument>
<argumentindex="1"name="label"type="String">
</argument>
<argumentindex="2"name="id"type="int">
</argument>
<description>
Add an item, with a "texture" icon, text "label" and (optionally) id. If no "id" is passed, "id" becomes the item index. New items are appended at the end.
</description>
</method>
<methodname="set_item_text">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="text"type="String">
</argument>
<description>
Set the text of an item at index "idx".
</description>
</method>
<methodname="set_item_icon">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="texture"type="Object">
</argument>
<description>
Set the icon of an item at index "idx".
</description>
</method>
<methodname="set_item_disabled">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="disabled"type="bool">
</argument>
<description>
</description>
</method>
<methodname="set_item_ID">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="id"type="int">
</argument>
<description>
Set the ID of an item at index "idx".
</description>
</method>
<methodname="set_item_metadata">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="metadata"type="var">
</argument>
<description>
</description>
</method>
<methodname="get_item_text"qualifiers="const">
<returntype="String">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Return the text of the item at index "idx".
</description>
</method>
<methodname="get_item_icon"qualifiers="const">
<returntype="Object">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Return the icon of the item at index "idx".
</description>
</method>
<methodname="get_item_ID"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Return the ID of the item at index "idx".
This signal is emitted when the current item was changed by the user. ID of the item selected is passed as argument (if no IDs were added, ID will be just the item index).
Abstraction and base class for packet-based protocols.
</brief_description>
<description>
PacketPeer is an abstration and base class for packet-based protocols (such as UDP). It provides an API for sending and receiving packets both as raw data or variables. This makes it easy to transfer data over a protocol, without having to encode data as low level bytes or having to worry about network ordering.
PacketStreamPeer provides a wrapper for working using packets over a stream. This allows for using packet based code with StreamPeers. PacketPeerStream implements a custom protocol over the StreamPeer, so the user should not read or write to the wrapped StreamPeer directly.
Provides an opaque background for [Control] children.
</brief_description>
<description>
Panel is a [Control] that displays an opaque background. It's commoly used as a parent and container for other types of [Control] nodes. 	[html div align="center"][html img src="images/panel_example.png"/][html /div]
Particles is a particle system 3D [Node] that is used to simulate several types of particle effects, such as explosions, rain, snow, fireflies, or other magical-like shinny sparkles. Particles are drawn using impostors, and given their dynamic behavior, the user must provide a visibility AABB (although helpers to create one automatically exist).
</description>
<methods>
<methodname="set_amount">
<argumentindex="0"name="amount"type="int">
</argument>
<description>
Set total amount of particles in the system.
</description>
</method>
<methodname="get_amount"qualifiers="const">
<returntype="int">
</return>
<description>
Return the total amount of particles in the system.
</description>
</method>
<methodname="set_emitting">
<argumentindex="0"name="enabled"type="bool">
</argument>
<description>
Set the "emitting" property state. When emitting, the particle system generates new particles at constant rate.
</description>
</method>
<methodname="is_emitting"qualifiers="const">
<returntype="bool">
</return>
<description>
Return the "emitting" property state (see [method set_emitting]).
</description>
</method>
<methodname="set_visibility_aabb">
<argumentindex="0"name="aabb"type="AABB">
</argument>
<description>
Set the visibility AABB for the particle system, since the default one will not work properly most of the time.
Return the normal vector towards where gravity is pulling (by default, negative Y).
</description>
</method>
<methodname="set_variable">
<argumentindex="0"name="variable"type="int">
</argument>
<argumentindex="1"name="value"type="real">
</argument>
<description>
Set a specific variable for the particle system (see VAR_* enum).
</description>
</method>
<methodname="get_variable"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="variable"type="int">
</argument>
<description>
Return a specific variable for the particle system (see VAR_* enum).
</description>
</method>
<methodname="set_randomness">
<argumentindex="0"name="variable"type="int">
</argument>
<argumentindex="1"name="randomness"type="real">
</argument>
<description>
Set the randomness for a specific variable of the particle system. Randomness produces small changes from the default each time a particle is emitted.
</description>
</method>
<methodname="get_randomness"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="arg0"type="int">
</argument>
<description>
Return the randomness for a specific variable of the particle system. Randomness produces small changes from the default each time a particle is emitted.
PopUp is a base [Control] used to show dialogs and popups. It's a subwindow and modal by default (see [Control]) and has helpers for custom popup behavior.
Popup (show the control in modal form) in the center of the screen, scalled at a ratio of size of the screen.
</description>
</method>
<methodname="popup">
<description>
Popup (show the control in modal form).
</description>
</method>
<methodname="set_exclusive">
<argumentindex="0"name="enable"type="bool">
</argument>
<description>
</description>
</method>
<methodname="is_exclusive"qualifiers="const">
<returntype="bool">
</return>
<description>
</description>
</method>
</methods>
<signals>
<signalname="about_to_show">
<description>
This signal is emitted when a popup is about to be shown. (often used in [PopupMenu] for clearing the list of options and creating a new one according to the current context).
Add a new item with text "label" and icon "texture. An id can optonally be provided, as well as an accelerator. If no id is provided, one will be created from the index.
Add a new item with text "label". An id can optonally be provided, as well as an accelerator. If no id is provided, one will be created from the index.
Add a new checkable item with text "label" and icon "texture. An id can optonally be provided, as well as an accelerator. If no id is provided, one will be created from the index. Note that checkable items just display a checkmark, but don't have any built-in checking behavior and must be checked/unchecked manually.
Add a new checkable item with text "label". An id can optonally be provided, as well as an accelerator. If no id is provided, one will be created from the index. Note that checkable items just display a checkmark, but don't have any built-in checking behavior and must be checked/unchecked manually.
</description>
</method>
<methodname="set_item_text">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="text"type="String">
</argument>
<description>
Set the text of the item at index "idx".
</description>
</method>
<methodname="set_item_icon">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="icon"type="Object">
</argument>
<description>
Set the icon of the item at index "idx".
</description>
</method>
<methodname="set_item_accelerator">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="accel"type="int">
</argument>
<description>
Set the accelerator of the item at index "idx". Accelerators are special combinations of keys that activate the item, no matter which control is fucused.
</description>
</method>
<methodname="set_item_metadata">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="metadata"type="var">
</argument>
<description>
</description>
</method>
<methodname="set_item_checked">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="arg1"type="bool">
</argument>
<description>
Set the checkstate status of the item at index "idx".
</description>
</method>
<methodname="set_item_disabled">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="arg1"type="bool">
</argument>
<description>
</description>
</method>
<methodname="set_item_ID">
<argumentindex="0"name="idx"type="int">
</argument>
<argumentindex="1"name="id"type="int">
</argument>
<description>
Set the id of the item at index "idx".
</description>
</method>
<methodname="get_item_text"qualifiers="const">
<returntype="String">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Return the text of the item at index "idx".
</description>
</method>
<methodname="get_item_icon"qualifiers="const">
<returntype="Object">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Return the icon of the item at index "idx".
Return the accelerator of the item at index "idx". Accelerators are special combinations of keys that activate the item, no matter which control is fucused.
</description>
</method>
<methodname="is_item_checked"qualifiers="const">
<returntype="bool">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Return the checkstate status of the item at index "idx".
</description>
</method>
<methodname="is_item_disabled"qualifiers="const">
<returntype="bool">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
</description>
</method>
<methodname="get_item_ID"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="idx"type="int">
</argument>
<description>
Return the id of the item at index "idx".
</description>
</method>
<methodname="get_item_index"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="id"type="int">
</argument>
<description>
Find and return the index of the item containing a given id.
</description>
</method>
<methodname="get_item_count"qualifiers="const">
<returntype="int">
</return>
<description>
Return the amount of items.
</description>
</method>
<methodname="add_separator">
<description>
Add a separator between items. Separators also occupy an index.
</description>
</method>
<methodname="clear">
<description>
Clear the popup menu.
</description>
</method>
</methods>
<signals>
<signalname="item_pressed">
<argumentindex="0"name="ID"type="int">
</argument>
<description>
This even is emitted when an item is pressed or its accelerator is activated. The id of the item is returned if it exists, else the index.
Portals provide virtual openings to [RoomInstance] nodes, so cameras can look at them from the outside. Note that portals are a visibility optimization technique, and are in no way related to the game of the same name (as in, they are not used for teleportation). For more information on how rooms and portals work, see [RoomInstance]. Portals are represented as 2D convex polygon shapes (in the X,Y local plane), and are placed on the surface of the areas occupied by a [RoomInstance], to indicate that the room can be accessed or looked-at through them. If two rooms are next to each other, and two similar portals in each of them share the same world position (and are parallel and opposed to each other), they will automatically "connect" and form "doors" (for example, the portals that connect a kitchen to a living room are placed in the door they share). Portals must always have a [RoomInstance] node as a parent, grandparent or far parent, or else they will not be active.
</description>
<methods>
<methodname="set_shape">
<argumentindex="0"name="points"type="Array">
</argument>
<description>
Set the portal shape. The shape is an array of [Point2] points, representing a convex polygon in the X,Y plane.
</description>
</method>
<methodname="get_shape"qualifiers="const">
<returntype="Array">
</return>
<description>
Return the portal shape. The shape is an array of [Point2] points, representing a convex polygon in the X,Y plane.
</description>
</method>
<methodname="set_enabled">
<argumentindex="0"name="enable"type="bool">
</argument>
<description>
Enable the portal (it is enabled by defaul though), disabling it will cause the parent [RoomInstance] to not be visible any longer when looking through the portal.
</description>
</method>
<methodname="is_enabled"qualifiers="const">
<returntype="bool">
</return>
<description>
Return wether the portal is active. When disabled it causes the parent [RoomInstance] to not be visible any longer when looking through the portal.
</description>
</method>
<methodname="set_disable_distance">
<argumentindex="0"name="distance"type="real">
</argument>
<description>
Set the distance threshold for disabling the portal. Every time that the portal goes beyond "distance", it disables itself, becoming the opaque color (see [method set_disabled_color]).
Return the distance threshold for disabling the portal. Every time that the portal goes beyond "distance", it disables itself, becoming the opaque color (see [method set_disabled_color]).
</description>
</method>
<methodname="set_disabled_color">
<argumentindex="0"name="color"type="Color">
</argument>
<description>
When the portal goes beyond the disable distance (see [method set_disable_distance]), it becomes opaque and displayed with color "color".
Range is a base class for [Control] nodes that change a floating point [html i]value[html /i] between a need a [html i]minimum[html /i], [html i]maximum[html /i], using [html i]step[html /i] and [html i]page[html /i], for example a [ScrollBar].
</description>
<methods>
<methodname="get_val"qualifiers="const">
<returntype="real">
</return>
<description>
Return the current value.
</description>
</method>
<methodname="get_min"qualifiers="const">
<returntype="real">
</return>
<description>
Return the minimum value.
</description>
</method>
<methodname="get_max"qualifiers="const">
<returntype="real">
</return>
<description>
Return the maximum value.
</description>
</method>
<methodname="get_step"qualifiers="const">
<returntype="real">
</return>
<description>
Return the stepping, if step is 0, stepping is disabled.
</description>
</method>
<methodname="get_page"qualifiers="const">
<returntype="real">
</return>
<description>
Return the page size, if page is 0, paging is disabled.
</description>
</method>
<methodname="get_unit_value"qualifiers="const">
<returntype="real">
</return>
<description>
Return value mapped to 0 to 1 (unit) range.
</description>
</method>
<methodname="set_val">
<argumentindex="0"name="value"type="real">
</argument>
<description>
</description>
</method>
<methodname="set_min">
<argumentindex="0"name="minimum"type="real">
</argument>
<description>
Set minimum value, clamped range value to it if it's less.
</description>
</method>
<methodname="set_max">
<argumentindex="0"name="maximum"type="real">
</argument>
<description>
</description>
</method>
<methodname="set_step">
<argumentindex="0"name="step"type="real">
</argument>
<description>
Set step value. If step is 0, stepping will be disabled.
</description>
</method>
<methodname="set_page">
<argumentindex="0"name="pagesize"type="real">
</argument>
<description>
Set page size. Page is mainly used for scrollbars or anything that controls text scrolling.
</description>
</method>
<methodname="set_unit_value">
<argumentindex="0"name="value"type="real">
</argument>
<description>
Set value mapped to 0 to 1 (unit) range, it will then be converted to the actual value within min and max.
</description>
</method>
<methodname="share">
<argumentindex="0"name="with"type="Object">
</argument>
<description>
</description>
</method>
<methodname="unshare">
<description>
</description>
</method>
</methods>
<signals>
<signalname="value_changed">
<argumentindex="0"name="value"type="real">
</argument>
<description>
This signal is emitted when value changes.
</description>
</signal>
<signalname="changed">
<description>
This signal is emitted when min, max, range or step change.
Resource is the base class for all resource types. Resources are primarily data containers. They are reference counted and freed when no longer in use. They are also loaded only once from disk, and further attempts to load the resource will return the same reference (all this in contrast to a [Node], which is not reference counted and can be instanced from disk as many times as desred). Resources can be saved externally on disk or bundled into another object, such as a [Node] or another resource.
</description>
<methods>
<methodname="set_path">
<argumentindex="0"name="path"type="String">
</argument>
<description>
Set the path of the resource. This is useful mainly for editors when saving/loading, and shouldn't be changed by anything else.
</description>
</method>
<methodname="get_path"qualifiers="const">
<returntype="String">
</return>
<description>
Return the path of the resource. This is useful mainly for editors when saving/loading, and shouldn't be changed by anything else.
</description>
</method>
<methodname="set_name">
<argumentindex="0"name="name"type="String">
</argument>
<description>
Set the name of the resources, any name is ok (it doesn't have to be unique). Name is for descriptive purposes only.
</description>
</method>
<methodname="get_name"qualifiers="const">
<returntype="String">
</return>
<description>
Return the name of the resources, any name is ok (it doesn't have to be unique). Name is for descriptive purposes only.
</description>
</method>
<methodname="get_rid"qualifiers="const">
<returntype="RID">
</return>
<description>
Return the RID of the resource (or an empty RID). Many resources (such as [Texture], [Mesh], etc) are high level abstractions of resources stored in a server, so this function will return the original RID.
Room contains the data to define the bounds of a scene (using a BSP Tree). It is instanced by a [RoomInstance] node to create rooms. See that class documentation for more information about rooms.
Set the bounds of the room as a BSP tree. a BSP Tree is defined a Dictionary: (TODO - see source code on how to create a BSP tree from a dictionary).
</description>
</method>
<methodname="get_bounds"qualifiers="const">
<returntype="Dictionary">
</return>
<description>
Return the bounds of the room as a BSP tree. a BSP Tree is defined a Dictionary: (TODO - see source code on how to create a BSP tree from a dictionary).
RoomInstance is a [Node] that instances a [Room] resource and places it on the world. Rooms are used for defining the areas taken up by [html i]interiors[html /i]. An [html i]interior[html /i] is any closed space that has an entrance/exit (or not) to the outside world, for example the inside of a house, a room in a house, a cave.[html br/]So why is this used? Rooms and Portals ([Portal]) are a common visualization optimization technique, it is used to make interiors invisible (not rendered) when the camera is at the exterior (such as an open field), and also the exterior invisible when inside an interior (such as a house). It is also used to make interior rooms invisible from other interior rooms. [html div align="center"][html img src="images/portals_example.png"/][html /div]
</description>
<methods>
<methodname="set_room">
<argumentindex="0"name="room"type="Object">
</argument>
<description>
Set the [Room] resource, containing the room bounds.
</description>
</method>
<methodname="get_room"qualifiers="const">
<returntype="Object">
</return>
<description>
Return the [Room] resource, containing the room bounds.
</description>
</method>
<methodname="compute_room_from_subtree">
<description>
This helper function computes a [Room] from the shapes of all the children [VisualInstance] nodes, and sets it to the node.
Sample provides an audio sample class, containing audio data, together with some information for playback, such as format, mix rate and loop. It is used by sound playback routines.
</description>
<methods>
<methodname="create">
<argumentindex="0"name="format"type="int">
</argument>
<argumentindex="1"name="stereo"type="bool">
</argument>
<argumentindex="2"name="length"type="int">
</argument>
<description>
Create new data for the sample, with format "format" (see FORMAT_* enum), stereo hint, and length in frames (not samples or bytes!) "frame". Calling create overrides previous existing data if it exists. Stereo samples are interleaved pairs of left and right (in that order) points
</description>
</method>
<methodname="get_format"qualifiers="const">
<returntype="int">
</return>
<description>
Return the sample format (see FORMAT_* enum).
</description>
</method>
<methodname="is_stereo"qualifiers="const">
<returntype="bool">
</return>
<description>
Return true if the sample was created stereo.
</description>
</method>
<methodname="get_length"qualifiers="const">
<returntype="int">
</return>
<description>
Return the sample length in frames.
</description>
</method>
<methodname="set_data">
<argumentindex="0"name="data"type="RawArray">
</argument>
<description>
Set sample data. Data must be little endian, no matter the host platform, and exactly as long to fit all frames. Example, if data is Stereo, 16 bits, 256 frames, it will be 1024 bytes long.
</description>
</method>
<methodname="get_data"qualifiers="const">
<returntype="RawArray">
</return>
<description>
Return sample data. Data will be endian, no matter with the host platform, and exactly as long to fit all frames. Example, if data is Stereo, 16 bits, 256 frames, it will be 1024 bytes long.
</description>
</method>
<methodname="set_mix_rate">
<argumentindex="0"name="hz"type="int">
</argument>
<description>
Set the mix rate for the sample (expected playback frequency).
</description>
</method>
<methodname="get_mix_rate"qualifiers="const">
<returntype="int">
</return>
<description>
Return the mix rate for the sample (expected playback frequency).
</description>
</method>
<methodname="set_loop_format">
<argumentindex="0"name="format"type="int">
</argument>
<description>
Set the loop format, see LOOP_* enum
</description>
</method>
<methodname="get_loop_format"qualifiers="const">
<returntype="int">
</return>
<description>
Return the loop format, see LOOP_* enum.
</description>
</method>
<methodname="set_loop_begin">
<argumentindex="0"name="pos"type="int">
</argument>
<description>
Set the loop begin position, it must be a valid frame and less than the loop end position.
</description>
</method>
<methodname="get_loop_begin"qualifiers="const">
<returntype="int">
</return>
<description>
Return the loop begin position.
</description>
</method>
<methodname="set_loop_end">
<argumentindex="0"name="pos"type="int">
</argument>
<description>
Set the loop end position, it must be a valid frame and greater than the loop begin position.
</description>
</method>
<methodname="get_loop_end"qualifiers="const">
<returntype="int">
</return>
<description>
Return the loop begin position.
</description>
</method>
</methods>
<constants>
<constantname="FORMAT_IMA_ADPCM"value="2">
Ima-ADPCM Audio.
</constant>
<constantname="LOOP_FORWARD"value="1">
Forward looping (when playback reaches loop end, goes back to loop begin)
</constant>
<constantname="FORMAT_PCM16"value="1">
16-Bits signed little endian PCM audio.
</constant>
<constantname="FORMAT_PCM8"value="0">
8-Bits signed little endian PCM audio.
</constant>
<constantname="LOOP_NONE"value="0">
No loop enabled.
</constant>
<constantname="LOOP_PING_PONG"value="2">
Ping-Pong looping (when playback reaches loop end, plays backward untilloop begin). Not available in all platforms.
SamplePlayer is a [Node] meant for simple sample playback. A library of samples is loaded and played back "as is", without positioning or anything.
Play back sample, given it's identifier "name". if "unique" is true, all othere previous samples will be stopped. The voice allocated for playback will be returned.
</description>
</method>
<methodname="stop">
<argumentindex="0"name="voice"type="int">
</argument>
<description>
Stop a voice "voice". (see [method play]).
</description>
</method>
<methodname="stop_all">
<description>
</description>
</method>
<methodname="set_mix_rate">
<argumentindex="0"name="voice"type="int">
</argument>
<argumentindex="1"name="hz"type="int">
</argument>
<description>
Change the mix rate of a voice "voice" to given "hz".
</description>
</method>
<methodname="set_pitch_scale">
<argumentindex="0"name="voice"type="int">
</argument>
<argumentindex="1"name="ratio"type="real">
</argument>
<description>
Scale the pitch (mix rate) of a voice by a ratio value "ratio". A ratio of 1.0 means the voice is unscaled.
</description>
</method>
<methodname="set_volume">
<argumentindex="0"name="voice"type="int">
</argument>
<argumentindex="1"name="nrg"type="real">
</argument>
<description>
Set the volume of a voice, 0db is maximum volume (every about -6db, volume is reduced in half). "db" does in fact go from zero to negative.
Set the panning of a voice. Panning goes from -1 (left) to +1 (right). Optionally, if the hardware supports 3D sound, also set depth and height (also in range -1 to +1).
Set and enable a filter of a voice, with type "type" (see FILTER_* enum), cutoff (0 to 22khz) frequency and resonance (0+).
</description>
</method>
<methodname="set_chorus">
<argumentindex="0"name="voice"type="int">
</argument>
<argumentindex="1"name="send"type="real">
</argument>
<description>
Set the chorus send level of a voice (0 to 1). For setting chorus parameters, see [AudioServer].
</description>
</method>
<methodname="set_reverb">
<argumentindex="0"name="voice"type="int">
</argument>
<argumentindex="1"name="room_type"type="int">
</argument>
<argumentindex="2"name="send"type="real">
</argument>
<description>
Set the reverb send level and type of a voice (0 to 1). (see REVERB_* enum for type).
</description>
</method>
<methodname="get_mix_rate"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="voice"type="int">
</argument>
<description>
Return the current mix rate for a given voice.
</description>
</method>
<methodname="get_pitch_scale"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="voice"type="int">
</argument>
<description>
Return the current pitch scale for a given voice.
</description>
</method>
<methodname="get_volume"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="voice"type="int">
</argument>
<description>
Return the current volume (in db) for a given voice. 0db is maximum volume (every about -6db, volume is reduced in half). "db" does in fact go from zero to negative.
</description>
</method>
<methodname="get_volume_db"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="voice"type="int">
</argument>
<description>
</description>
</method>
<methodname="get_pan"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="voice"type="int">
</argument>
<description>
Return the current panning for a given voice. Panning goes from -1 (left) to +1 (right).
</description>
</method>
<methodname="get_pan_depth"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="voice"type="int">
</argument>
<description>
Return the current pan depth for a given voice (not used unless the hardware supports 3D sound)
</description>
</method>
<methodname="get_pan_height"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="voice"type="int">
</argument>
<description>
Return the current pan height for a given voice (not used unless the hardware supports 3D sound)
</description>
</method>
<methodname="get_filter_type"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="voice"type="int">
</argument>
<description>
Return the current filter type in use (see FILTER_* enum) for a given voice.
Scrollbars are a [Range] based [Control], that display a draggable area (the size of the page). Horizontal ([HScrollBar]) and Vertical ([VScrollBar]) versions are available.
Separator is a [Control] used for sepataring other controls. It's purely a visual decoration. Horizontal ([HSeparator]) and Vertical ([VSeparator]) versions are available.
Skeleton provides a hierachial interface for managing bones, including pose, rest and animation (see [Animation]). Skeleton will support rag doll dynamics in the future.
</description>
<methods>
<methodname="add_bone">
<argumentindex="0"name="name"type="String">
</argument>
<description>
Add a bone, with name "name". [method get_bone_count] will become the bone index.
</description>
</method>
<methodname="find_bone"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="name"type="String">
</argument>
<description>
Return the bone index that matches "name" as its name.
</description>
</method>
<methodname="get_bone_name"qualifiers="const">
<returntype="String">
</return>
<argumentindex="0"name="bone_idx"type="int">
</argument>
<description>
Return the name of the bone at index "index"
</description>
</method>
<methodname="get_bone_parent"qualifiers="const">
<returntype="int">
</return>
<argumentindex="0"name="bone_idx"type="int">
</argument>
<description>
Return the bone index which is the parent of the bone at "bone_idx". If -1, then bone has no parent. Note that the parent bone returned will always be less than "bone_idx".
</description>
</method>
<methodname="set_bone_parent">
<argumentindex="0"name="bone_idx"type="int">
</argument>
<argumentindex="1"name="parent_idx"type="int">
</argument>
<description>
Set the bone index "parent_idx" as the parent of the bone at "bone_idx". If -1, then bone has no parent. Note: "parent_idx" must be less than "bone_idx".
</description>
</method>
<methodname="get_bone_count"qualifiers="const">
<returntype="int">
</return>
<description>
Return the amount of bones in the skeleton.
</description>
</method>
<methodname="get_bone_rest"qualifiers="const">
<returntype="Transform">
</return>
<argumentindex="0"name="bone_idx"type="int">
</argument>
<description>
Return the rest transform for a bone "bone_idx".
</description>
</method>
<methodname="set_bone_rest">
<argumentindex="0"name="bone_idx"type="int">
</argument>
<argumentindex="1"name="rest"type="Transform">
</argument>
<description>
Set the rest transform for bone "bone_idx"
Spatial is the base for every type of 3D [Node]. It contains a 3D [Transform] which can be set or get as local or global. If a Spatial [Node] has Spatial children, their transforms will be relative to the parent.
</description>
<methods>
<methodname="set_transform">
<argumentindex="0"name="local"type="Transform">
</argument>
<description>
Set the transform locally, relative to the parent spatial node.
</description>
</method>
<methodname="get_transform"qualifiers="const">
<returntype="Transform">
</return>
<description>
Return the local transform, relative to the bone parent.
</description>
</method>
<methodname="set_global_transform">
<argumentindex="0"name="global"type="Transform">
</argument>
<description>
Set the transform globally, relative to worldspace.
Spatial nodes receive this notifacation with their global transform changes. This means that either the current or a parent node changed it's transform.
Spotlight Light, such as a reflector spotlight or a latern.
</brief_description>
<description>
A SpotLight light is a type of [Light] node that emits lights in a specific direction, in the shape of a cone. The light is attenuated through the distance and this attenuation can be configured by changing the energy, radius and attenuation parameters of [Light]. TODO: Image of a spotlight.
[html a href="http://squirrel-lang.org/"]Squirrel Language[html /a] support for the engine. Allows to load a [Script] from a .sq or .nut source or compiled file, or bundled it into scenes.
StaticBody implements a static collision [Node], by utilizing a rigid body in the [PhysicsServer]. Static bodies are used for static collision. For more information on physics body nodes, see [PhysicsBody].
Abstraction and base class for stream-based protocols.
</brief_description>
<description>
StreamPeer is an abstration and base class for stream-based protocols (such as TCP or Unix Sockets). It provides an API for sending and receiving data through streams as raw data or strings.
</description>
<methods>
<methodname="put_data">
<returntype="int">
</return>
<argumentindex="0"name="data"type="RawArray">
</argument>
<description>
Send a chunk of data through the connection, blocking if necesary until the data is done sending. This function returns an [Error] code.
</description>
</method>
<methodname="put_partial_data">
<returntype="Array">
</return>
<argumentindex="0"name="data"type="RawArray">
</argument>
<description>
Send a chunk of data through the connection, if all the data could not be sent at once, only part of it will. This function returns two values, an [Error] code and an integer, describing how much data was actually sent.
</description>
</method>
<methodname="get_data">
<returntype="Array">
</return>
<argumentindex="0"name="bytes"type="int">
</argument>
<description>
Return a chunk data with the received bytes. The amount of bytes to be received can be requested in the "bytes" argument. If not enough bytes are available, the function will block until the desired amount is received. This function returns two values, an [Error] code and a data array.
</description>
</method>
<methodname="get_partial_data">
<returntype="Array">
</return>
<argumentindex="0"name="bytes"type="int">
</argument>
<description>
Return a chunk data with the received bytes. The amount of bytes to be received can be requested in the "bytes" argument. If not enough bytes are available, the function will return how many were actually received. This function returns two values, an [Error] code, and a data array.
StyleBox is [Resource] that provides an abstract base class for dawing stylized boxes for the UI. StyleBoxes are used for dawing the styles of buttons, line edit backgrounds, tree backgrounds, etc. and also for testing a transparency mask for pointer signals. If mask test fails on a StyleBox assigned as mask to a control, clicks and motion signals will go through it to the one below.
</description>
<methods>
<methodname="test_mask"qualifiers="const">
<returntype="bool">
</return>
<argumentindex="0"name="point"type="Vector2">
</argument>
<argumentindex="1"name="rect"type="Rect2">
</argument>
<description>
Test a position in a rectangle, return wether it pases the mask test.
</description>
</method>
<methodname="set_default_margin">
<argumentindex="0"name="margin"type="int">
</argument>
<argumentindex="1"name="offset"type="real">
</argument>
<description>
Set the default offset "offset" of the margin "margin" (see MARGIN_* enum) for a StyleBox, Controls that draw styleboxes with context inside need to know the margin, so the border of the stylebox is not occluded.
Return the default offset of the margin "margin" (see MARGIN_* enum) of a StyleBox, Controls that draw styleboxes with context inside need to know the margin, so the border of the stylebox is not occluded.
</description>
</method>
<methodname="get_margin"qualifiers="const">
<returntype="real">
</return>
<argumentindex="0"name="margin"type="int">
</argument>
<description>
Return the offset of margin "margin" (see MARGIN_* enum).
</description>
</method>
<methodname="get_minimum_size"qualifiers="const">
<returntype="Vector2">
</return>
<description>
Return the minimum size that this stylebox can be shrunk to.
</description>
</method>
<methodname="get_offset"qualifiers="const">
<returntype="Vector2">
</return>
<description>
Return the "offset" of a stylebox, this is a helper function, like writing Point2( style.get_margin(MARGIN_LEFT), style.get_margin(MARGIN_TOP) )
This StyleBox is similar to [StyleBoxTexture], but only meant to be used for mask testing. It takes an image and applies stretch rules to determine if the poit clicked is masked or not.
</description>
<methods>
<methodname="set_image">
<argumentindex="0"name="image"type="Image">
</argument>
<description>
Set the image used for mask testing. Pixels (converted to grey) that have a value, less than 0.5 will fail the test.
</description>
</method>
<methodname="get_image"qualifiers="const">
<returntype="Image">
</return>
<description>
Return the image used for mask testing. (see [method set_imag]).
</description>
</method>
<methodname="set_expand">
<argumentindex="0"name="expand"type="bool">
</argument>
<description>
Set the expand property (default). When expanding, the image will use the same rules as [StyleBoxTexture] for expand. If not expanding, the image will always be tested at its original size.
</description>
</method>
<methodname="get_expand"qualifiers="const">
<returntype="bool">
</return>
<description>
Return wether the expand property is set(default). When expanding, the image will use the same rules as [StyleBoxTexture] for expand. If not expanding, the image will always be tested at its original size.
</description>
</method>
<methodname="set_expand_margin_size">
<argumentindex="0"name="margin"type="int">
</argument>
<argumentindex="1"name="size"type="real">
</argument>
<description>
Set an expand margin size (from enum MARGIN_*). Parts of the image below the size of the margin (and in the direction of the margin) will not expand.
Return the expand margin size (from enum MARGIN_*). Parts of the image below the size of the margin (and in the direction of the margin) will not expand.