mirror of
https://github.com/godotengine/godot.git
synced 2025-01-21 01:11:20 +00:00
Style: Misc docs and comment style and language fixes
- Removed empty paragraphs in XML. - Consistently use bold style for "Example:", on a new line. - Fix usage of `[code]` when hyperlinks could be used (`[member]`, `[constant]`). - Fix invalid usage of backticks for inline code in BBCode. - Fix some American/British English spelling inconsistencies. - Other minor fixes spotted along the way, including typo fixes with codespell. - Don't specify `@GlobalScope` for `enum` and `constant`.
This commit is contained in:
parent
39cece382d
commit
f7c611ab71
@ -1310,7 +1310,7 @@ void Input::parse_mapping(String p_mapping) {
|
||||
JoyButton output_button = _get_output_button(output);
|
||||
JoyAxis output_axis = _get_output_axis(output);
|
||||
ERR_CONTINUE_MSG(output_button == JoyButton::INVALID && output_axis == JoyAxis::INVALID,
|
||||
vformat("Unrecognised output string \"%s\" in mapping:\n%s", output, p_mapping));
|
||||
vformat("Unrecognized output string \"%s\" in mapping:\n%s", output, p_mapping));
|
||||
ERR_CONTINUE_MSG(output_button != JoyButton::INVALID && output_axis != JoyAxis::INVALID,
|
||||
vformat("Output string \"%s\" matched both button and axis in mapping:\n%s", output, p_mapping));
|
||||
|
||||
|
@ -34,7 +34,7 @@
|
||||
#include "core/math/vector2.h"
|
||||
#include "core/typedefs.h"
|
||||
|
||||
static inline float undenormalise(volatile float f) {
|
||||
static inline float undenormalize(volatile float f) {
|
||||
union {
|
||||
uint32_t i;
|
||||
float f;
|
||||
@ -101,9 +101,9 @@ struct AudioFrame {
|
||||
r /= p_sample;
|
||||
}
|
||||
|
||||
_ALWAYS_INLINE_ void undenormalise() {
|
||||
l = ::undenormalise(l);
|
||||
r = ::undenormalise(r);
|
||||
_ALWAYS_INLINE_ void undenormalize() {
|
||||
l = ::undenormalize(l);
|
||||
r = ::undenormalize(r);
|
||||
}
|
||||
|
||||
_FORCE_INLINE_ AudioFrame lerp(const AudioFrame &p_b, float p_t) const {
|
||||
|
@ -815,7 +815,7 @@ void Basis::get_axis_angle(Vector3 &r_axis, real_t &r_angle) const {
|
||||
return;
|
||||
}
|
||||
// As we have reached here there are no singularities so we can handle normally.
|
||||
double s = Math::sqrt((rows[2][1] - rows[1][2]) * (rows[2][1] - rows[1][2]) + (rows[0][2] - rows[2][0]) * (rows[0][2] - rows[2][0]) + (rows[1][0] - rows[0][1]) * (rows[1][0] - rows[0][1])); // Used to normalise.
|
||||
double s = Math::sqrt((rows[2][1] - rows[1][2]) * (rows[2][1] - rows[1][2]) + (rows[0][2] - rows[2][0]) * (rows[0][2] - rows[2][0]) + (rows[1][0] - rows[0][1]) * (rows[1][0] - rows[0][1])); // Used to normalize.
|
||||
|
||||
if (Math::abs(s) < CMP_EPSILON) {
|
||||
// Prevent divide by zero, should not happen if matrix is orthogonal and should be caught by singularity test above.
|
||||
|
@ -572,7 +572,8 @@
|
||||
<return type="float" />
|
||||
<param index="0" name="lin" type="float" />
|
||||
<description>
|
||||
Converts from linear energy to decibels (audio). This can be used to implement volume sliders that behave as expected (since volume isn't linear). Example:
|
||||
Converts from linear energy to decibels (audio). This can be used to implement volume sliders that behave as expected (since volume isn't linear).
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
# "Slider" refers to a node that inherits Range such as HSlider or VSlider.
|
||||
# Its range must be configured to go from 0 to 1.
|
||||
@ -841,7 +842,7 @@
|
||||
<return type="PackedInt64Array" />
|
||||
<param index="0" name="seed" type="int" />
|
||||
<description>
|
||||
Given a [param seed], returns a [PackedInt64Array] of size [code]2[/code], where its first element is the randomised [int] value, and the second element is the same as [param seed]. Passing the same [param seed] consistently returns the same array.
|
||||
Given a [param seed], returns a [PackedInt64Array] of size [code]2[/code], where its first element is the randomized [int] value, and the second element is the same as [param seed]. Passing the same [param seed] consistently returns the same array.
|
||||
[b]Note:[/b] "Seed" here refers to the internal state of the pseudo random number generator, currently implemented as a 64 bit integer.
|
||||
[codeblock]
|
||||
var a = rand_from_seed(4)
|
||||
@ -2487,7 +2488,8 @@
|
||||
</constant>
|
||||
<constant name="OK" value="0" enum="Error">
|
||||
Methods that return [enum Error] return [constant OK] when no error occurred.
|
||||
Since [constant OK] has value 0, and all other error constants are positive integers, it can also be used in boolean checks. For example:
|
||||
Since [constant OK] has value 0, and all other error constants are positive integers, it can also be used in boolean checks.
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
var error = method_that_returns_error()
|
||||
if error != OK:
|
||||
@ -2648,7 +2650,8 @@
|
||||
The property has no hint for the editor.
|
||||
</constant>
|
||||
<constant name="PROPERTY_HINT_RANGE" value="1" enum="PropertyHint">
|
||||
Hints that an [int] or [float] property should be within a range specified via the hint string [code]"min,max"[/code] or [code]"min,max,step"[/code]. The hint string can optionally include [code]"or_greater"[/code] and/or [code]"or_less"[/code] to allow manual input going respectively above the max or below the min values. Example: [code]"-360,360,1,or_greater,or_less"[/code].
|
||||
Hints that an [int] or [float] property should be within a range specified via the hint string [code]"min,max"[/code] or [code]"min,max,step"[/code]. The hint string can optionally include [code]"or_greater"[/code] and/or [code]"or_less"[/code] to allow manual input going respectively above the max or below the min values.
|
||||
[b]Example:[/b] [code]"-360,360,1,or_greater,or_less"[/code].
|
||||
Additionally, other keywords can be included: [code]"exp"[/code] for exponential range editing, [code]"radians"[/code] for editing radian angles in degrees, [code]"degrees"[/code] to hint at an angle and [code]"hide_slider"[/code] to hide the slider.
|
||||
</constant>
|
||||
<constant name="PROPERTY_HINT_ENUM" value="2" enum="PropertyHint">
|
||||
@ -2722,7 +2725,8 @@
|
||||
<constant name="PROPERTY_HINT_OBJECT_ID" value="24" enum="PropertyHint">
|
||||
</constant>
|
||||
<constant name="PROPERTY_HINT_TYPE_STRING" value="25" enum="PropertyHint">
|
||||
Hints that a property represents a particular type. If a property is [constant TYPE_STRING], allows to set a type from the create dialog. If you need to create an [Array] to contain elements of a specific type, the [code]hint_string[/code] must encode nested types using [code]":"[/code] and [code]"/"[/code] for specifying [Resource] types. For example:
|
||||
Hints that a property represents a particular type. If a property is [constant TYPE_STRING], allows to set a type from the create dialog. If you need to create an [Array] to contain elements of a specific type, the [code]hint_string[/code] must encode nested types using [code]":"[/code] and [code]"/"[/code] for specifying [Resource] types.
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
hint_string = "%s:" % [TYPE_INT] # Array of integers.
|
||||
hint_string = "%s:%s:" % [TYPE_ARRAY, TYPE_REAL] # Two-dimensional array of floats.
|
||||
|
@ -62,7 +62,7 @@
|
||||
Sets autowrapping for the text in the dialog.
|
||||
</member>
|
||||
<member name="dialog_close_on_escape" type="bool" setter="set_close_on_escape" getter="get_close_on_escape" default="true">
|
||||
If [code]true[/code], the dialog will be hidden when the escape key ([constant @GlobalScope.KEY_ESCAPE]) is pressed.
|
||||
If [code]true[/code], the dialog will be hidden when the escape key ([constant KEY_ESCAPE]) is pressed.
|
||||
</member>
|
||||
<member name="dialog_hide_on_ok" type="bool" setter="set_hide_on_ok" getter="get_hide_on_ok" default="true">
|
||||
If [code]true[/code], the dialog is hidden when the OK button is pressed. You can set it to [code]false[/code] if you want to do e.g. input validation when receiving the [signal confirmed] signal, and handle hiding the dialog in your own logic.
|
||||
|
@ -317,13 +317,13 @@
|
||||
<method name="get_typed_builtin" qualifiers="const">
|
||||
<return type="int" />
|
||||
<description>
|
||||
Returns the [code]TYPE[/code] constant for a typed array. If the [Array] is not typed, returns [constant @GlobalScope.TYPE_NIL].
|
||||
Returns the [enum Variant.Type] constant for a typed array. If the [Array] is not typed, returns [constant TYPE_NIL].
|
||||
</description>
|
||||
</method>
|
||||
<method name="get_typed_class_name" qualifiers="const">
|
||||
<return type="StringName" />
|
||||
<description>
|
||||
Returns a class name of a typed [Array] of type [constant @GlobalScope.TYPE_OBJECT].
|
||||
Returns a class name of a typed [Array] of type [constant TYPE_OBJECT].
|
||||
</description>
|
||||
</method>
|
||||
<method name="get_typed_script" qualifiers="const">
|
||||
@ -353,7 +353,6 @@
|
||||
GD.Print(arr.Contains("7")); // False
|
||||
[/csharp]
|
||||
[/codeblocks]
|
||||
|
||||
[b]Note:[/b] This is equivalent to using the [code]in[/code] operator as follows:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
@ -543,7 +542,7 @@
|
||||
<param index="1" name="class_name" type="StringName" />
|
||||
<param index="2" name="script" type="Variant" />
|
||||
<description>
|
||||
Makes the [Array] typed. The [param type] should be one of the [@GlobalScope] [code]TYPE[/code] constants. [param class_name] is optional and can only be provided for [constant @GlobalScope.TYPE_OBJECT]. [param script] can only be provided if [param class_name] is not empty.
|
||||
Makes the [Array] typed. The [param type] should be one of the [enum Variant.Type] constants. [param class_name] is optional and can only be provided for [constant TYPE_OBJECT]. [param script] can only be provided if [param class_name] is not empty.
|
||||
The method fails if an array is already typed.
|
||||
</description>
|
||||
</method>
|
||||
|
@ -12,7 +12,7 @@
|
||||
<method name="convert_to_image" qualifiers="const">
|
||||
<return type="Image" />
|
||||
<description>
|
||||
Returns an image of the same size as the bitmap and with a [enum Image.Format] of type [code]FORMAT_L8[/code]. [code]true[/code] bits of the bitmap are being converted into white pixels, and [code]false[/code] bits into black.
|
||||
Returns an image of the same size as the bitmap and with a [enum Image.Format] of type [constant Image.FORMAT_L8]. [code]true[/code] bits of the bitmap are being converted into white pixels, and [code]false[/code] bits into black.
|
||||
</description>
|
||||
</method>
|
||||
<method name="create">
|
||||
|
@ -42,7 +42,7 @@
|
||||
</tutorials>
|
||||
<members>
|
||||
<member name="alignment" type="int" setter="set_text_alignment" getter="get_text_alignment" enum="HorizontalAlignment" default="1">
|
||||
Text alignment policy for the button's text, use one of the [enum @GlobalScope.HorizontalAlignment] constants.
|
||||
Text alignment policy for the button's text, use one of the [enum HorizontalAlignment] constants.
|
||||
</member>
|
||||
<member name="clip_text" type="bool" setter="set_clip_text" getter="get_clip_text" default="false">
|
||||
When this property is enabled, text that is too large to fit the button is clipped, when disabled the Button will always be wide enough to hold the text.
|
||||
@ -58,7 +58,7 @@
|
||||
To edit margin and spacing of the icon, use [theme_item h_separation] theme property and [code]content_margin_*[/code] properties of the used [StyleBox]es.
|
||||
</member>
|
||||
<member name="icon_alignment" type="int" setter="set_icon_alignment" getter="get_icon_alignment" enum="HorizontalAlignment" default="0">
|
||||
Specifies if the icon should be aligned to the left, right, or center of a button. Uses the same [enum @GlobalScope.HorizontalAlignment] constants as the text alignment. If centered, text will draw on top of the icon.
|
||||
Specifies if the icon should be aligned to the left, right, or center of a button. Uses the same [enum HorizontalAlignment] constants as the text alignment. If centered, text will draw on top of the icon.
|
||||
</member>
|
||||
<member name="language" type="String" setter="set_language" getter="get_language" default="""">
|
||||
Language code used for line-breaking and text shaping algorithms, if left empty current locale is used instead.
|
||||
|
@ -14,7 +14,8 @@
|
||||
<return type="CallbackTweener" />
|
||||
<param index="0" name="delay" type="float" />
|
||||
<description>
|
||||
Makes the callback call delayed by given time in seconds. Example:
|
||||
Makes the callback call delayed by given time in seconds.
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
var tween = get_tree().create_tween()
|
||||
tween.tween_callback(queue_free).set_delay(2) #this will call queue_free() after 2 seconds
|
||||
|
@ -152,7 +152,7 @@
|
||||
</member>
|
||||
<member name="floor_snap_length" type="float" setter="set_floor_snap_length" getter="get_floor_snap_length" default="1.0">
|
||||
Sets a snapping distance. When set to a value different from [code]0.0[/code], the body is kept attached to slopes when calling [method move_and_slide]. The snapping vector is determined by the given distance along the opposite direction of the [member up_direction].
|
||||
As long as the snapping vector is in contact with the ground and the body moves against `up_direction`, the body will remain attached to the surface. Snapping is not applied if the body moves along `up_direction`, so it will be able to detach from the ground when jumping.
|
||||
As long as the snapping vector is in contact with the ground and the body moves against [member up_direction], the body will remain attached to the surface. Snapping is not applied if the body moves along [member up_direction], so it will be able to detach from the ground when jumping.
|
||||
</member>
|
||||
<member name="floor_stop_on_slope" type="bool" setter="set_floor_stop_on_slope_enabled" getter="is_floor_stop_on_slope_enabled" default="true">
|
||||
If [code]true[/code], the body will not slide on slopes when calling [method move_and_slide] when the body is standing still.
|
||||
|
@ -137,7 +137,7 @@
|
||||
</member>
|
||||
<member name="floor_snap_length" type="float" setter="set_floor_snap_length" getter="get_floor_snap_length" default="0.1">
|
||||
Sets a snapping distance. When set to a value different from [code]0.0[/code], the body is kept attached to slopes when calling [method move_and_slide]. The snapping vector is determined by the given distance along the opposite direction of the [member up_direction].
|
||||
As long as the snapping vector is in contact with the ground and the body moves against `up_direction`, the body will remain attached to the surface. Snapping is not applied if the body moves along `up_direction`, so it will be able to detach from the ground when jumping.
|
||||
As long as the snapping vector is in contact with the ground and the body moves against [member up_direction], the body will remain attached to the surface. Snapping is not applied if the body moves along [member up_direction], so it will be able to detach from the ground when jumping.
|
||||
</member>
|
||||
<member name="floor_stop_on_slope" type="bool" setter="set_floor_stop_on_slope_enabled" getter="is_floor_stop_on_slope_enabled" default="true">
|
||||
If [code]true[/code], the body will not slide on slopes when calling [method move_and_slide] when the body is standing still.
|
||||
|
@ -4,7 +4,7 @@
|
||||
Multiline text control intended for editing code.
|
||||
</brief_description>
|
||||
<description>
|
||||
CodeEdit is a specialised [TextEdit] designed for editing plain text code files. It contains a bunch of features commonly found in code editors such as line numbers, line folding, code completion, indent management and string / comment management.
|
||||
CodeEdit is a specialized [TextEdit] designed for editing plain text code files. It contains a bunch of features commonly found in code editors such as line numbers, line folding, code completion, indent management and string / comment management.
|
||||
[b]Note:[/b] By default [CodeEdit] always use left-to-right text direction to correctly display source code.
|
||||
</description>
|
||||
<tutorials>
|
||||
|
@ -197,7 +197,7 @@
|
||||
<description>
|
||||
Returns the luminance of the color in the [code][0.0, 1.0][/code] range.
|
||||
This is useful when determining light or dark color. Colors with a luminance smaller than 0.5 can be generally considered dark.
|
||||
[b]Note:[/b] [method get_luminance] relies on the colour being in the linear color space to return an accurate relative luminance value. If the color is in the sRGB color space, use [method srgb_to_linear] to convert it to the linear color space first.
|
||||
[b]Note:[/b] [method get_luminance] relies on the color being in the linear color space to return an accurate relative luminance value. If the color is in the sRGB color space, use [method srgb_to_linear] to convert it to the linear color space first.
|
||||
</description>
|
||||
</method>
|
||||
<method name="hex" qualifiers="static">
|
||||
|
@ -163,7 +163,7 @@
|
||||
<param index="0" name="path" type="String" />
|
||||
<description>
|
||||
Loads the config file specified as a parameter. The file's contents are parsed and loaded in the [ConfigFile] object which the method was called on.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="load_encrypted">
|
||||
@ -172,7 +172,7 @@
|
||||
<param index="1" name="key" type="PackedByteArray" />
|
||||
<description>
|
||||
Loads the encrypted config file specified as a parameter, using the provided [param key] to decrypt it. The file's contents are parsed and loaded in the [ConfigFile] object which the method was called on.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="load_encrypted_pass">
|
||||
@ -181,7 +181,7 @@
|
||||
<param index="1" name="password" type="String" />
|
||||
<description>
|
||||
Loads the encrypted config file specified as a parameter, using the provided [param password] to decrypt it. The file's contents are parsed and loaded in the [ConfigFile] object which the method was called on.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="parse">
|
||||
@ -189,7 +189,7 @@
|
||||
<param index="0" name="data" type="String" />
|
||||
<description>
|
||||
Parses the passed string as the contents of a config file. The string is parsed and loaded in the ConfigFile object which the method was called on.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="save">
|
||||
@ -197,7 +197,7 @@
|
||||
<param index="0" name="path" type="String" />
|
||||
<description>
|
||||
Saves the contents of the [ConfigFile] object to the file specified as a parameter. The output file uses an INI-style structure.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="save_encrypted">
|
||||
@ -206,7 +206,7 @@
|
||||
<param index="1" name="key" type="PackedByteArray" />
|
||||
<description>
|
||||
Saves the contents of the [ConfigFile] object to the AES-256 encrypted file specified as a parameter, using the provided [param key] to encrypt it. The output file uses an INI-style structure.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="save_encrypted_pass">
|
||||
@ -215,7 +215,7 @@
|
||||
<param index="1" name="password" type="String" />
|
||||
<description>
|
||||
Saves the contents of the [ConfigFile] object to the AES-256 encrypted file specified as a parameter, using the provided [param password] to encrypt it. The output file uses an INI-style structure.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="set_value">
|
||||
|
@ -110,7 +110,7 @@
|
||||
<param index="0" name="event" type="InputEvent" />
|
||||
<description>
|
||||
Virtual method to be implemented by the user. Use this method to process and accept inputs on UI elements. See [method accept_event].
|
||||
Example: clicking a control.
|
||||
[b]Example usage for clicking a control:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
func _gui_input(event):
|
||||
@ -159,7 +159,7 @@
|
||||
The returned node will be added as child to a [PopupPanel], so you should only provide the contents of that panel. That [PopupPanel] can be themed using [method Theme.set_stylebox] for the type [code]"TooltipPanel"[/code] (see [member tooltip_text] for an example).
|
||||
[b]Note:[/b] The tooltip is shrunk to minimal size. If you want to ensure it's fully visible, you might want to set its [member custom_minimum_size] to some non-zero value.
|
||||
[b]Note:[/b] The node (and any relevant children) should be [member CanvasItem.visible] when returned, otherwise, the viewport that instantiates it will not be able to calculate its minimum size reliably.
|
||||
Example of usage with a custom-constructed node:
|
||||
[b]Example of usage with a custom-constructed node:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
func _make_custom_tooltip(for_text):
|
||||
@ -176,7 +176,7 @@
|
||||
}
|
||||
[/csharp]
|
||||
[/codeblocks]
|
||||
Example of usage with a custom scene instance:
|
||||
[b]Example of usage with a custom scene instance:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
func _make_custom_tooltip(for_text):
|
||||
@ -201,7 +201,7 @@
|
||||
<param index="1" name="text" type="String" />
|
||||
<description>
|
||||
User defined BiDi algorithm override function.
|
||||
Returns [code]Array[/code] of [code]Vector2i[/code] text ranges, in the left-to-right order. Ranges should cover full source [param text] without overlaps. BiDi algorithm will be used on each range separately.
|
||||
Returns an [Array] of [Vector2i] text ranges, in the left-to-right order. Ranges should cover full source [param text] without overlaps. BiDi algorithm will be used on each range separately.
|
||||
</description>
|
||||
</method>
|
||||
<method name="accept_event">
|
||||
@ -422,7 +422,7 @@
|
||||
<description>
|
||||
Returns the position of this [Control] in global screen coordinates (i.e. taking window position into account). Mostly useful for editor plugins.
|
||||
Equals to [member global_position] if the window is embedded (see [member Viewport.gui_embed_subwindows]).
|
||||
Example usage for showing a popup:
|
||||
[b]Example usage for showing a popup:[/b]
|
||||
[codeblock]
|
||||
popup_menu.position = get_screen_position() + get_local_mouse_position()
|
||||
popup_menu.reset_size()
|
||||
@ -528,7 +528,7 @@
|
||||
<param index="0" name="at_position" type="Vector2" default="Vector2(0, 0)" />
|
||||
<description>
|
||||
Returns the tooltip text [param at_position] in local coordinates, which will typically appear when the cursor is resting over this control. By default, it returns [member tooltip_text].
|
||||
[b]Note:[/b] This method can be overridden to customise its behaviour. If this method returns an empty [String], no tooltip is displayed.
|
||||
[b]Note:[/b] This method can be overridden to customize its behavior. If this method returns an empty [String], no tooltip is displayed.
|
||||
</description>
|
||||
</method>
|
||||
<method name="grab_click_focus">
|
||||
@ -916,7 +916,7 @@
|
||||
<param index="2" name="margin" type="int" default="0" />
|
||||
<description>
|
||||
Sets the offsets to a [param preset] from [enum Control.LayoutPreset] enum. This is the code equivalent to using the Layout menu in the 2D editor.
|
||||
Use parameter [param resize_mode] with constants from [enum Control.LayoutPresetMode] to better determine the resulting size of the [Control]. Constant size will be ignored if used with presets that change size, e.g. [code]PRESET_LEFT_WIDE[/code].
|
||||
Use parameter [param resize_mode] with constants from [enum Control.LayoutPresetMode] to better determine the resulting size of the [Control]. Constant size will be ignored if used with presets that change size, e.g. [constant PRESET_LEFT_WIDE].
|
||||
Use parameter [param margin] to determine the gap between the [Control] and the edges.
|
||||
</description>
|
||||
</method>
|
||||
@ -979,23 +979,23 @@
|
||||
The focus access mode for the control (None, Click or All). Only one Control can be focused at the same time, and it will receive keyboard, gamepad, and mouse signals.
|
||||
</member>
|
||||
<member name="focus_neighbor_bottom" type="NodePath" setter="set_focus_neighbor" getter="get_focus_neighbor" default="NodePath("")">
|
||||
Tells Godot which node it should give focus to if the user presses the down arrow on the keyboard or down on a gamepad by default. You can change the key by editing the [code]ui_down[/code] input action. The node must be a [Control]. If this property is not set, Godot will give focus to the closest [Control] to the bottom of this one.
|
||||
Tells Godot which node it should give focus to if the user presses the down arrow on the keyboard or down on a gamepad by default. You can change the key by editing the [member ProjectSettings.input/ui_down] input action. The node must be a [Control]. If this property is not set, Godot will give focus to the closest [Control] to the bottom of this one.
|
||||
</member>
|
||||
<member name="focus_neighbor_left" type="NodePath" setter="set_focus_neighbor" getter="get_focus_neighbor" default="NodePath("")">
|
||||
Tells Godot which node it should give focus to if the user presses the left arrow on the keyboard or left on a gamepad by default. You can change the key by editing the [code]ui_left[/code] input action. The node must be a [Control]. If this property is not set, Godot will give focus to the closest [Control] to the left of this one.
|
||||
Tells Godot which node it should give focus to if the user presses the left arrow on the keyboard or left on a gamepad by default. You can change the key by editing the [member ProjectSettings.input/ui_left] input action. The node must be a [Control]. If this property is not set, Godot will give focus to the closest [Control] to the left of this one.
|
||||
</member>
|
||||
<member name="focus_neighbor_right" type="NodePath" setter="set_focus_neighbor" getter="get_focus_neighbor" default="NodePath("")">
|
||||
Tells Godot which node it should give focus to if the user presses the right arrow on the keyboard or right on a gamepad by default. You can change the key by editing the [code]ui_right[/code] input action. The node must be a [Control]. If this property is not set, Godot will give focus to the closest [Control] to the bottom of this one.
|
||||
Tells Godot which node it should give focus to if the user presses the right arrow on the keyboard or right on a gamepad by default. You can change the key by editing the [member ProjectSettings.input/ui_right] input action. The node must be a [Control]. If this property is not set, Godot will give focus to the closest [Control] to the bottom of this one.
|
||||
</member>
|
||||
<member name="focus_neighbor_top" type="NodePath" setter="set_focus_neighbor" getter="get_focus_neighbor" default="NodePath("")">
|
||||
Tells Godot which node it should give focus to if the user presses the top arrow on the keyboard or top on a gamepad by default. You can change the key by editing the [code]ui_top[/code] input action. The node must be a [Control]. If this property is not set, Godot will give focus to the closest [Control] to the bottom of this one.
|
||||
Tells Godot which node it should give focus to if the user presses the top arrow on the keyboard or top on a gamepad by default. You can change the key by editing the [member ProjectSettings.input/ui_up] input action. The node must be a [Control]. If this property is not set, Godot will give focus to the closest [Control] to the bottom of this one.
|
||||
</member>
|
||||
<member name="focus_next" type="NodePath" setter="set_focus_next" getter="get_focus_next" default="NodePath("")">
|
||||
Tells Godot which node it should give focus to if the user presses [kbd]Tab[/kbd] on a keyboard by default. You can change the key by editing the [code]ui_focus_next[/code] input action.
|
||||
Tells Godot which node it should give focus to if the user presses [kbd]Tab[/kbd] on a keyboard by default. You can change the key by editing the [member ProjectSettings.input/ui_focus_next] input action.
|
||||
If this property is not set, Godot will select a "best guess" based on surrounding nodes in the scene tree.
|
||||
</member>
|
||||
<member name="focus_previous" type="NodePath" setter="set_focus_previous" getter="get_focus_previous" default="NodePath("")">
|
||||
Tells Godot which node it should give focus to if the user presses [kbd]Shift + Tab[/kbd] on a keyboard by default. You can change the key by editing the [code]ui_focus_prev[/code] input action.
|
||||
Tells Godot which node it should give focus to if the user presses [kbd]Shift + Tab[/kbd] on a keyboard by default. You can change the key by editing the [member ProjectSettings.input/ui_focus_prev] input action.
|
||||
If this property is not set, Godot will select a "best guess" based on surrounding nodes in the scene tree.
|
||||
</member>
|
||||
<member name="global_position" type="Vector2" setter="_set_global_position" getter="get_global_position">
|
||||
@ -1019,7 +1019,7 @@
|
||||
</member>
|
||||
<member name="mouse_force_pass_scroll_events" type="bool" setter="set_force_pass_scroll_events" getter="is_force_pass_scroll_events" default="true">
|
||||
When enabled, scroll wheel events processed by [method _gui_input] will be passed to the parent control even if [member mouse_filter] is set to [constant MOUSE_FILTER_STOP]. As it defaults to true, this allows nested scrollable containers to work out of the box.
|
||||
You should disable it on the root of your UI if you do not want scroll events to go to the [code]_unhandled_input[/code] processing.
|
||||
You should disable it on the root of your UI if you do not want scroll events to go to the [method Node._unhandled_input] processing.
|
||||
</member>
|
||||
<member name="offset_bottom" type="float" setter="set_offset" getter="get_offset" default="0.0">
|
||||
Distance between the node's bottom edge and its parent control, based on [member anchor_bottom].
|
||||
@ -1076,7 +1076,7 @@
|
||||
[b]Note:[/b] Theme items are looked for in the tree order, from branch to root, where each [Control] node is checked for its [member theme] property. The earliest match against any type/class name is returned. The project-level Theme and the default Theme are checked last.
|
||||
</member>
|
||||
<member name="tooltip_text" type="String" setter="set_tooltip_text" getter="get_tooltip_text" default="""">
|
||||
The default tooltip text. The tooltip appears when the user's mouse cursor stays idle over this control for a few moments, provided that the [member mouse_filter] property is not [constant MOUSE_FILTER_IGNORE]. The time required for the tooltip to appear can be changed with the [code]gui/timers/tooltip_delay_sec[/code] option in Project Settings. See also [method get_tooltip].
|
||||
The default tooltip text. The tooltip appears when the user's mouse cursor stays idle over this control for a few moments, provided that the [member mouse_filter] property is not [constant MOUSE_FILTER_IGNORE]. The time required for the tooltip to appear can be changed with the [member ProjectSettings.gui/timers/tooltip_delay_sec] option. See also [method get_tooltip].
|
||||
The tooltip popup will use either a default implementation, or a custom one that you can provide by overriding [method _make_custom_tooltip]. The default tooltip includes a [PopupPanel] and [Label] whose theme properties can be customized using [Theme] methods with the [code]"TooltipPanel"[/code] and [code]"TooltipLabel"[/code] respectively. For example:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
@ -1330,7 +1330,7 @@
|
||||
The control will receive mouse button input events through [method _gui_input] if clicked on. And the control will receive the [signal mouse_entered] and [signal mouse_exited] signals. These events are automatically marked as handled, and they will not propagate further to other controls. This also results in blocking signals in other controls.
|
||||
</constant>
|
||||
<constant name="MOUSE_FILTER_PASS" value="1" enum="MouseFilter">
|
||||
The control will receive mouse button input events through [method _gui_input] if clicked on. And the control will receive the [signal mouse_entered] and [signal mouse_exited] signals. If this control does not handle the event, the parent control (if any) will be considered, and so on until there is no more parent control to potentially handle it. This also allows signals to fire in other controls. If no control handled it, the event will be passed to `_unhandled_input` for further processing.
|
||||
The control will receive mouse button input events through [method _gui_input] if clicked on. And the control will receive the [signal mouse_entered] and [signal mouse_exited] signals. If this control does not handle the event, the parent control (if any) will be considered, and so on until there is no more parent control to potentially handle it. This also allows signals to fire in other controls. If no control handled it, the event will be passed to [method Node._unhandled_input] for further processing.
|
||||
</constant>
|
||||
<constant name="MOUSE_FILTER_IGNORE" value="2" enum="MouseFilter">
|
||||
The control will not receive mouse button input events through [method _gui_input]. The control will also not receive the [signal mouse_entered] nor [signal mouse_exited] signals. This will not block other controls from receiving these events or firing the signals. Ignored events will not be handled automatically.
|
||||
|
@ -30,7 +30,7 @@
|
||||
<method name="clean_dupes">
|
||||
<return type="void" />
|
||||
<description>
|
||||
Removes points that are closer than [code]CMP_EPSILON[/code] (0.00001) units to their neighbor on the curve.
|
||||
Removes duplicate points, i.e. points that are less than 0.00001 units (engine epsilon value) away from their neighbor on the curve.
|
||||
</description>
|
||||
</method>
|
||||
<method name="clear_points">
|
||||
|
@ -339,7 +339,7 @@
|
||||
<return type="Variant" />
|
||||
<param index="0" name="key" type="Variant" />
|
||||
<description>
|
||||
Retunrs a value at the given [param key] or [code]null[/code] and error if the key does not exist. For safe access, use [method get] or [method has].
|
||||
Returns a value at the given [param key] or [code]null[/code] and error if the key does not exist. For safe access, use [method get] or [method has].
|
||||
</description>
|
||||
</operator>
|
||||
</operators>
|
||||
|
@ -70,7 +70,7 @@
|
||||
<param index="0" name="to_dir" type="String" />
|
||||
<description>
|
||||
Changes the currently opened directory to the one passed as an argument. The argument can be relative to the current directory (e.g. [code]newdir[/code] or [code]../newdir[/code]), or an absolute path (e.g. [code]/tmp/newdir[/code] or [code]res://somedir/newdir[/code]).
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="copy">
|
||||
@ -81,7 +81,7 @@
|
||||
<description>
|
||||
Copies the [param from] file to the [param to] destination. Both arguments should be paths to files, either relative or absolute. If the destination file exists and is not access-protected, it will be overwritten.
|
||||
If [param chmod_flags] is different than [code]-1[/code], the Unix permissions for the destination path will be set to the provided value, if available on the current operating system.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="copy_absolute" qualifiers="static">
|
||||
@ -221,7 +221,7 @@
|
||||
<param index="0" name="path" type="String" />
|
||||
<description>
|
||||
Creates a directory. The argument can be relative to the current directory, or an absolute path. The target directory should be placed in an already existing directory (to create the full path recursively, see [method make_dir_recursive]).
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="make_dir_absolute" qualifiers="static">
|
||||
@ -236,7 +236,7 @@
|
||||
<param index="0" name="path" type="String" />
|
||||
<description>
|
||||
Creates a target directory and all necessary intermediate directories in its path, by calling [method make_dir] recursively. The argument can be relative to the current directory, or an absolute path.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="make_dir_recursive_absolute" qualifiers="static">
|
||||
@ -260,7 +260,7 @@
|
||||
<description>
|
||||
Permanently deletes the target file or an empty directory. The argument can be relative to the current directory, or an absolute path. If the target directory is not empty, the operation will fail.
|
||||
If you don't want to delete the file/directory permanently, use [method OS.move_to_trash] instead.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="remove_absolute" qualifiers="static">
|
||||
@ -276,7 +276,7 @@
|
||||
<param index="1" name="to" type="String" />
|
||||
<description>
|
||||
Renames (move) the [param from] file or directory to the [param to] destination. Both arguments should be paths to files or directories, either relative or absolute. If the destination file or directory exists and is not access-protected, it will be overwritten.
|
||||
Returns one of the [enum Error] code constants ([code]OK[/code] on success).
|
||||
Returns one of the [enum Error] code constants ([constant OK] on success).
|
||||
</description>
|
||||
</method>
|
||||
<method name="rename_absolute" qualifiers="static">
|
||||
|
@ -1008,8 +1008,8 @@
|
||||
<param index="1" name="callable" type="Callable" />
|
||||
<description>
|
||||
Adds a callback, which is called when the utterance has started, finished, canceled or reached a text boundary.
|
||||
- [code]TTS_UTTERANCE_STARTED[/code], [code]TTS_UTTERANCE_ENDED[/code], and [code]TTS_UTTERANCE_CANCELED[/code] callable's method should take one [int] parameter, the utterance id.
|
||||
- [code]TTS_UTTERANCE_BOUNDARY[/code] callable's method should take two [int] parameters, the index of the character and the utterance id.
|
||||
- [constant TTS_UTTERANCE_STARTED], [constant TTS_UTTERANCE_ENDED], and [constant TTS_UTTERANCE_CANCELED] callable's method should take one [int] parameter, the utterance id.
|
||||
- [constant TTS_UTTERANCE_BOUNDARY] callable's method should take two [int] parameters, the index of the character and the utterance id.
|
||||
[b]Note:[/b] The granularity of the boundary callbacks is engine dependent.
|
||||
[b]Note:[/b] This method is implemented on Android, iOS, Web, Linux (X11), macOS, and Windows.
|
||||
</description>
|
||||
@ -1170,7 +1170,7 @@
|
||||
<return type="Vector3i" />
|
||||
<param index="0" name="window_id" type="int" default="0" />
|
||||
<description>
|
||||
Returns left margins ([code]x[/code]), right margins ([code]y[/code]) adn height ([code]z[/code]) of the title that are safe to use (contains no buttons or other elements) when [constant WINDOW_FLAG_EXTEND_TO_TITLE] flag is set.
|
||||
Returns left margins ([code]x[/code]), right margins ([code]y[/code]) and height ([code]z[/code]) of the title that are safe to use (contains no buttons or other elements) when [constant WINDOW_FLAG_EXTEND_TO_TITLE] flag is set.
|
||||
</description>
|
||||
</method>
|
||||
<method name="window_get_size" qualifiers="const">
|
||||
|
@ -5,7 +5,7 @@
|
||||
</brief_description>
|
||||
<description>
|
||||
Object that holds all the available Commands and their shortcuts text. These Commands can be accessed through [b]Editor > Command Palette[/b] menu.
|
||||
Command key names use slash delimiters to distinguish sections Example: [code]"example/command1"[/code] then [code]example[/code] will be the section name.
|
||||
Command key names use slash delimiters to distinguish sections, for example: [code]"example/command1"[/code] then [code]example[/code] will be the section name.
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var command_palette = get_editor_interface().get_command_palette()
|
||||
|
@ -4,7 +4,7 @@
|
||||
A modified version of [FileDialog] used by the editor.
|
||||
</brief_description>
|
||||
<description>
|
||||
[EditorFileDialog] is an enhanced version of [FileDialog] avaiable only to editor plugins. Additional features include list of favorited/recent files and ability to see files as thumbnails grid instead of list.
|
||||
[EditorFileDialog] is an enhanced version of [FileDialog] available only to editor plugins. Additional features include list of favorited/recent files and ability to see files as thumbnails grid instead of list.
|
||||
</description>
|
||||
<tutorials>
|
||||
</tutorials>
|
||||
|
@ -7,8 +7,8 @@
|
||||
This is the control that implements property editing in the editor's Settings dialogs, the Inspector dock, etc. To get the [EditorInspector] used in the editor's Inspector dock, use [method EditorInterface.get_inspector].
|
||||
[EditorInspector] will show properties in the same order as the array returned by [method Object.get_property_list].
|
||||
If a property's name is path-like (i.e. if it contains forward slashes), [EditorInspector] will create nested sections for "directories" along the path. For example, if a property is named [code]highlighting/gdscript/node_path_color[/code], it will be shown as "Node Path Color" inside the "GDScript" section nested inside the "Highlighting" section.
|
||||
If a property has [constant @GlobalScope.PROPERTY_USAGE_GROUP] usage, it will group subsequent properties whose name starts with the property's hint string. The group ends when a property does not start with that hint string or when a new group starts. An empty group name effectively ends the current group. [EditorInspector] will create a top-level section for each group. For example, if a property with group usage is named [code]Collide With[/code] and its hint string is [code]collide_with_[/code], a subsequent [code]collide_with_area[/code] property will be shown as "Area" inside the "Collide With" section.
|
||||
If a property has [constant @GlobalScope.PROPERTY_USAGE_SUBGROUP] usage, a subgroup will be created in the same way as a group, and a second-level section will be created for each subgroup.
|
||||
If a property has [constant PROPERTY_USAGE_GROUP] usage, it will group subsequent properties whose name starts with the property's hint string. The group ends when a property does not start with that hint string or when a new group starts. An empty group name effectively ends the current group. [EditorInspector] will create a top-level section for each group. For example, if a property with group usage is named [code]Collide With[/code] and its hint string is [code]collide_with_[/code], a subsequent [code]collide_with_area[/code] property will be shown as "Area" inside the "Collide With" section.
|
||||
If a property has [constant PROPERTY_USAGE_SUBGROUP] usage, a subgroup will be created in the same way as a group, and a second-level section will be created for each subgroup.
|
||||
[b]Note:[/b] Unlike sections created from path-like property names, [EditorInspector] won't capitalize the name for sections created from groups. So properties with group usage usually use capitalized names instead of snake_cased names.
|
||||
</description>
|
||||
<tutorials>
|
||||
|
@ -222,7 +222,7 @@
|
||||
<method name="save_scene">
|
||||
<return type="int" enum="Error" />
|
||||
<description>
|
||||
Saves the scene. Returns either [code]OK[/code] or [code]ERR_CANT_CREATE[/code] (see [@GlobalScope] constants).
|
||||
Saves the scene. Returns either [constant OK] or [constant ERR_CANT_CREATE].
|
||||
</description>
|
||||
</method>
|
||||
<method name="save_scene_as">
|
||||
|
@ -100,7 +100,8 @@
|
||||
<param index="0" name="viewport_camera" type="Camera3D" />
|
||||
<param index="1" name="event" type="InputEvent" />
|
||||
<description>
|
||||
Called when there is a root node in the current edited scene, [method _handles] is implemented, and an [InputEvent] happens in the 3D viewport. The return value decides whether the [InputEvent] is consumed or forwarded to other [EditorPlugin]s. See [enum AfterGUIInput] for options. Example:
|
||||
Called when there is a root node in the current edited scene, [method _handles] is implemented, and an [InputEvent] happens in the 3D viewport. The return value decides whether the [InputEvent] is consumed or forwarded to other [EditorPlugin]s. See [enum AfterGUIInput] for options.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
# Prevents the InputEvent from reaching other Editor classes.
|
||||
@ -115,7 +116,8 @@
|
||||
}
|
||||
[/csharp]
|
||||
[/codeblocks]
|
||||
Must [code]return EditorPlugin.AFTER_GUI_INPUT_PASS[/code] in order to forward the [InputEvent] to other Editor classes. Example:
|
||||
Must [code]return EditorPlugin.AFTER_GUI_INPUT_PASS[/code] in order to forward the [InputEvent] to other Editor classes.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
# Consumes InputEventMouseMotion and forwards other InputEvent types.
|
||||
@ -182,7 +184,8 @@
|
||||
<return type="bool" />
|
||||
<param index="0" name="event" type="InputEvent" />
|
||||
<description>
|
||||
Called when there is a root node in the current edited scene, [method _handles] is implemented and an [InputEvent] happens in the 2D viewport. Intercepts the [InputEvent], if [code]return true[/code] [EditorPlugin] consumes the [param event], otherwise forwards [param event] to other Editor classes. Example:
|
||||
Called when there is a root node in the current edited scene, [method _handles] is implemented and an [InputEvent] happens in the 2D viewport. Intercepts the [InputEvent], if [code]return true[/code] [EditorPlugin] consumes the [param event], otherwise forwards [param event] to other Editor classes.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
# Prevents the InputEvent from reaching other Editor classes.
|
||||
@ -197,7 +200,8 @@
|
||||
}
|
||||
[/csharp]
|
||||
[/codeblocks]
|
||||
Must [code]return false[/code] in order to forward the [InputEvent] to other Editor classes. Example:
|
||||
Must [code]return false[/code] in order to forward the [InputEvent] to other Editor classes.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
# Consumes InputEventMouseMotion and forwards other InputEvent types.
|
||||
|
@ -14,7 +14,6 @@
|
||||
[b]Note:[/b] A character is a symbol that represents an item (letter, digit etc.) in an abstract way.
|
||||
[b]Note:[/b] A glyph is a bitmap or shape used to draw a one or more characters in a context-dependent manner. Glyph indices are bound to the specific font data source.
|
||||
[b]Note:[/b] If a none of the font data sources contain glyphs for a character used in a string, the character in question will be replaced with a box displaying its hexadecimal code.
|
||||
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var f = load("res://BarlowCondensed-Bold.ttf")
|
||||
|
@ -5,7 +5,6 @@
|
||||
</brief_description>
|
||||
<description>
|
||||
OpenType variations, simulated bold / slant, and additional font settings like OpenType features and extra spacing.
|
||||
|
||||
To use simulated bold font variant:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
|
@ -30,7 +30,6 @@
|
||||
if error != OK:
|
||||
push_error("An error occurred in the HTTP request.")
|
||||
|
||||
|
||||
# Called when the HTTP request is completed.
|
||||
func _http_request_completed(result, response_code, headers, body):
|
||||
var json = JSON.new()
|
||||
@ -95,7 +94,6 @@
|
||||
if error != OK:
|
||||
push_error("An error occurred in the HTTP request.")
|
||||
|
||||
|
||||
# Called when the HTTP request is completed.
|
||||
func _http_request_completed(result, response_code, headers, body):
|
||||
if result != HTTPRequest.RESULT_SUCCESS:
|
||||
|
@ -471,7 +471,8 @@
|
||||
<param index="1" name="y" type="int" />
|
||||
<param index="2" name="color" type="Color" />
|
||||
<description>
|
||||
Sets the [Color] of the pixel at [code](x, y)[/code] to [param color]. Example:
|
||||
Sets the [Color] of the pixel at [code](x, y)[/code] to [param color].
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var img_width = 10
|
||||
@ -498,7 +499,8 @@
|
||||
<param index="0" name="point" type="Vector2i" />
|
||||
<param index="1" name="color" type="Color" />
|
||||
<description>
|
||||
Sets the [Color] of the pixel at [param point] to [param color]. Example:
|
||||
Sets the [Color] of the pixel at [param point] to [param color].
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var img_width = 10
|
||||
|
@ -5,7 +5,6 @@
|
||||
</brief_description>
|
||||
<description>
|
||||
ImporterMesh is a type of [Resource] analogous to [ArrayMesh]. It contains vertex array-based geometry, divided in [i]surfaces[/i]. Each surface contains a completely separate array and a material used to draw it. Design wise, a mesh with multiple surfaces is preferred to a single surface, because objects created in 3D editing software commonly contain multiple materials.
|
||||
|
||||
Unlike its runtime counterpart, [ImporterMesh] contains mesh data before various import steps, such as lod and shadow mesh generation, have taken place. Modify surface data by calling [method clear], followed by [method add_surface] for each surface.
|
||||
</description>
|
||||
<tutorials>
|
||||
|
@ -254,7 +254,7 @@
|
||||
<param index="0" name="event" type="InputEvent" />
|
||||
<description>
|
||||
Feeds an [InputEvent] to the game. Can be used to artificially trigger input events from code. Also generates [method Node._input] calls.
|
||||
Example:
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var cancel_event = InputEventAction.new()
|
||||
@ -366,7 +366,7 @@
|
||||
<param index="0" name="position" type="Vector2" />
|
||||
<description>
|
||||
Sets the mouse position to the specified vector, provided in pixels and relative to an origin at the upper left corner of the currently focused Window Manager game window.
|
||||
Mouse position is clipped to the limits of the screen resolution, or to the limits of the game window if [enum MouseMode] is set to [code]MOUSE_MODE_CONFINED[/code] or [code]MOUSE_MODE_CONFINED_HIDDEN[/code].
|
||||
Mouse position is clipped to the limits of the screen resolution, or to the limits of the game window if [enum MouseMode] is set to [constant MOUSE_MODE_CONFINED] or [constant MOUSE_MODE_CONFINED_HIDDEN].
|
||||
</description>
|
||||
</method>
|
||||
</methods>
|
||||
|
@ -69,18 +69,18 @@
|
||||
The MIDI channel of this input event. There are 16 channels, so this value ranges from 0 to 15. MIDI channel 9 is reserved for the use with percussion instruments, the rest of the channels are for non-percussion instruments.
|
||||
</member>
|
||||
<member name="controller_number" type="int" setter="set_controller_number" getter="get_controller_number" default="0">
|
||||
If the message is [code]MIDI_MESSAGE_CONTROL_CHANGE[/code], this indicates the controller number, otherwise this is zero. Controllers include devices such as pedals and levers.
|
||||
If the message is [constant MIDI_MESSAGE_CONTROL_CHANGE], this indicates the controller number, otherwise this is zero. Controllers include devices such as pedals and levers.
|
||||
</member>
|
||||
<member name="controller_value" type="int" setter="set_controller_value" getter="get_controller_value" default="0">
|
||||
If the message is [code]MIDI_MESSAGE_CONTROL_CHANGE[/code], this indicates the controller value, otherwise this is zero. Controllers include devices such as pedals and levers.
|
||||
If the message is [constant MIDI_MESSAGE_CONTROL_CHANGE], this indicates the controller value, otherwise this is zero. Controllers include devices such as pedals and levers.
|
||||
</member>
|
||||
<member name="instrument" type="int" setter="set_instrument" getter="get_instrument" default="0">
|
||||
The instrument of this input event. This value ranges from 0 to 127. Refer to the instrument list on the General MIDI wikipedia article to see a list of instruments, except that this value is 0-index, so subtract one from every number on that chart. A standard piano will have an instrument number of 0.
|
||||
</member>
|
||||
<member name="message" type="int" setter="set_message" getter="get_message" enum="MIDIMessage" default="0">
|
||||
Returns a value indicating the type of message for this MIDI signal. This is a member of the [enum @GlobalScope.MIDIMessage] enum.
|
||||
Returns a value indicating the type of message for this MIDI signal. This is a member of the [enum MIDIMessage] enum.
|
||||
For MIDI messages between 0x80 and 0xEF, only the left half of the bits are returned as this value, as the other part is the channel (ex: 0x94 becomes 0x9). For MIDI messages from 0xF0 to 0xFF, the value is returned as-is.
|
||||
Notes will return [code]MIDI_MESSAGE_NOTE_ON[/code] when activated, but they might not always return [code]MIDI_MESSAGE_NOTE_OFF[/code] when deactivated, therefore your code should treat the input as stopped if some period of time has passed.
|
||||
Notes will return [constant MIDI_MESSAGE_NOTE_ON] when activated, but they might not always return [constant MIDI_MESSAGE_NOTE_OFF] when deactivated, therefore your code should treat the input as stopped if some period of time has passed.
|
||||
For more information, see the MIDI message status byte list chart linked above.
|
||||
</member>
|
||||
<member name="pitch" type="int" setter="set_pitch" getter="get_pitch" default="0">
|
||||
|
@ -54,7 +54,7 @@
|
||||
<param index="0" name="json_string" type="String" />
|
||||
<description>
|
||||
Attempts to parse the [param json_string] provided.
|
||||
Returns an [enum Error]. If the parse was successful, it returns [code]OK[/code] and the result can be retrieved using [member data]. If unsuccessful, use [method get_error_line] and [method get_error_message] for identifying the source of the failure.
|
||||
Returns an [enum Error]. If the parse was successful, it returns [constant OK] and the result can be retrieved using [member data]. If unsuccessful, use [method get_error_line] and [method get_error_message] for identifying the source of the failure.
|
||||
Non-static variant of [method parse_string], if you want custom error handling.
|
||||
</description>
|
||||
</method>
|
||||
|
@ -5,7 +5,7 @@
|
||||
</brief_description>
|
||||
<description>
|
||||
JavaScriptObject is used to interact with JavaScript objects retrieved or created via [method JavaScriptBridge.get_interface], [method JavaScriptBridge.create_object], or [method JavaScriptBridge.create_callback].
|
||||
Example:
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
extends Node
|
||||
|
||||
|
@ -630,7 +630,7 @@
|
||||
<return type="int" enum="Error" />
|
||||
<param index="0" name="method" type="StringName" />
|
||||
<description>
|
||||
Sends a remote procedure call request for the given [param method] to peers on the network (and locally), optionally sending all additional arguments as arguments to the method called by the RPC. The call request will only be received by nodes with the same [NodePath], including the exact same node name. Behaviour depends on the RPC configuration for the given method, see [method rpc_config]. Methods are not exposed to RPCs by default. Returns [code]null[/code].
|
||||
Sends a remote procedure call request for the given [param method] to peers on the network (and locally), optionally sending all additional arguments as arguments to the method called by the RPC. The call request will only be received by nodes with the same [NodePath], including the exact same node name. Behavior depends on the RPC configuration for the given method, see [method rpc_config]. Methods are not exposed to RPCs by default. Returns [code]null[/code].
|
||||
[b]Note:[/b] You can only safely use RPCs on clients after you received the [code]connected_to_server[/code] signal from the [MultiplayerAPI]. You also need to keep track of the connection state, either by the [MultiplayerAPI] signals like [code]server_disconnected[/code] or by checking [code]get_multiplayer().peer.get_connection_status() == CONNECTION_CONNECTED[/code].
|
||||
</description>
|
||||
</method>
|
||||
|
@ -134,7 +134,7 @@
|
||||
<method name="get_cache_dir" qualifiers="const">
|
||||
<return type="String" />
|
||||
<description>
|
||||
Returns the [i]global[/i] cache data directory according to the operating system's standards. On desktop platforms, this path can be overridden by setting the [code]XDG_CACHE_HOME[/code] environment variable before starting the project. See [url=$DOCS_URL/tutorials/io/data_paths.html]File paths in Godot projects[/url] in the documentation for more information. See also [method get_config_dir] and [method get_data_dir].
|
||||
Returns the [i]global[/i] cache data directory according to the operating system's standards. On the Linux/BSD platform, this path can be overridden by setting the [code]XDG_CACHE_HOME[/code] environment variable before starting the project. See [url=$DOCS_URL/tutorials/io/data_paths.html]File paths in Godot projects[/url] in the documentation for more information. See also [method get_config_dir] and [method get_data_dir].
|
||||
Not to be confused with [method get_user_data_dir], which returns the [i]project-specific[/i] user data path.
|
||||
</description>
|
||||
</method>
|
||||
@ -192,7 +192,7 @@
|
||||
<method name="get_config_dir" qualifiers="const">
|
||||
<return type="String" />
|
||||
<description>
|
||||
Returns the [i]global[/i] user configuration directory according to the operating system's standards. On desktop platforms, this path can be overridden by setting the [code]XDG_CONFIG_HOME[/code] environment variable before starting the project. See [url=$DOCS_URL/tutorials/io/data_paths.html]File paths in Godot projects[/url] in the documentation for more information. See also [method get_cache_dir] and [method get_data_dir].
|
||||
Returns the [i]global[/i] user configuration directory according to the operating system's standards. On the Linux/BSD platform, this path can be overridden by setting the [code]XDG_CONFIG_HOME[/code] environment variable before starting the project. See [url=$DOCS_URL/tutorials/io/data_paths.html]File paths in Godot projects[/url] in the documentation for more information. See also [method get_cache_dir] and [method get_data_dir].
|
||||
Not to be confused with [method get_user_data_dir], which returns the [i]project-specific[/i] user data path.
|
||||
</description>
|
||||
</method>
|
||||
@ -200,14 +200,14 @@
|
||||
<return type="PackedStringArray" />
|
||||
<description>
|
||||
Returns an array of MIDI device names.
|
||||
The returned array will be empty if the system MIDI driver has not previously been initialised with [method open_midi_inputs].
|
||||
The returned array will be empty if the system MIDI driver has not previously been initialized with [method open_midi_inputs].
|
||||
[b]Note:[/b] This method is implemented on Linux, macOS and Windows.
|
||||
</description>
|
||||
</method>
|
||||
<method name="get_data_dir" qualifiers="const">
|
||||
<return type="String" />
|
||||
<description>
|
||||
Returns the [i]global[/i] user data directory according to the operating system's standards. On desktop platforms, this path can be overridden by setting the [code]XDG_DATA_HOME[/code] environment variable before starting the project. See [url=$DOCS_URL/tutorials/io/data_paths.html]File paths in Godot projects[/url] in the documentation for more information. See also [method get_cache_dir] and [method get_config_dir].
|
||||
Returns the [i]global[/i] user data directory according to the operating system's standards. On the Linux/BSD platform, this path can be overridden by setting the [code]XDG_DATA_HOME[/code] environment variable before starting the project. See [url=$DOCS_URL/tutorials/io/data_paths.html]File paths in Godot projects[/url] in the documentation for more information. See also [method get_cache_dir] and [method get_config_dir].
|
||||
Not to be confused with [method get_user_data_dir], which returns the [i]project-specific[/i] user data path.
|
||||
</description>
|
||||
</method>
|
||||
|
@ -108,7 +108,8 @@
|
||||
<return type="Variant" />
|
||||
<param index="0" name="method" type="StringName" />
|
||||
<description>
|
||||
Calls the [param method] on the object and returns the result. This method supports a variable number of arguments, so parameters are passed as a comma separated list. Example:
|
||||
Calls the [param method] on the object and returns the result. This method supports a variable number of arguments, so parameters are passed as a comma separated list.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var node = Node3D.new()
|
||||
@ -126,7 +127,8 @@
|
||||
<return type="Variant" />
|
||||
<param index="0" name="method" type="StringName" />
|
||||
<description>
|
||||
Calls the [param method] on the object during idle time. This method supports a variable number of arguments, so parameters are passed as a comma separated list. Example:
|
||||
Calls the [param method] on the object during idle time. This method supports a variable number of arguments, so parameters are passed as a comma separated list.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var node = Node3D.new()
|
||||
@ -318,7 +320,8 @@
|
||||
<return type="int" enum="Error" />
|
||||
<param index="0" name="signal" type="StringName" />
|
||||
<description>
|
||||
Emits the given [param signal]. The signal must exist, so it should be a built-in signal of this class or one of its parent classes, or a user-defined signal. This method supports a variable number of arguments, so parameters are passed as a comma separated list. Example:
|
||||
Emits the given [param signal]. The signal must exist, so it should be a built-in signal of this class or one of its parent classes, or a user-defined signal. This method supports a variable number of arguments, so parameters are passed as a comma separated list.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
emit_signal("hit", "sword", 100)
|
||||
@ -366,7 +369,8 @@
|
||||
<return type="Variant" />
|
||||
<param index="0" name="property_path" type="NodePath" />
|
||||
<description>
|
||||
Gets the object's property indexed by the given [param property_path]. The path should be a [NodePath] relative to the current object and can use the colon character ([code]:[/code]) to access nested properties. Examples: [code]"position:x"[/code] or [code]"material:next_pass:blend_mode"[/code].
|
||||
Gets the object's property indexed by the given [param property_path]. The path should be a [NodePath] relative to the current object and can use the colon character ([code]:[/code]) to access nested properties.
|
||||
[b]Examples:[/b] [code]"position:x"[/code] or [code]"material:next_pass:blend_mode"[/code].
|
||||
[b]Note:[/b] Even though the method takes [NodePath] argument, it doesn't support actual paths to [Node]s in the scene tree, only colon-separated sub-property paths. For the purpose of nodes, use [method Node.get_node_and_resource] instead.
|
||||
</description>
|
||||
</method>
|
||||
@ -535,7 +539,8 @@
|
||||
<param index="0" name="property_path" type="NodePath" />
|
||||
<param index="1" name="value" type="Variant" />
|
||||
<description>
|
||||
Assigns a new value to the property identified by the [param property_path]. The path should be a [NodePath] relative to the current object and can use the colon character ([code]:[/code]) to access nested properties. Example:
|
||||
Assigns a new value to the property identified by the [param property_path]. The path should be a [NodePath] relative to the current object and can use the colon character ([code]:[/code]) to access nested properties.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var node = Node2D.new()
|
||||
|
@ -216,7 +216,7 @@
|
||||
<signal name="item_focused">
|
||||
<param index="0" name="index" type="int" />
|
||||
<description>
|
||||
Emitted when the user navigates to an item using the [code]ui_up[/code] or [code]ui_down[/code] actions. The index of the item selected is passed as argument.
|
||||
Emitted when the user navigates to an item using the [member ProjectSettings.input/ui_up] or [member ProjectSettings.input/ui_down] input actions. The index of the item selected is passed as argument.
|
||||
</description>
|
||||
</signal>
|
||||
<signal name="item_selected">
|
||||
|
@ -30,7 +30,7 @@
|
||||
</member>
|
||||
<member name="recovery_as_collision" type="bool" setter="set_recovery_as_collision_enabled" getter="is_recovery_as_collision_enabled" default="false">
|
||||
If set to [code]true[/code], any depenetration from the recovery phase is reported as a collision; this is used e.g. by [CharacterBody2D] for improving floor detection during floor snapping.
|
||||
If set to [code]false[/code], only collisions resulting from the motion are reported, which is generally the desired behaviour.
|
||||
If set to [code]false[/code], only collisions resulting from the motion are reported, which is generally the desired behavior.
|
||||
</member>
|
||||
</members>
|
||||
</class>
|
||||
|
@ -33,7 +33,7 @@
|
||||
</member>
|
||||
<member name="recovery_as_collision" type="bool" setter="set_recovery_as_collision_enabled" getter="is_recovery_as_collision_enabled" default="false">
|
||||
If set to [code]true[/code], any depenetration from the recovery phase is reported as a collision; this is used e.g. by [CharacterBody3D] for improving floor detection during floor snapping.
|
||||
If set to [code]false[/code], only collisions resulting from the motion are reported, which is generally the desired behaviour.
|
||||
If set to [code]false[/code], only collisions resulting from the motion are reported, which is generally the desired behavior.
|
||||
</member>
|
||||
</members>
|
||||
</class>
|
||||
|
@ -526,15 +526,14 @@
|
||||
<signal name="id_focused">
|
||||
<param index="0" name="id" type="int" />
|
||||
<description>
|
||||
Emitted when user navigated to an item of some [param id] using [code]ui_up[/code] or [code]ui_down[/code] action.
|
||||
Emitted when the user navigated to an item of some [param id] using the [member ProjectSettings.input/ui_up] or [member ProjectSettings.input/ui_down] input action.
|
||||
</description>
|
||||
</signal>
|
||||
<signal name="id_pressed">
|
||||
<param index="0" name="id" type="int" />
|
||||
<description>
|
||||
Emitted when an item of some [param id] is pressed or its accelerator is activated.
|
||||
|
||||
[b]Note:[/b] If [param id] is negative (either explicitly or due to overflow), this will return the correponding index instead.
|
||||
[b]Note:[/b] If [param id] is negative (either explicitly or due to overflow), this will return the corresponding index instead.
|
||||
</description>
|
||||
</signal>
|
||||
<signal name="index_pressed">
|
||||
|
@ -729,7 +729,7 @@
|
||||
Default font glyph sub-pixel positioning mode. See [member FontFile.subpixel_positioning].
|
||||
</member>
|
||||
<member name="gui/theme/default_theme_scale" type="float" setter="" getter="" default="1.0">
|
||||
The default scale factor for [Control]s, when not overriden by a [Theme].
|
||||
The default scale factor for [Control]s, when not overridden by a [Theme].
|
||||
[b]Note:[/b] This property is only read when the project starts. To change the default scale at runtime, set [member ThemeDB.fallback_base_scale] instead.
|
||||
</member>
|
||||
<member name="gui/theme/lcd_subpixel_layout" type="int" setter="" getter="" default="1">
|
||||
@ -1019,7 +1019,7 @@
|
||||
[b]Note:[/b] Default [code]ui_*[/code] actions cannot be removed as they are necessary for the internal logic of several [Control]s. The events assigned to the action can however be modified.
|
||||
</member>
|
||||
<member name="input/ui_text_toggle_insert_mode" type="Dictionary" setter="" getter="">
|
||||
Default [InputEventAction] to toggle [i]instert mode[/i] in a text field. While in insert mode, inserting new text overrides the character after the cursor, unless the next character is a new line.
|
||||
Default [InputEventAction] to toggle [i]insert mode[/i] in a text field. While in insert mode, inserting new text overrides the character after the cursor, unless the next character is a new line.
|
||||
[b]Note:[/b] Default [code]ui_*[/code] actions cannot be removed as they are necessary for the internal logic of several [Control]s. The events assigned to the action can however be modified.
|
||||
</member>
|
||||
<member name="input/ui_undo" type="Dictionary" setter="" getter="">
|
||||
@ -1891,7 +1891,7 @@
|
||||
Sets the quality for rough screen-space reflections. Turning off will make all screen space reflections sharp, while higher values make rough reflections look better.
|
||||
</member>
|
||||
<member name="rendering/environment/ssao/adaptive_target" type="float" setter="" getter="" default="0.5">
|
||||
Quality target to use when [member rendering/environment/ssao/quality] is set to [code]ULTRA[/code]. A value of [code]0.0[/code] provides a quality and speed similar to [code]MEDIUM[/code] while a value of [code]1.0[/code] provides much higher quality than any of the other settings at the cost of performance.
|
||||
Quality target to use when [member rendering/environment/ssao/quality] is set to [code]Ultra[/code]. A value of [code]0.0[/code] provides a quality and speed similar to [code]Medium[/code] while a value of [code]1.0[/code] provides much higher quality than any of the other settings at the cost of performance.
|
||||
</member>
|
||||
<member name="rendering/environment/ssao/blur_passes" type="int" setter="" getter="" default="2">
|
||||
Number of blur passes to use when computing screen-space ambient occlusion. A higher number will result in a smoother look, but will be slower to compute and will have less high-frequency detail.
|
||||
@ -1906,10 +1906,10 @@
|
||||
If [code]true[/code], screen-space ambient occlusion will be rendered at half size and then upscaled before being added to the scene. This is significantly faster but may miss small details. If [code]false[/code], screen-space ambient occlusion will be rendered at full size.
|
||||
</member>
|
||||
<member name="rendering/environment/ssao/quality" type="int" setter="" getter="" default="2">
|
||||
Sets the quality of the screen-space ambient occlusion effect. Higher values take more samples and so will result in better quality, at the cost of performance. Setting to [code]ULTRA[/code] will use the [member rendering/environment/ssao/adaptive_target] setting.
|
||||
Sets the quality of the screen-space ambient occlusion effect. Higher values take more samples and so will result in better quality, at the cost of performance. Setting to [code]Ultra[/code] will use the [member rendering/environment/ssao/adaptive_target] setting.
|
||||
</member>
|
||||
<member name="rendering/environment/ssil/adaptive_target" type="float" setter="" getter="" default="0.5">
|
||||
Quality target to use when [member rendering/environment/ssil/quality] is set to [code]ULTRA[/code]. A value of [code]0.0[/code] provides a quality and speed similar to [code]MEDIUM[/code] while a value of [code]1.0[/code] provides much higher quality than any of the other settings at the cost of performance. When using the adaptive target, the performance cost scales with the complexity of the scene.
|
||||
Quality target to use when [member rendering/environment/ssil/quality] is set to [code]Ultra[/code]. A value of [code]0.0[/code] provides a quality and speed similar to [code]Medium[/code] while a value of [code]1.0[/code] provides much higher quality than any of the other settings at the cost of performance. When using the adaptive target, the performance cost scales with the complexity of the scene.
|
||||
</member>
|
||||
<member name="rendering/environment/ssil/blur_passes" type="int" setter="" getter="" default="4">
|
||||
Number of blur passes to use when computing screen-space indirect lighting. A higher number will result in a smoother look, but will be slower to compute and will have less high-frequency detail.
|
||||
@ -1924,7 +1924,7 @@
|
||||
If [code]true[/code], screen-space indirect lighting will be rendered at half size and then upscaled before being added to the scene. This is significantly faster but may miss small details and may result in some objects appearing to glow at their edges.
|
||||
</member>
|
||||
<member name="rendering/environment/ssil/quality" type="int" setter="" getter="" default="2">
|
||||
Sets the quality of the screen-space indirect lighting effect. Higher values take more samples and so will result in better quality, at the cost of performance. Setting to [code]ULTRA[/code] will use the [member rendering/environment/ssil/adaptive_target] setting.
|
||||
Sets the quality of the screen-space indirect lighting effect. Higher values take more samples and so will result in better quality, at the cost of performance. Setting to [code]Ultra[/code] will use the [member rendering/environment/ssil/adaptive_target] setting.
|
||||
</member>
|
||||
<member name="rendering/environment/subsurface_scattering/subsurface_scattering_depth_scale" type="float" setter="" getter="" default="0.01">
|
||||
Scales the depth over which the subsurface scattering effect is applied. A high value may allow light to scatter into a part of the mesh or another mesh that is close in screen space but far in depth.
|
||||
@ -2261,7 +2261,7 @@
|
||||
Action map configuration to load by default.
|
||||
</member>
|
||||
<member name="xr/openxr/enabled" type="bool" setter="" getter="" default="false">
|
||||
If [code]true[/code] Godot will setup and initialise OpenXR on startup.
|
||||
If [code]true[/code] Godot will setup and initialize OpenXR on startup.
|
||||
</member>
|
||||
<member name="xr/openxr/form_factor" type="int" setter="" getter="" default=""0"">
|
||||
Specify whether OpenXR should be configured for an HMD or a hand held device.
|
||||
|
@ -13,7 +13,8 @@
|
||||
<method name="as_relative">
|
||||
<return type="PropertyTweener" />
|
||||
<description>
|
||||
When called, the final value will be used as a relative value instead. Example:
|
||||
When called, the final value will be used as a relative value instead.
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
var tween = get_tree().create_tween()
|
||||
tween.tween_property(self, "position", Vector2.RIGHT * 100, 1).as_relative() #the node will move by 100 pixels to the right
|
||||
@ -24,7 +25,8 @@
|
||||
<return type="PropertyTweener" />
|
||||
<param index="0" name="value" type="Variant" />
|
||||
<description>
|
||||
Sets a custom initial value to the [PropertyTweener]. Example:
|
||||
Sets a custom initial value to the [PropertyTweener].
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
var tween = get_tree().create_tween()
|
||||
tween.tween_property(self, "position", Vector2(200, 100), 1).from(Vector2(100, 100)) #this will move the node from position (100, 100) to (200, 100)
|
||||
|
@ -232,7 +232,7 @@
|
||||
<param index="0" name="draw_list" type="int" />
|
||||
<param index="1" name="color" type="Color" />
|
||||
<description>
|
||||
Sets blend constants for draw list, blend constants are used only if the graphics pipeline is created with [code]DYNAMIC_STATE_BLEND_CONSTANTS[/code] flag set.
|
||||
Sets blend constants for draw list, blend constants are used only if the graphics pipeline is created with [constant DYNAMIC_STATE_BLEND_CONSTANTS] flag set.
|
||||
</description>
|
||||
</method>
|
||||
<method name="draw_list_set_push_constant">
|
||||
|
@ -24,7 +24,7 @@
|
||||
<param index="0" name="subresources" type="bool" default="false" />
|
||||
<description>
|
||||
Duplicates this resource, returning a new resource with its [code]export[/code]ed or [constant PROPERTY_USAGE_STORAGE] properties copied from the original.
|
||||
If [param subresources] is [code]false[/code], a shallow copy is returned. Nested resources within subresources are not duplicated and are shared from the original resource. This behavior can be overriden by the [constant PROPERTY_USAGE_DO_NOT_SHARE_ON_DUPLICATE] flag.
|
||||
If [param subresources] is [code]false[/code], a shallow copy is returned. Nested resources within subresources are not duplicated and are shared from the original resource. This behavior can be overridden by the [constant PROPERTY_USAGE_DO_NOT_SHARE_ON_DUPLICATE] flag.
|
||||
[b]Note:[/b] For custom resources, this method will fail if [method Object._init] has been defined with required parameters.
|
||||
</description>
|
||||
</method>
|
||||
@ -51,7 +51,7 @@
|
||||
<method name="get_rid" qualifiers="const">
|
||||
<return type="RID" />
|
||||
<description>
|
||||
Returns the [RID] of this resource (or an empty RID). Many resources (such as [Texture2D], [Mesh], and so on) are high-level abstractions of resources stored in a specialised server ([DisplayServer], [RenderingServer], etc.), so this function will return the original [RID].
|
||||
Returns the [RID] of this resource (or an empty RID). Many resources (such as [Texture2D], [Mesh], and so on) are high-level abstractions of resources stored in a specialized server ([DisplayServer], [RenderingServer], etc.), so this function will return the original [RID].
|
||||
</description>
|
||||
</method>
|
||||
<method name="setup_local_to_scene">
|
||||
|
@ -6,7 +6,7 @@
|
||||
<description>
|
||||
A ScrollContainer node meant to contain a [Control] child.
|
||||
ScrollContainers will automatically create a scrollbar child ([HScrollBar], [VScrollBar], or both) when needed and will only draw the Control within the ScrollContainer area. Scrollbars will automatically be drawn at the right (for vertical) or bottom (for horizontal) and will enable dragging to move the viewable Control (and its children) within the ScrollContainer. Scrollbars will also automatically resize the grabber based on the [member Control.custom_minimum_size] of the Control relative to the ScrollContainer.
|
||||
Works great with a [Panel] control. You can set [code]EXPAND[/code] on the children's size flags, so they will upscale to the ScrollContainer's size if it's larger (scroll is invisible for the chosen dimension).
|
||||
Works great with a [Panel] control. You can set [constant Control.SIZE_EXPAND] on the children's size flags, so they will upscale to the ScrollContainer's size if it's larger (scroll is invisible for the chosen dimension).
|
||||
</description>
|
||||
<tutorials>
|
||||
<link title="GUI containers">$DOCS_URL/tutorials/ui/gui_containers.html</link>
|
||||
|
@ -13,7 +13,8 @@
|
||||
<method name="get_rect" qualifiers="const">
|
||||
<return type="Rect2" />
|
||||
<description>
|
||||
Returns a [Rect2] representing the Sprite2D's boundary in local coordinates. Can be used to detect if the Sprite2D was clicked. Example:
|
||||
Returns a [Rect2] representing the Sprite2D's boundary in local coordinates. Can be used to detect if the Sprite2D was clicked.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
func _input(event):
|
||||
|
@ -44,7 +44,7 @@
|
||||
<return type="Array" />
|
||||
<param index="0" name="bytes" type="int" />
|
||||
<description>
|
||||
Returns a chunk data with the received bytes. The number of bytes to be received can be requested in the [param bytes] argument. If not enough bytes are available, the function will block until the desired amount is received. This function returns two values, an [enum @GlobalScope.Error] code and a data array.
|
||||
Returns a chunk data with the received bytes. The number of bytes to be received can be requested in the [param bytes] argument. If not enough bytes are available, the function will block until the desired amount is received. This function returns two values, an [enum Error] code and a data array.
|
||||
</description>
|
||||
</method>
|
||||
<method name="get_double">
|
||||
@ -63,7 +63,7 @@
|
||||
<return type="Array" />
|
||||
<param index="0" name="bytes" type="int" />
|
||||
<description>
|
||||
Returns a chunk data with the received bytes. The number 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 [enum @GlobalScope.Error] code, and a data array.
|
||||
Returns a chunk data with the received bytes. The number 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 [enum Error] code, and a data array.
|
||||
</description>
|
||||
</method>
|
||||
<method name="get_string">
|
||||
@ -144,7 +144,7 @@
|
||||
<return type="int" enum="Error" />
|
||||
<param index="0" name="data" type="PackedByteArray" />
|
||||
<description>
|
||||
Sends a chunk of data through the connection, blocking if necessary until the data is done sending. This function returns an [enum @GlobalScope.Error] code.
|
||||
Sends a chunk of data through the connection, blocking if necessary until the data is done sending. This function returns an [enum Error] code.
|
||||
</description>
|
||||
</method>
|
||||
<method name="put_double">
|
||||
@ -165,7 +165,7 @@
|
||||
<return type="Array" />
|
||||
<param index="0" name="data" type="PackedByteArray" />
|
||||
<description>
|
||||
Sends 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 [enum @GlobalScope.Error] code and an integer, describing how much data was actually sent.
|
||||
Sends 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 [enum Error] code and an integer, describing how much data was actually sent.
|
||||
</description>
|
||||
</method>
|
||||
<method name="put_string">
|
||||
|
@ -239,7 +239,7 @@
|
||||
<description>
|
||||
Splits a string using a [param delimiter] and returns a substring at index [param slice]. Returns an empty string if the index doesn't exist.
|
||||
This is a more performant alternative to [method split] for cases when you need only one element from the array at a fixed index.
|
||||
Example:
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
print("i/am/example/string".get_slice("/", 2)) # Prints 'example'.
|
||||
[/codeblock]
|
||||
@ -408,7 +408,7 @@
|
||||
<param index="0" name="parts" type="PackedStringArray" />
|
||||
<description>
|
||||
Returns a [String] which is the concatenation of the [param parts]. The separator between elements is the string providing this method.
|
||||
Example:
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
print(", ".join(["One", "Two", "Three", "Four"]))
|
||||
@ -430,7 +430,7 @@
|
||||
<param index="0" name="length" type="int" />
|
||||
<description>
|
||||
Returns a number of characters from the left of the string. If negative [param length] is used, the characters are counted downwards from [String]'s length.
|
||||
Examples:
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
print("sample text".left(3)) #prints "sam"
|
||||
print("sample text".left(-3)) #prints "sample t"
|
||||
@ -514,7 +514,7 @@
|
||||
Converts a [float] to a string representation of a decimal number.
|
||||
The number of decimal places can be specified with [param decimals]. If [param decimals] is [code]-1[/code] (default), decimal places will be automatically adjusted so that the string representation has 14 significant digits (counting both digits to the left and the right of the decimal point).
|
||||
Trailing zeros are not included in the string. The last digit will be rounded and not truncated.
|
||||
Some examples:
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
String.num(3.141593) # "3.141593"
|
||||
String.num(3.141593, 3) # "3.142"
|
||||
@ -617,7 +617,7 @@
|
||||
<param index="0" name="length" type="int" />
|
||||
<description>
|
||||
Returns a number of characters from the right of the string. If negative [param length] is used, the characters are counted downwards from [String]'s length.
|
||||
Examples:
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
print("sample text".right(3)) #prints "ext"
|
||||
print("sample text".right(-3)) #prints "ple text"
|
||||
@ -642,7 +642,7 @@
|
||||
The splits in the returned array are sorted in the same order as the original string, from left to right.
|
||||
If [param allow_empty] is [code]true[/code], and there are two adjacent delimiters in the string, it will add an empty string to the array of substrings at this position.
|
||||
If [param maxsplit] is specified, it defines the number of splits to do from the right up to [param maxsplit]. The default value of 0 means that all items are split, thus giving the same result as [method split].
|
||||
Example:
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var some_string = "One,Two,Three,Four"
|
||||
@ -718,7 +718,7 @@
|
||||
If [param allow_empty] is [code]true[/code], and there are two adjacent delimiters in the string, it will add an empty string to the array of substrings at this position.
|
||||
If [param maxsplit] is specified, it defines the number of splits to do from the left up to [param maxsplit]. The default value of [code]0[/code] means that all items are split.
|
||||
If you need only one element from the array at a specific index, [method get_slice] is a more performant option.
|
||||
Example:
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var some_string = "One,Two,Three,Four"
|
||||
|
@ -9,7 +9,8 @@
|
||||
- Border width (individual width for each border)
|
||||
- Rounded corners (individual radius for each corner)
|
||||
- Shadow (with blur and offset)
|
||||
Setting corner radius to high values is allowed. As soon as corners overlap, the stylebox will switch to a relative system. Example:
|
||||
Setting corner radius to high values is allowed. As soon as corners overlap, the stylebox will switch to a relative system.
|
||||
[b]Example:[/b]
|
||||
[codeblock]
|
||||
height = 30
|
||||
corner_radius_top_left = 50
|
||||
|
@ -275,28 +275,28 @@
|
||||
</methods>
|
||||
<constants>
|
||||
<constant name="CUSTOM_RGBA8_UNORM" value="0" enum="CustomFormat">
|
||||
Limits range of data passed to `set_custom` to unsigned normalized 0 to 1 stored in 8 bits per channel. See [constant Mesh.ARRAY_CUSTOM_RGBA8_UNORM].
|
||||
Limits range of data passed to [method set_custom] to unsigned normalized 0 to 1 stored in 8 bits per channel. See [constant Mesh.ARRAY_CUSTOM_RGBA8_UNORM].
|
||||
</constant>
|
||||
<constant name="CUSTOM_RGBA8_SNORM" value="1" enum="CustomFormat">
|
||||
Limits range of data passed to `set_custom` to signed normalized -1 to 1 stored in 8 bits per channel. See [constant Mesh.ARRAY_CUSTOM_RGBA8_SNORM].
|
||||
Limits range of data passed to [method set_custom] to signed normalized -1 to 1 stored in 8 bits per channel. See [constant Mesh.ARRAY_CUSTOM_RGBA8_SNORM].
|
||||
</constant>
|
||||
<constant name="CUSTOM_RG_HALF" value="2" enum="CustomFormat">
|
||||
Stores data passed to `set_custom` as half precision floats, and uses only red and green color channels. See [constant Mesh.ARRAY_CUSTOM_RG_HALF].
|
||||
Stores data passed to [method set_custom] as half precision floats, and uses only red and green color channels. See [constant Mesh.ARRAY_CUSTOM_RG_HALF].
|
||||
</constant>
|
||||
<constant name="CUSTOM_RGBA_HALF" value="3" enum="CustomFormat">
|
||||
Stores data passed to `set_custom` as half precision floats and uses all color channels. See [constant Mesh.ARRAY_CUSTOM_RGBA_HALF].
|
||||
Stores data passed to [method set_custom] as half precision floats and uses all color channels. See [constant Mesh.ARRAY_CUSTOM_RGBA_HALF].
|
||||
</constant>
|
||||
<constant name="CUSTOM_R_FLOAT" value="4" enum="CustomFormat">
|
||||
Stores data passed to `set_custom` as full precision floats, and uses only red color channel. See [constant Mesh.ARRAY_CUSTOM_R_FLOAT].
|
||||
Stores data passed to [method set_custom] as full precision floats, and uses only red color channel. See [constant Mesh.ARRAY_CUSTOM_R_FLOAT].
|
||||
</constant>
|
||||
<constant name="CUSTOM_RG_FLOAT" value="5" enum="CustomFormat">
|
||||
Stores data passed to `set_custom` as full precision floats, and uses only red and green color channels. See [constant Mesh.ARRAY_CUSTOM_RG_FLOAT].
|
||||
Stores data passed to [method set_custom] as full precision floats, and uses only red and green color channels. See [constant Mesh.ARRAY_CUSTOM_RG_FLOAT].
|
||||
</constant>
|
||||
<constant name="CUSTOM_RGB_FLOAT" value="6" enum="CustomFormat">
|
||||
Stores data passed to `set_custom` as full precision floats, and uses only red, green and blue color channels. See [constant Mesh.ARRAY_CUSTOM_RGB_FLOAT].
|
||||
Stores data passed to [method set_custom] as full precision floats, and uses only red, green and blue color channels. See [constant Mesh.ARRAY_CUSTOM_RGB_FLOAT].
|
||||
</constant>
|
||||
<constant name="CUSTOM_RGBA_FLOAT" value="7" enum="CustomFormat">
|
||||
Stores data passed to `set_custom` as full precision floats, and uses all color channels. See [constant Mesh.ARRAY_CUSTOM_RGBA_FLOAT].
|
||||
Stores data passed to [method set_custom] as full precision floats, and uses all color channels. See [constant Mesh.ARRAY_CUSTOM_RGBA_FLOAT].
|
||||
</constant>
|
||||
<constant name="CUSTOM_MAX" value="8" enum="CustomFormat">
|
||||
Used to indicate a disabled custom channel.
|
||||
|
@ -217,7 +217,7 @@
|
||||
</theme_item>
|
||||
<theme_item name="side_margin" data_type="constant" type="int" default="8">
|
||||
The space at the left or right edges of the tab bar, accordingly with the current [member tab_alignment].
|
||||
The margin is ignored with [code]ALIGNMENT_RIGHT[/code] if the tabs are clipped (see [member clip_tabs]) or a popup has been set (see [method set_popup]). The margin is always ignored with [code]ALIGNMENT_CENTER[/code].
|
||||
The margin is ignored with [constant TabBar.ALIGNMENT_RIGHT] if the tabs are clipped (see [member clip_tabs]) or a popup has been set (see [method set_popup]). The margin is always ignored with [constant TabBar.ALIGNMENT_CENTER].
|
||||
</theme_item>
|
||||
<theme_item name="font" data_type="font" type="Font">
|
||||
The font used to draw tab names.
|
||||
|
@ -1416,7 +1416,7 @@
|
||||
<param index="0" name="shaped" type="RID" />
|
||||
<param index="1" name="direction" type="int" enum="TextServer.Direction" default="0" />
|
||||
<description>
|
||||
Sets desired text direction. If set to [code]TEXT_DIRECTION_AUTO[/code], direction will be detected based on the buffer contents and current locale.
|
||||
Sets desired text direction. If set to [constant DIRECTION_AUTO], direction will be detected based on the buffer contents and current locale.
|
||||
[b]Note:[/b] Direction is ignored if server does not support [constant FEATURE_BIDI_LAYOUT] feature (supported by [TextServerAdvanced]).
|
||||
</description>
|
||||
</method>
|
||||
@ -1823,7 +1823,7 @@
|
||||
Font have fixed-width characters.
|
||||
</constant>
|
||||
<constant name="STRUCTURED_TEXT_DEFAULT" value="0" enum="StructuredTextParser">
|
||||
Use default behavior. Same as [code]STRUCTURED_TEXT_NONE[/code] unless specified otherwise in the control description.
|
||||
Use default behavior. Same as [constant STRUCTURED_TEXT_NONE] unless specified otherwise in the control description.
|
||||
</constant>
|
||||
<constant name="STRUCTURED_TEXT_URI" value="1" enum="StructuredTextParser">
|
||||
BiDi override for URI.
|
||||
|
@ -7,7 +7,6 @@
|
||||
A TileSet is a library of tiles for a [TileMap]. A TileSet handles a list of [TileSetSource], each of them storing a set of tiles.
|
||||
Tiles can either be from a [TileSetAtlasSource], that render tiles out of a texture with support for physics, navigation, etc... or from a [TileSetScenesCollectionSource] which exposes scene-based tiles.
|
||||
Tiles are referenced by using three IDs: their source ID, their atlas coordinates ID and their alternative tile ID.
|
||||
|
||||
A TileSet can be configured so that its tiles expose more or less properties. To do so, the TileSet resources uses property layers, that you can add or remove depending on your needs.
|
||||
For example, adding a physics layer allows giving collision shapes to your tiles. Each layer having dedicated properties (physics layer an mask), you may add several TileSet physics layers for each type of collision you need.
|
||||
See the functions to add new layers for more information.
|
||||
|
@ -6,9 +6,7 @@
|
||||
<description>
|
||||
An atlas is a grid of tiles laid out on a texture. Each tile in the grid must be exposed using [method create_tile]. Those tiles are then indexed using their coordinates in the grid.
|
||||
Each tile can also have a size in the grid coordinates, making it more or less cells in the atlas.
|
||||
|
||||
Alternatives version of a tile can be created using [method create_alternative_tile], which are then indexed using an alternative ID. The main tile (the one in the grid), is accessed with an alternative ID equal to 0.
|
||||
|
||||
Each tile alternate has a set of properties that is defined by the source's [TileSet] layers. Those properties are stored in a TileData object that can be accessed and modified using [method get_tile_data].
|
||||
As TileData properties are stored directly in the TileSetAtlasSource resource, their properties might also be set using [code]TileSetAtlasSource.set("<coords_x>:<coords_y>/<alternative_id>/<tile_data_property>")[/code].
|
||||
</description>
|
||||
|
@ -7,7 +7,6 @@
|
||||
Exposes a set of tiles for a [TileSet] resource.
|
||||
Tiles in a source are indexed with two IDs, coordinates ID (of type Vector2i) and an alternative ID (of type int), named according to their use in the [TileSetAtlasSource] class.
|
||||
Depending on the TileSet source type, those IDs might have restrictions on their values, this is why the base [TileSetSource] class only exposes getters for them.
|
||||
|
||||
You can iterate over all tiles exposed by a TileSetSource by first iterating over coordinates IDs using [method get_tiles_count] and [method get_tile_id], then over alternative IDs using [method get_alternative_tiles_count] and [method get_alternative_tile_id].
|
||||
</description>
|
||||
<tutorials>
|
||||
|
@ -251,7 +251,7 @@
|
||||
<param index="0" name="column" type="int" />
|
||||
<param index="1" name="min_width" type="int" />
|
||||
<description>
|
||||
Overrides the calculated minimum width of a column. It can be set to `0` to restore the default behavior. Columns that have the "Expand" flag will use their "min_width" in a similar fashion to [member Control.size_flags_stretch_ratio].
|
||||
Overrides the calculated minimum width of a column. It can be set to [code]0[/code] to restore the default behavior. Columns that have the "Expand" flag will use their "min_width" in a similar fashion to [member Control.size_flags_stretch_ratio].
|
||||
</description>
|
||||
</method>
|
||||
<method name="set_column_expand">
|
||||
|
@ -177,7 +177,8 @@
|
||||
<method name="parallel">
|
||||
<return type="Tween" />
|
||||
<description>
|
||||
Makes the next [Tweener] run parallelly to the previous one. Example:
|
||||
Makes the next [Tweener] run parallelly to the previous one.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var tween = create_tween()
|
||||
@ -272,7 +273,7 @@
|
||||
<param index="0" name="callback" type="Callable" />
|
||||
<description>
|
||||
Creates and appends a [CallbackTweener]. This method can be used to call an arbitrary method in any object. Use [method Callable.bind] to bind additional arguments for the call.
|
||||
Example: object that keeps shooting every 1 second.
|
||||
[b]Example:[/b] Object that keeps shooting every 1 second:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var tween = get_tree().create_tween().set_loops()
|
||||
@ -283,7 +284,7 @@
|
||||
tween.TweenCallback(new Callable(Shoot)).SetDelay(1.0f);
|
||||
[/csharp]
|
||||
[/codeblocks]
|
||||
Example: turning a sprite red and then blue, with 2 second delay.
|
||||
[b]Example:[/b] Turning a sprite red and then blue, with 2 second delay:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var tween = get_tree().create_tween()
|
||||
@ -304,7 +305,7 @@
|
||||
<param index="0" name="time" type="float" />
|
||||
<description>
|
||||
Creates and appends an [IntervalTweener]. This method can be used to create delays in the tween animation, as an alternative to using the delay in other [Tweener]s, or when there's no animation (in which case the [Tween] acts as a timer). [param time] is the length of the interval, in seconds.
|
||||
Example: creating an interval in code execution.
|
||||
[b]Example:[/b] Creating an interval in code execution:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
# ... some code
|
||||
@ -317,7 +318,7 @@
|
||||
// ... more code
|
||||
[/csharp]
|
||||
[/codeblocks]
|
||||
Example: creating an object that moves back and forth and jumps every few seconds.
|
||||
[b]Example:[/b] Creating an object that moves back and forth and jumps every few seconds:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var tween = create_tween().set_loops()
|
||||
@ -348,7 +349,7 @@
|
||||
<param index="3" name="duration" type="float" />
|
||||
<description>
|
||||
Creates and appends a [MethodTweener]. This method is similar to a combination of [method tween_callback] and [method tween_property]. It calls a method over time with a tweened value provided as an argument. The value is tweened between [param from] and [param to] over the time specified by [param duration], in seconds. Use [method Callable.bind] to bind additional arguments for the call. You can use [method MethodTweener.set_ease] and [method MethodTweener.set_trans] to tweak the easing and transition of the value or [method MethodTweener.set_delay] to delay the tweening.
|
||||
Example: making a 3D object look from one point to another point.
|
||||
[b]Example:[/b] Making a 3D object look from one point to another point:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var tween = create_tween()
|
||||
@ -359,7 +360,7 @@
|
||||
tween.TweenMethod(new Callable(() => LookAt(Vector3.Up)), new Vector3(-1.0f, 0.0f, -1.0f), new Vector3(1.0f, 0.0f, -1.0f), 1.0f); // The LookAt() method takes up vector as second argument.
|
||||
[/csharp]
|
||||
[/codeblocks]
|
||||
Example: setting a text of a [Label], using an intermediate method and after a delay.
|
||||
[b]Example:[/b] Setting the text of a [Label], using an intermediate method and after a delay:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
func _ready():
|
||||
@ -393,7 +394,8 @@
|
||||
<param index="2" name="final_val" type="Variant" />
|
||||
<param index="3" name="duration" type="float" />
|
||||
<description>
|
||||
Creates and appends a [PropertyTweener]. This method tweens a [param property] of an [param object] between an initial value and [param final_val] in a span of time equal to [param duration], in seconds. The initial value by default is the property's value at the time the tweening of the [PropertyTweener] starts. For example:
|
||||
Creates and appends a [PropertyTweener]. This method tweens a [param property] of an [param object] between an initial value and [param final_val] in a span of time equal to [param duration], in seconds. The initial value by default is the property's value at the time the tweening of the [PropertyTweener] starts.
|
||||
[b]Example:[/b]
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var tween = create_tween()
|
||||
@ -408,7 +410,7 @@
|
||||
[/codeblocks]
|
||||
will move the sprite to position (100, 200) and then to (200, 300). If you use [method PropertyTweener.from] or [method PropertyTweener.from_current], the starting position will be overwritten by the given value instead. See other methods in [PropertyTweener] to see how the tweening can be tweaked further.
|
||||
[b]Note:[/b] You can find the correct property name by hovering over the property in the Inspector. You can also provide the components of a property directly by using [code]"property:component"[/code] (eg. [code]position:x[/code]), where it would only apply to that particular component.
|
||||
Example: moving object twice from the same position, with different transition types.
|
||||
[b]Example:[/b] Moving an object twice from the same position, with different transition types:
|
||||
[codeblocks]
|
||||
[gdscript]
|
||||
var tween = create_tween()
|
||||
|
@ -19,7 +19,7 @@
|
||||
</methods>
|
||||
<members>
|
||||
<member name="input_name" type="String" setter="set_input_name" getter="get_input_name" default=""[None]"">
|
||||
One of the several input constants in lower-case style like: "vertex"([code]VERTEX[/code]) or "point_size"([code]POINT_SIZE[/code]).
|
||||
One of the several input constants in lower-case style like: "vertex" ([code]VERTEX[/code]) or "point_size" ([code]POINT_SIZE[/code]).
|
||||
</member>
|
||||
</members>
|
||||
<signals>
|
||||
|
@ -32,7 +32,7 @@
|
||||
<method name="get_play_area" qualifiers="const">
|
||||
<return type="PackedVector3Array" />
|
||||
<description>
|
||||
Returns an array of vectors that denotes the physical play area mapped to the virtual space around the [XROrigin3D] point. The points form a convex polygon that can be used to react to or visualise the play area. This returns an empty array if this feature is not supported or if the information is not yet available.
|
||||
Returns an array of vectors that denotes the physical play area mapped to the virtual space around the [XROrigin3D] point. The points form a convex polygon that can be used to react to or visualize the play area. This returns an empty array if this feature is not supported or if the information is not yet available.
|
||||
</description>
|
||||
</method>
|
||||
<method name="get_render_target_size">
|
||||
@ -66,7 +66,7 @@
|
||||
<method name="is_initialized" qualifiers="const">
|
||||
<return type="bool" />
|
||||
<description>
|
||||
Is [code]true[/code] if this interface has been initialised.
|
||||
Is [code]true[/code] if this interface has been initialized.
|
||||
</description>
|
||||
</method>
|
||||
<method name="is_passthrough_enabled">
|
||||
|
@ -138,7 +138,7 @@
|
||||
<method name="_is_initialized" qualifiers="virtual const">
|
||||
<return type="bool" />
|
||||
<description>
|
||||
Returns [code]true[/code] if this interface has been initialised.
|
||||
Returns [code]true[/code] if this interface has been initialized.
|
||||
</description>
|
||||
</method>
|
||||
<method name="_notification" qualifiers="virtual">
|
||||
|
@ -43,7 +43,7 @@ MIDIDriverALSAMidi::MessageCategory MIDIDriverALSAMidi::msg_category(uint8_t msg
|
||||
} else if (msg_part >= 0xf0) {
|
||||
// System Exclusive begin/end are specified as System Common Category messages,
|
||||
// but we separate them here and give them their own categories as their
|
||||
// behaviour is significantly different.
|
||||
// behavior is significantly different.
|
||||
if (msg_part == 0xf0) {
|
||||
return MessageCategory::SysExBegin;
|
||||
} else if (msg_part == 0xf7) {
|
||||
|
@ -75,10 +75,10 @@ private:
|
||||
CharString general_defines;
|
||||
|
||||
// A version is a high-level construct which is a combination of built-in and user-defined shader code, Each user-created Shader makes one version
|
||||
// Variants use #ifdefs to toggle behaviour on and off to change behaviour of the shader
|
||||
// Variants use #ifdefs to toggle behavior on and off to change behavior of the shader
|
||||
// All variants are compiled each time a new version is created
|
||||
// Specializations use #ifdefs to toggle behaviour on and off for performance, on supporting hardware, they will compile a version with everything enabled, and then compile more copies to improve performance
|
||||
// Use specializations to enable and disabled advanced features, use variants to toggle behaviour when different data may be used (e.g. using a samplerArray vs a sampler, or doing a depth prepass vs a color pass)
|
||||
// Specializations use #ifdefs to toggle behavior on and off for performance, on supporting hardware, they will compile a version with everything enabled, and then compile more copies to improve performance
|
||||
// Use specializations to enable and disabled advanced features, use variants to toggle behavior when different data may be used (e.g. using a samplerArray vs a sampler, or doing a depth prepass vs a color pass)
|
||||
struct Version {
|
||||
Vector<StringName> texture_uniforms;
|
||||
CharString uniforms;
|
||||
|
@ -1336,7 +1336,7 @@ Error VulkanContext::_create_device() {
|
||||
vulkan11features.shaderDrawParameters = 0;
|
||||
nextptr = &vulkan11features;
|
||||
} else {
|
||||
// On Vulkan 1.0 and 1.1 we use our older structs to initialise these features.
|
||||
// On Vulkan 1.0 and 1.1 we use our older structs to initialize these features.
|
||||
storage_feature.sType = VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_16BIT_STORAGE_FEATURES_KHR;
|
||||
storage_feature.pNext = nextptr;
|
||||
storage_feature.storageBuffer16BitAccess = storage_buffer_capabilities.storage_buffer_16_bit_access_is_supported;
|
||||
@ -1483,7 +1483,7 @@ Error VulkanContext::_initialize_queues(VkSurfaceKHR p_surface) {
|
||||
color_space = surfFormats[0].colorSpace;
|
||||
} else {
|
||||
// These should be ordered with the ones we want to use on top and fallback modes further down
|
||||
// we want a 32bit RGBA unsigned normalised buffer or similar.
|
||||
// we want a 32bit RGBA unsigned normalized buffer or similar.
|
||||
const VkFormat allowed_formats[] = {
|
||||
VK_FORMAT_B8G8R8A8_UNORM,
|
||||
VK_FORMAT_R8G8B8A8_UNORM
|
||||
|
@ -338,7 +338,7 @@ float EditorAudioBus::_normalized_volume_to_scaled_db(float normalized) {
|
||||
* values to relative decibal values.
|
||||
* One formula is an exponential graph which intends to counteract
|
||||
* the logarithmic nature of human hearing. This is an approximation
|
||||
* of the behaviour of a 'logarithmic potentiometer' found on most
|
||||
* of the behavior of a 'logarithmic potentiometer' found on most
|
||||
* musical instruments and also emulated in popular software.
|
||||
* The other two equations are hand-tuned linear tapers that intend to
|
||||
* try to ease the exponential equation in areas where it makes sense.*/
|
||||
|
@ -375,7 +375,7 @@ void EditorHelp::_add_method(const DocData::MethodDoc &p_method, bool p_overview
|
||||
if (qualifier == "vararg") {
|
||||
hint = TTR("This method supports a variable number of arguments.");
|
||||
} else if (qualifier == "virtual") {
|
||||
hint = TTR("This method is called by the engine.\nIt can be overriden to customise built-in behavior.");
|
||||
hint = TTR("This method is called by the engine.\nIt can be overridden to customize built-in behavior.");
|
||||
} else if (qualifier == "const") {
|
||||
hint = TTR("This method has no side effects.\nIt does not modify the object in any way.");
|
||||
} else if (qualifier == "static") {
|
||||
|
@ -227,7 +227,7 @@ void EditorLog::add_message(const String &p_msg, MessageType p_type) {
|
||||
// Make text split by new lines their own message.
|
||||
// See #41321 for reasoning. At time of writing, multiple print()'s in running projects
|
||||
// get grouped together and sent to the editor log as one message. This can mess with the
|
||||
// search functionality (see the comments on the PR above for more details). This behaviour
|
||||
// search functionality (see the comments on the PR above for more details). This behavior
|
||||
// also matches that of other IDE's.
|
||||
Vector<String> lines = p_msg.split("\n", true);
|
||||
|
||||
|
@ -466,7 +466,7 @@ void EditorPropertyArray::drop_data_fw(const Point2 &p_point, const Variant &p_d
|
||||
|
||||
Variant array = object->get_array();
|
||||
|
||||
// Handle the case where array is not initialised yet.
|
||||
// Handle the case where array is not initialized yet.
|
||||
if (!array.is_array()) {
|
||||
Callable::CallError ce;
|
||||
Variant::construct(array_type, array, nullptr, 0, ce);
|
||||
|
@ -159,7 +159,7 @@ bool EditorSettings::_get(const StringName &p_name, Variant &r_ret) const {
|
||||
|
||||
if (!sc->has_meta("original")) {
|
||||
// Getting the meta when it doesn't exist will return an empty array. If the 'shortcut_events' have been cleared,
|
||||
// we still want save the shortcut in this case so that shortcuts that the user has customised are not reset,
|
||||
// we still want save the shortcut in this case so that shortcuts that the user has customized are not reset,
|
||||
// even if the 'original' has not been populated yet. This can happen when calling save() from the Project Manager.
|
||||
save_array.push_back(dict);
|
||||
continue;
|
||||
|
@ -430,7 +430,7 @@ void VersionControlEditorPlugin::_discard_file(String p_file_path, EditorVCSInte
|
||||
CHECK_PLUGIN_INITIALIZED();
|
||||
EditorVCSInterface::get_singleton()->discard_file(p_file_path);
|
||||
}
|
||||
// FIXIT: The project.godot file shows weird behaviour
|
||||
// FIXIT: The project.godot file shows weird behavior
|
||||
EditorFileSystem::get_singleton()->update_file(p_file_path);
|
||||
}
|
||||
|
||||
|
@ -620,7 +620,7 @@ int Main::test_entrypoint(int argc, char *argv[], bool &tests_need_run) {
|
||||
* - setup(execpath, argc, argv, p_second_phase) is the main entry point for all platforms,
|
||||
* responsible for the initialization of all low level singletons and core types, and parsing
|
||||
* command line arguments to configure things accordingly.
|
||||
* If p_second_phase is true, it will chain into setup2() (default behaviour). This is
|
||||
* If p_second_phase is true, it will chain into setup2() (default behavior). This is
|
||||
* disabled on some platforms (Android, iOS, UWP) which trigger the second step in their
|
||||
* own time.
|
||||
*
|
||||
|
@ -76,7 +76,7 @@ public:
|
||||
static void cleanup(bool p_force = false);
|
||||
};
|
||||
|
||||
// Test main override is for the testing behaviour.
|
||||
// Test main override is for the testing behavior.
|
||||
#define TEST_MAIN_OVERRIDE \
|
||||
bool run_test = false; \
|
||||
int return_code = Main::test_entrypoint(argc, argv, run_test); \
|
||||
|
@ -1,5 +1,5 @@
|
||||
#!/bin/sh
|
||||
SKIP_LIST="./thirdparty,*.gen.*,*.po,*.pot,package-lock.json,./core/string/locales.h,./DONORS.md,./misc/dist/linux/org.godotengine.Godot.desktop,./misc/scripts/codespell.sh"
|
||||
SKIP_LIST="./.git,./bin,./thirdparty,*.gen.*,*.po,*.pot,package-lock.json,./core/string/locales.h,./DONORS.md,./misc/dist/linux/org.godotengine.Godot.desktop,./misc/scripts/codespell.sh"
|
||||
IGNORE_LIST="alo,ba,childs,complies,curvelinear,doubleclick,expct,fave,findn,gird,gud,inout,lod,nd,numer,ois,readded,ro,sav,statics,te,varius,varn,wan"
|
||||
|
||||
codespell -w -q 3 -S "${SKIP_LIST}" -L "${IGNORE_LIST}"
|
||||
|
@ -242,7 +242,7 @@ void StreamPeerMbedTLS::poll() {
|
||||
return;
|
||||
}
|
||||
|
||||
// We could pass nullptr as second parameter, but some behaviour sanitizers don't seem to like that.
|
||||
// We could pass nullptr as second parameter, but some behavior sanitizers don't seem to like that.
|
||||
// Passing a 1 byte buffer to workaround it.
|
||||
uint8_t byte;
|
||||
int ret = mbedtls_ssl_read(tls_ctx->get_context(), &byte, 0);
|
||||
|
@ -6,7 +6,7 @@
|
||||
<description>
|
||||
This is a generic mobile VR implementation where you need to provide details about the phone and HMD used. It does not rely on any existing framework. This is the most basic interface we have. For the best effect, you need a mobile phone with a gyroscope and accelerometer.
|
||||
Note that even though there is no positional tracking, the camera will assume the headset is at a height of 1.85 meters. You can change this by setting [member eye_height].
|
||||
You can initialise this interface as follows:
|
||||
You can initialize this interface as follows:
|
||||
[codeblock]
|
||||
var interface = XRServer.find_interface("Native mobile")
|
||||
if interface and interface.initialize():
|
||||
|
@ -155,7 +155,7 @@ void MobileVRInterface::set_position_from_sensors() {
|
||||
last_magnetometer_data = magneto;
|
||||
|
||||
if (grav.length() < 0.1) {
|
||||
// not ideal but use our accelerometer, this will contain shaky user behaviour
|
||||
// not ideal but use our accelerometer, this will contain shaky user behavior
|
||||
// maybe look into some math but I'm guessing that if this isn't available, it's because we lack the gyro sensor to actually work out
|
||||
// what a stable gravity vector is
|
||||
grav = acc;
|
||||
|
@ -53,7 +53,7 @@ void uninitialize_mobile_vr_module(ModuleInitializationLevel p_level) {
|
||||
}
|
||||
|
||||
if (mobile_vr.is_valid()) {
|
||||
// uninitialise our interface if it is initialised
|
||||
// uninitialize our interface if it is initialized
|
||||
if (mobile_vr->is_initialized()) {
|
||||
mobile_vr->uninitialize();
|
||||
}
|
||||
|
@ -6,7 +6,6 @@
|
||||
<description>
|
||||
Spawnable scenes can be configured in the editor or through code (see [method add_spawnable_scene]).
|
||||
Also supports custom node spawns through [method spawn], calling [method _spawn_custom] on all peers.
|
||||
|
||||
Internally, [MultiplayerSpawner] uses [method MultiplayerAPI.object_configuration_add] to notify spawns passing the spawned node as the [code]object[/code] and itself as the [code]configuration[/code], and [method MultiplayerAPI.object_configuration_remove] to notify despawns in a similar way.
|
||||
</description>
|
||||
<tutorials>
|
||||
@ -17,8 +16,7 @@
|
||||
<param index="0" name="data" type="Variant" />
|
||||
<description>
|
||||
Method called on all peers when a custom spawn was requested by the authority using [method spawn]. Should return a [Node] that is not in the scene tree.
|
||||
|
||||
[b]Note:[/b] Spawned nodes should [b]not[/b] be added to the scene with `add_child`. This is done automatically.
|
||||
[b]Note:[/b] Spawned nodes should [b]not[/b] be added to the scene with [method Node.add_child]. This is done automatically.
|
||||
</description>
|
||||
</method>
|
||||
<method name="add_spawnable_scene">
|
||||
@ -52,7 +50,6 @@
|
||||
<param index="0" name="data" type="Variant" default="null" />
|
||||
<description>
|
||||
Requests a custom spawn, with [code]data[/code] passed to [method _spawn_custom] on all peers. Returns the locally spawned node instance already inside the scene tree, and added as a child of the node pointed by [member spawn_path].
|
||||
|
||||
[b]Note:[/b] Spawnable scenes are spawned automatically. [method spawn] is only needed for custom spawns.
|
||||
</description>
|
||||
</method>
|
||||
@ -60,7 +57,6 @@
|
||||
<members>
|
||||
<member name="spawn_limit" type="int" setter="set_spawn_limit" getter="get_spawn_limit" default="0">
|
||||
Maximum nodes that is allowed to be spawned by this spawner. Includes both spawnable scenes and custom spawns.
|
||||
|
||||
When set to [code]0[/code] (the default), there is no limit.
|
||||
</member>
|
||||
<member name="spawn_path" type="NodePath" setter="set_spawn_path" getter="get_spawn_path" default="NodePath("")">
|
||||
|
@ -6,9 +6,7 @@
|
||||
<description>
|
||||
By default, [MultiplayerSynchronizer] synchronizes configured properties to all peers.
|
||||
Visibility can be handled directly with [method set_visibility_for] or as-needed with [method add_visibility_filter] and [method update_visibility].
|
||||
|
||||
[MultiplayerSpawner]s will handle nodes according to visibility of synchronizers as long as the node at [member root_path] was spawned by one.
|
||||
|
||||
Internally, [MultiplayerSynchronizer] uses [method MultiplayerAPI.object_configuration_add] to notify synchronization start passing the [Node] at [member root_path] as the [code]object[/code] and itself as the [code]configuration[/code], and uses [method MultiplayerAPI.object_configuration_remove] to notify synchronization end in a similar way.
|
||||
</description>
|
||||
<tutorials>
|
||||
@ -19,7 +17,6 @@
|
||||
<param index="0" name="filter" type="Callable" />
|
||||
<description>
|
||||
Adds a peer visibility filter for this synchronizer.
|
||||
|
||||
[code]filter[/code] should take a peer id [int] and return a [bool].
|
||||
</description>
|
||||
</method>
|
||||
|
@ -325,7 +325,7 @@ Error SceneReplicationInterface::_update_spawn_visibility(int p_peer, const Obje
|
||||
// Check visibility for each peers.
|
||||
for (const KeyValue<int, PeerInfo> &E : peers_info) {
|
||||
if (is_visible) {
|
||||
// This is fast, since the the object is visibile to everyone, we don't need to check each peer.
|
||||
// This is fast, since the the object is visible to everyone, we don't need to check each peer.
|
||||
if (E.value.spawn_nodes.has(p_oid)) {
|
||||
// Already spawned.
|
||||
continue;
|
||||
|
@ -75,7 +75,7 @@ private:
|
||||
HashSet<ObjectID> spawned_nodes;
|
||||
HashSet<ObjectID> sync_nodes;
|
||||
|
||||
// Pending spawn informations.
|
||||
// Pending spawn information.
|
||||
ObjectID pending_spawn;
|
||||
int pending_spawn_remote = 0;
|
||||
const uint8_t *pending_buffer = nullptr;
|
||||
|
@ -6,7 +6,7 @@
|
||||
<description>
|
||||
This resource defines an OpenXR action. Actions can be used both for inputs (buttons/joystick/trigger/etc) and outputs (haptics).
|
||||
OpenXR performs automatic conversion between action type and input type whenever possible. An analogue trigger bound to a boolean action will thus return [code]false[/code] if the trigger is depressed and [code]true[/code] if pressed fully.
|
||||
Actions are not directly bound to specific devices, instead OpenXR recognises a limited number of top level paths that identify devices by usage. We can restrict which devices an action can be bound to by these top level paths. For instance an action that should only be used for hand held controllers can have the top level paths "/user/hand/left" and "/user/hand/right" associated with them. See the [url=https://www.khronos.org/registry/OpenXR/specs/1.0/html/xrspec.html#semantic-path-reserved]reserved path section in the OpenXR specification[/url] for more info on the top level paths.
|
||||
Actions are not directly bound to specific devices, instead OpenXR recognizes a limited number of top level paths that identify devices by usage. We can restrict which devices an action can be bound to by these top level paths. For instance an action that should only be used for hand held controllers can have the top level paths "/user/hand/left" and "/user/hand/right" associated with them. See the [url=https://www.khronos.org/registry/OpenXR/specs/1.0/html/xrspec.html#semantic-path-reserved]reserved path section in the OpenXR specification[/url] for more info on the top level paths.
|
||||
Note that the name of the resource is used to register the action with.
|
||||
</description>
|
||||
<tutorials>
|
||||
@ -16,7 +16,7 @@
|
||||
The type of action.
|
||||
</member>
|
||||
<member name="localized_name" type="String" setter="set_localized_name" getter="get_localized_name" default="""">
|
||||
The localised description of this action.
|
||||
The localized description of this action.
|
||||
</member>
|
||||
<member name="toplevel_paths" type="PackedStringArray" setter="set_toplevel_paths" getter="get_toplevel_paths" default="PackedStringArray()">
|
||||
A collections of toplevel paths to which this action can be bound.
|
||||
|
@ -36,7 +36,7 @@
|
||||
Collection of actions for this action set.
|
||||
</member>
|
||||
<member name="localized_name" type="String" setter="set_localized_name" getter="get_localized_name" default="""">
|
||||
The localised name of this action set.
|
||||
The localized name of this action set.
|
||||
</member>
|
||||
<member name="priority" type="int" setter="set_priority" getter="get_priority" default="0">
|
||||
The priority for this action set.
|
||||
|
@ -5,7 +5,7 @@
|
||||
</brief_description>
|
||||
<description>
|
||||
The OpenXR interface allows Godot to interact with OpenXR runtimes and make it possible to create XR experiences and games.
|
||||
Due to the needs of OpenXR this interface works slightly different than other plugin based XR interfaces. It needs to be initialised when Godot starts. You need to enable OpenXR, settings for this can be found in your games project settings under the XR heading. You do need to mark a viewport for use with XR in order for Godot to know which render result should be output to the headset.
|
||||
Due to the needs of OpenXR this interface works slightly different than other plugin based XR interfaces. It needs to be initialized when Godot starts. You need to enable OpenXR, settings for this can be found in your games project settings under the XR heading. You do need to mark a viewport for use with XR in order for Godot to know which render result should be output to the headset.
|
||||
</description>
|
||||
<tutorials>
|
||||
<link title="Setting up XR">$DOCS_URL/tutorials/xr/setting_up_xr.html</link>
|
||||
|
@ -102,7 +102,7 @@ void OpenXRHandTrackingExtension::on_state_ready() {
|
||||
// Setup our hands and reset data
|
||||
for (int i = 0; i < MAX_OPENXR_TRACKED_HANDS; i++) {
|
||||
// we'll do this later
|
||||
hand_trackers[i].is_initialised = false;
|
||||
hand_trackers[i].is_initialized = false;
|
||||
hand_trackers[i].hand_tracker = XR_NULL_HANDLE;
|
||||
|
||||
hand_trackers[i].aimState.aimPose = { { 0.0, 0.0, 0.0, 0.0 }, { 0.0, 0.0, 0.0 } };
|
||||
@ -144,7 +144,7 @@ void OpenXRHandTrackingExtension::on_process() {
|
||||
if (XR_FAILED(result)) {
|
||||
// not successful? then we do nothing.
|
||||
print_line("OpenXR: Failed to obtain hand tracking information [", openxr_api->get_error_string(result), "]");
|
||||
hand_trackers[i].is_initialised = false;
|
||||
hand_trackers[i].is_initialized = false;
|
||||
} else {
|
||||
void *next_pointer = nullptr;
|
||||
if (hand_tracking_aim_state_ext) {
|
||||
@ -172,11 +172,11 @@ void OpenXRHandTrackingExtension::on_process() {
|
||||
hand_trackers[i].locations.jointCount = XR_HAND_JOINT_COUNT_EXT;
|
||||
hand_trackers[i].locations.jointLocations = hand_trackers[i].joint_locations;
|
||||
|
||||
hand_trackers[i].is_initialised = true;
|
||||
hand_trackers[i].is_initialized = true;
|
||||
}
|
||||
}
|
||||
|
||||
if (hand_trackers[i].is_initialised) {
|
||||
if (hand_trackers[i].is_initialized) {
|
||||
void *next_pointer = nullptr;
|
||||
|
||||
XrHandJointsMotionRangeInfoEXT motionRangeInfo;
|
||||
@ -240,7 +240,7 @@ void OpenXRHandTrackingExtension::cleanup_hand_tracking() {
|
||||
if (hand_trackers[i].hand_tracker != XR_NULL_HANDLE) {
|
||||
xrDestroyHandTrackerEXT(hand_trackers[i].hand_tracker);
|
||||
|
||||
hand_trackers[i].is_initialised = false;
|
||||
hand_trackers[i].is_initialized = false;
|
||||
hand_trackers[i].hand_tracker = XR_NULL_HANDLE;
|
||||
}
|
||||
}
|
||||
|
@ -40,7 +40,7 @@
|
||||
class OpenXRHandTrackingExtension : public OpenXRExtensionWrapper {
|
||||
public:
|
||||
struct HandTracker {
|
||||
bool is_initialised = false;
|
||||
bool is_initialized = false;
|
||||
XrHandJointsMotionRangeEXT motion_range = XR_HAND_JOINTS_MOTION_RANGE_UNOBSTRUCTED_EXT;
|
||||
|
||||
XrHandTrackerEXT hand_tracker = XR_NULL_HANDLE;
|
||||
|
@ -96,7 +96,7 @@ void OpenXRInterface::_load_action_map() {
|
||||
|
||||
// This may seem a bit duplicitous to a little bit of background info here.
|
||||
// OpenXRActionMap (with all its sub resource classes) is a class that allows us to configure and store an action map in.
|
||||
// This gives the user the ability to edit the action map in a UI and customise the actions.
|
||||
// This gives the user the ability to edit the action map in a UI and customize the actions.
|
||||
// OpenXR however requires us to submit an action map and it takes over from that point and we can no longer change it.
|
||||
// This system does that push and we store the info needed to then work with this action map going forward.
|
||||
|
||||
@ -166,7 +166,7 @@ void OpenXRInterface::_load_action_map() {
|
||||
}
|
||||
}
|
||||
|
||||
// Only add our action if we have atleast one valid toplevel path
|
||||
// Only add our action if we have at least one valid toplevel path
|
||||
if (trackers_for_action.size() > 0) {
|
||||
Action *action = create_action(action_set, xr_action->get_name(), xr_action->get_localized_name(), xr_action->get_action_type(), trackers_for_action);
|
||||
if (action) {
|
||||
@ -355,7 +355,7 @@ OpenXRInterface::Tracker *OpenXRInterface::find_tracker(const String &p_tracker_
|
||||
Ref<XRPositionalTracker> positional_tracker;
|
||||
positional_tracker.instantiate();
|
||||
|
||||
// We have standardised some names to make things nicer to the user so lets recognise the toplevel paths related to these.
|
||||
// We have standardized some names to make things nicer to the user so lets recognize the toplevel paths related to these.
|
||||
if (p_tracker_name == "/user/hand/left") {
|
||||
positional_tracker->set_tracker_type(XRServer::TRACKER_CONTROLLER);
|
||||
positional_tracker->set_tracker_name("left_hand");
|
||||
|
@ -206,7 +206,7 @@ void OpenXRHand::_update_skeleton() {
|
||||
const OpenXRHandTrackingExtension::HandTracker *hand_tracker = hand_tracking_ext->get_hand_tracker(hand);
|
||||
const float ws = XRServer::get_singleton()->get_world_scale();
|
||||
|
||||
if (hand_tracker->is_initialised && hand_tracker->locations.isActive) {
|
||||
if (hand_tracker->is_initialized && hand_tracker->locations.isActive) {
|
||||
for (int i = 0; i < XR_HAND_JOINT_COUNT_EXT; i++) {
|
||||
confidences[i] = XRPose::XR_TRACKING_CONFIDENCE_NONE;
|
||||
quaternions[i] = Quaternion();
|
||||
|
@ -4,7 +4,7 @@
|
||||
Class for searching text for patterns using regular expressions.
|
||||
</brief_description>
|
||||
<description>
|
||||
A regular expression (or regex) is a compact language that can be used to recognise strings that follow a specific pattern, such as URLs, email addresses, complete sentences, etc. For example, a regex of [code]ab[0-9][/code] would find any string that is [code]ab[/code] followed by any number from [code]0[/code] to [code]9[/code]. For a more in-depth look, you can easily find various tutorials and detailed explanations on the Internet.
|
||||
A regular expression (or regex) is a compact language that can be used to recognize strings that follow a specific pattern, such as URLs, email addresses, complete sentences, etc. For example, a regex of [code]ab[0-9][/code] would find any string that is [code]ab[/code] followed by any number from [code]0[/code] to [code]9[/code]. For a more in-depth look, you can easily find various tutorials and detailed explanations on the Internet.
|
||||
To begin, the RegEx object needs to be compiled with the search pattern using [method compile] before it can be used.
|
||||
[codeblock]
|
||||
var regex = RegEx.new()
|
||||
|
@ -74,7 +74,7 @@
|
||||
<param index="3" name="proto" type="String" default=""UDP"" />
|
||||
<param index="4" name="duration" type="int" default="0" />
|
||||
<description>
|
||||
Adds a mapping to forward the external [code]port[/code] (between 1 and 65535, although recommended to use port 1024 or above) on the default gateway (see [method get_gateway]) to the [code]internal_port[/code] on the local machine for the given protocol [code]proto[/code] (either [code]TCP[/code] or [code]UDP[/code], with UDP being the default). If a port mapping for the given port and protocol combination already exists on that gateway device, this method tries to overwrite it. If that is not desired, you can retrieve the gateway manually with [method get_gateway] and call [method add_port_mapping] on it, if any. Note that forwarding a well-known port (below 1024) with UPnP may fail depending on the device.
|
||||
Adds a mapping to forward the external [code]port[/code] (between 1 and 65535, although recommended to use port 1024 or above) on the default gateway (see [method get_gateway]) to the [code]internal_port[/code] on the local machine for the given protocol [code]proto[/code] (either [code]"TCP"[/code] or [code]"UDP"[/code], with UDP being the default). If a port mapping for the given port and protocol combination already exists on that gateway device, this method tries to overwrite it. If that is not desired, you can retrieve the gateway manually with [method get_gateway] and call [method add_port_mapping] on it, if any. Note that forwarding a well-known port (below 1024) with UPnP may fail depending on the device.
|
||||
Depending on the gateway device, if a mapping for that port already exists, it will either be updated or it will refuse this command due to that conflict, especially if the existing mapping for that port wasn't created via UPnP or points to a different network address (or device) than this one.
|
||||
If [code]internal_port[/code] is [code]0[/code] (the default), the same port number is used for both the external and the internal port (the [code]port[/code] value).
|
||||
The description ([code]desc[/code]) is shown in some routers management UIs and can be used to point out which application added the mapping.
|
||||
@ -93,7 +93,7 @@
|
||||
<param index="0" name="port" type="int" />
|
||||
<param index="1" name="proto" type="String" default=""UDP"" />
|
||||
<description>
|
||||
Deletes the port mapping for the given port and protocol combination on the default gateway (see [method get_gateway]) if one exists. [code]port[/code] must be a valid port between 1 and 65535, [code]proto[/code] can be either [code]TCP[/code] or [code]UDP[/code]. May be refused for mappings pointing to addresses other than this one, for well-known ports (below 1024), or for mappings not added via UPnP. See [enum UPNPResult] for possible return values.
|
||||
Deletes the port mapping for the given port and protocol combination on the default gateway (see [method get_gateway]) if one exists. [code]port[/code] must be a valid port between 1 and 65535, [code]proto[/code] can be either [code]"TCP"[/code] or [code]"UDP"[/code]. May be refused for mappings pointing to addresses other than this one, for well-known ports (below 1024), or for mappings not added via UPnP. See [enum UPNPResult] for possible return values.
|
||||
</description>
|
||||
</method>
|
||||
<method name="discover">
|
||||
|
@ -133,7 +133,7 @@
|
||||
<return type="int" enum="Error" />
|
||||
<param index="0" name="message" type="String" />
|
||||
<description>
|
||||
Sends the given [param message] using WebSocket text mode. Perfer this method over [method PacketPeer.put_packet] when interacting with third-party text-based API (e.g. when using [JSON] formatted messages).
|
||||
Sends the given [param message] using WebSocket text mode. Prefer this method over [method PacketPeer.put_packet] when interacting with third-party text-based API (e.g. when using [JSON] formatted messages).
|
||||
</description>
|
||||
</method>
|
||||
<method name="set_no_delay">
|
||||
|
@ -57,7 +57,7 @@ void uninitialize_webxr_module(ModuleInitializationLevel p_level) {
|
||||
|
||||
#ifdef WEB_ENABLED
|
||||
if (webxr.is_valid()) {
|
||||
// uninitialise our interface if it is initialised
|
||||
// uninitialize our interface if it is initialized
|
||||
if (webxr->is_initialized()) {
|
||||
webxr->uninitialize();
|
||||
}
|
||||
|
@ -212,7 +212,7 @@ int DisplayServerWeb::mouse_button_callback(int p_pressed, int p_button, double
|
||||
void DisplayServerWeb::mouse_move_callback(double p_x, double p_y, double p_rel_x, double p_rel_y, int p_modifiers) {
|
||||
MouseButton input_mask = Input::get_singleton()->get_mouse_button_mask();
|
||||
// For motion outside the canvas, only read mouse movement if dragging
|
||||
// started inside the canvas; imitating desktop app behaviour.
|
||||
// started inside the canvas; imitating desktop app behavior.
|
||||
if (!get_singleton()->cursor_inside_canvas && input_mask == MouseButton::NONE) {
|
||||
return;
|
||||
}
|
||||
|
@ -167,7 +167,7 @@ bool JoypadWindows::setup_dinput_joypad(const DIDEVICEINSTANCE *instance) {
|
||||
const GUID &guid = instance->guidProduct;
|
||||
char uid[128];
|
||||
|
||||
ERR_FAIL_COND_V_MSG(memcmp(&guid.Data4[2], "PIDVID", 6), false, "DirectInput device not recognised.");
|
||||
ERR_FAIL_COND_V_MSG(memcmp(&guid.Data4[2], "PIDVID", 6), false, "DirectInput device not recognized.");
|
||||
WORD type = BSWAP16(0x03);
|
||||
WORD vendor = BSWAP16(LOWORD(guid.Data1));
|
||||
WORD product = BSWAP16(HIWORD(guid.Data1));
|
||||
|
@ -833,7 +833,7 @@ void TextEdit::_notification(int p_what) {
|
||||
continue;
|
||||
}
|
||||
|
||||
// If we've changed colour we are at the start of a new section, therefore we need to go back to the end
|
||||
// If we've changed color we are at the start of a new section, therefore we need to go back to the end
|
||||
// of the previous section to draw it, we'll also add the character back on.
|
||||
if (color != previous_color) {
|
||||
characters--;
|
||||
@ -2659,7 +2659,7 @@ void TextEdit::_do_backspace(bool p_word, bool p_all_to_left) {
|
||||
set_caret_line(get_caret_line(caret_idx), false, true, 0, caret_idx);
|
||||
set_caret_column(column, caret_idx == 0, caret_idx);
|
||||
|
||||
// Now we can clean up the overlaping caret.
|
||||
// Now we can clean up the overlapping caret.
|
||||
if (overlapping_caret_index != -1) {
|
||||
backspace(overlapping_caret_index);
|
||||
i++;
|
||||
@ -6560,7 +6560,7 @@ void TextEdit::_cut_internal(int p_caret) {
|
||||
int indent_level = get_indent_level(cl);
|
||||
double hscroll = get_h_scroll();
|
||||
|
||||
// Check for overlaping carets.
|
||||
// Check for overlapping carets.
|
||||
// We don't need to worry about selections as that is caught before this entire section.
|
||||
for (int j = i - 1; j >= 0; j--) {
|
||||
if (get_caret_line(caret_edit_order[j]) == cl) {
|
||||
|
@ -1184,7 +1184,7 @@ void unregister_scene_types() {
|
||||
ResourceLoader::remove_resource_format_loader(resource_loader_shader_include);
|
||||
resource_loader_shader_include.unref();
|
||||
|
||||
// StandardMaterial3D is not initialised when 3D is disabled, so it shouldn't be cleaned up either
|
||||
// StandardMaterial3D is not initialized when 3D is disabled, so it shouldn't be cleaned up either
|
||||
#ifndef _3D_DISABLED
|
||||
BaseMaterial3D::finish_shaders();
|
||||
PhysicalSkyMaterial::cleanup_shader();
|
||||
|
@ -94,7 +94,7 @@ void AudioEffectDelayInstance::_process_chunk(const AudioFrame *p_src_frames, Au
|
||||
|
||||
//apply lowpass and feedback gain
|
||||
AudioFrame fb_in = out * feedback_level_f * lpf_ic + h * lpf_c;
|
||||
fb_in.undenormalise(); //avoid denormals
|
||||
fb_in.undenormalize(); //avoid denormals
|
||||
|
||||
h = fb_in;
|
||||
fb_buf[feedback_buffer_pos] = fb_in;
|
||||
|
@ -50,7 +50,7 @@ void AudioEffectDistortionInstance::process(const AudioFrame *p_src_frames, Audi
|
||||
float lofi_mult = powf(2.0, 2.0 + (1.0 - drive_f) * 14); //goes from 16 to 2 bits
|
||||
|
||||
for (int i = 0; i < p_frame_count * 2; i++) {
|
||||
float out = undenormalise(src[i] * lpf_ic + lpf_c * h[i & 1]);
|
||||
float out = undenormalize(src[i] * lpf_ic + lpf_c * h[i & 1]);
|
||||
h[i & 1] = out;
|
||||
float a = out;
|
||||
float ha = src[i] - out; //high freqs
|
||||
|
@ -77,7 +77,7 @@ void Reverb::process(float *p_src, float *p_dst, int p_frames) {
|
||||
read_pos += echo_buffer_size;
|
||||
}
|
||||
|
||||
float in = undenormalise(echo_buffer[read_pos] * params.predelay_fb + p_src[i]);
|
||||
float in = undenormalize(echo_buffer[read_pos] * params.predelay_fb + p_src[i]);
|
||||
|
||||
echo_buffer[echo_buffer_pos] = in;
|
||||
|
||||
@ -111,7 +111,7 @@ void Reverb::process(float *p_src, float *p_dst, int p_frames) {
|
||||
c.pos = 0;
|
||||
}
|
||||
|
||||
float out = undenormalise(c.buffer[c.pos] * c.feedback);
|
||||
float out = undenormalize(c.buffer[c.pos] * c.feedback);
|
||||
out = out * (1.0 - c.damp) + c.damp_h * c.damp; //lowpass
|
||||
c.damp_h = out;
|
||||
c.buffer[c.pos] = input_buffer[j] + out;
|
||||
@ -138,7 +138,7 @@ void Reverb::process(float *p_src, float *p_dst, int p_frames) {
|
||||
ap=&allpass[m_ap]; \
|
||||
if (ap->pos>=ap_size_limit[m_ap]) \
|
||||
ap->pos=0; \
|
||||
aux=undenormalise(ap->buffer[ap->pos]); \
|
||||
aux=undenormalize(ap->buffer[ap->pos]); \
|
||||
in=sample; \
|
||||
sample=-in+aux; \
|
||||
ap->pos++;
|
||||
@ -163,7 +163,7 @@ void Reverb::process(float *p_src, float *p_dst, int p_frames) {
|
||||
}
|
||||
|
||||
float aux = a.buffer[a.pos];
|
||||
a.buffer[a.pos] = undenormalise(allpass_feedback * aux + p_dst[j]);
|
||||
a.buffer[a.pos] = undenormalize(allpass_feedback * aux + p_dst[j]);
|
||||
p_dst[j] = aux - allpass_feedback * a.buffer[a.pos];
|
||||
a.pos++;
|
||||
}
|
||||
|
@ -361,7 +361,7 @@ void SkyRD::ReflectionData::update_reflection_data(int p_size, int p_mipmaps, bo
|
||||
uint32_t w = p_size, h = p_size;
|
||||
|
||||
EffectsRD *effects = RendererCompositorRD::singleton->get_effects();
|
||||
ERR_FAIL_NULL_MSG(effects, "Effects haven't been initialised");
|
||||
ERR_FAIL_NULL_MSG(effects, "Effects haven't been initialized");
|
||||
bool prefer_raster_effects = effects->get_prefer_raster_effects();
|
||||
|
||||
if (p_use_array) {
|
||||
@ -465,7 +465,7 @@ void SkyRD::ReflectionData::update_reflection_data(int p_size, int p_mipmaps, bo
|
||||
|
||||
void SkyRD::ReflectionData::create_reflection_fast_filter(bool p_use_arrays) {
|
||||
RendererRD::CopyEffects *copy_effects = RendererRD::CopyEffects::get_singleton();
|
||||
ERR_FAIL_NULL_MSG(copy_effects, "Effects haven't been initialised");
|
||||
ERR_FAIL_NULL_MSG(copy_effects, "Effects haven't been initialized");
|
||||
bool prefer_raster_effects = copy_effects->get_prefer_raster_effects();
|
||||
|
||||
if (prefer_raster_effects) {
|
||||
@ -523,7 +523,7 @@ void SkyRD::ReflectionData::create_reflection_fast_filter(bool p_use_arrays) {
|
||||
|
||||
void SkyRD::ReflectionData::create_reflection_importance_sample(bool p_use_arrays, int p_cube_side, int p_base_layer, uint32_t p_sky_ggx_samples_quality) {
|
||||
RendererRD::CopyEffects *copy_effects = RendererRD::CopyEffects::get_singleton();
|
||||
ERR_FAIL_NULL_MSG(copy_effects, "Effects haven't been initialised");
|
||||
ERR_FAIL_NULL_MSG(copy_effects, "Effects haven't been initialized");
|
||||
bool prefer_raster_effects = copy_effects->get_prefer_raster_effects();
|
||||
|
||||
if (prefer_raster_effects) {
|
||||
@ -592,7 +592,7 @@ void SkyRD::ReflectionData::create_reflection_importance_sample(bool p_use_array
|
||||
|
||||
void SkyRD::ReflectionData::update_reflection_mipmaps(int p_start, int p_end) {
|
||||
RendererRD::CopyEffects *copy_effects = RendererRD::CopyEffects::get_singleton();
|
||||
ERR_FAIL_NULL_MSG(copy_effects, "Effects haven't been initialised");
|
||||
ERR_FAIL_NULL_MSG(copy_effects, "Effects haven't been initialized");
|
||||
bool prefer_raster_effects = copy_effects->get_prefer_raster_effects();
|
||||
|
||||
RD::get_singleton()->draw_command_begin_label("Update Radiance Cubemap Array Mipmaps");
|
||||
|
@ -106,15 +106,15 @@ uint32_t XRInterfaceExtension::get_capabilities() const {
|
||||
}
|
||||
|
||||
bool XRInterfaceExtension::is_initialized() const {
|
||||
bool initialised = false;
|
||||
GDVIRTUAL_CALL(_is_initialized, initialised);
|
||||
return initialised;
|
||||
bool initialized = false;
|
||||
GDVIRTUAL_CALL(_is_initialized, initialized);
|
||||
return initialized;
|
||||
}
|
||||
|
||||
bool XRInterfaceExtension::initialize() {
|
||||
bool initialised = false;
|
||||
GDVIRTUAL_CALL(_initialize, initialised);
|
||||
return initialised;
|
||||
bool initialized = false;
|
||||
GDVIRTUAL_CALL(_initialize, initialized);
|
||||
return initialized;
|
||||
}
|
||||
|
||||
void XRInterfaceExtension::uninitialize() {
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user