2017-09-13 04:42:36 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2020-03-31 00:22:57 +08:00
<class name= "Sprite2D" inherits= "Node2D" version= "4.0" >
2017-09-13 04:42:36 +08:00
<brief_description >
2019-06-22 07:04:47 +08:00
General-purpose sprite node.
2017-09-13 04:42:36 +08:00
</brief_description>
<description >
2017-09-24 00:11:51 +08:00
A node that displays a 2D texture. The texture displayed can be a region from a larger atlas texture, or a frame from a sprite sheet animation.
2017-09-13 04:42:36 +08:00
</description>
<tutorials >
</tutorials>
<methods >
2018-02-25 14:19:42 +08:00
<method name= "get_rect" qualifiers= "const" >
<return type= "Rect2" >
</return>
<description >
2020-03-31 00:22:57 +08:00
Returns a [Rect2] representing the Sprite2D's boundary in local coordinates. Can be used to detect if the Sprite2D was clicked. Example:
2019-05-26 21:51:27 +08:00
[codeblock]
func _input(event):
if event is InputEventMouseButton and event.pressed and event.button_index == BUTTON_LEFT:
if get_rect().has_point(to_local(event.position)):
print("A click!")
[/codeblock]
2018-02-25 14:19:42 +08:00
</description>
</method>
2018-08-30 04:25:11 +08:00
<method name= "is_pixel_opaque" qualifiers= "const" >
<return type= "bool" >
</return>
<argument index= "0" name= "pos" type= "Vector2" >
</argument>
<description >
2019-06-18 22:17:48 +08:00
Returns [code]true[/code], if the pixel at the given position is opaque and [code]false[/code] in other case.
2019-06-22 07:04:47 +08:00
[b]Note:[/b] It also returns [code]false[/code], if the sprite's texture is [code]null[/code] or if the given position is invalid.
2018-08-30 04:25:11 +08:00
</description>
</method>
2017-09-13 04:42:36 +08:00
</methods>
<members >
2019-06-29 18:38:01 +08:00
<member name= "centered" type= "bool" setter= "set_centered" getter= "is_centered" default= "true" >
2019-06-29 21:24:23 +08:00
If [code]true[/code], texture is centered.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "flip_h" type= "bool" setter= "set_flip_h" getter= "is_flipped_h" default= "false" >
2019-06-29 21:24:23 +08:00
If [code]true[/code], texture is flipped horizontally.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "flip_v" type= "bool" setter= "set_flip_v" getter= "is_flipped_v" default= "false" >
2019-06-29 21:24:23 +08:00
If [code]true[/code], texture is flipped vertically.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "frame" type= "int" setter= "set_frame" getter= "get_frame" default= "0" >
2017-10-07 00:33:16 +08:00
Current frame to display from sprite sheet. [member vframes] or [member hframes] must be greater than 1.
2017-09-13 04:42:36 +08:00
</member>
2019-07-30 03:12:57 +08:00
<member name= "frame_coords" type= "Vector2" setter= "set_frame_coords" getter= "get_frame_coords" default= "Vector2( 0, 0 )" >
2019-01-26 02:21:23 +08:00
Coordinates of the frame to display from sprite sheet. This is as an alias for the [member frame] property. [member vframes] or [member hframes] must be greater than 1.
</member>
2019-06-29 18:38:01 +08:00
<member name= "hframes" type= "int" setter= "set_hframes" getter= "get_hframes" default= "1" >
2018-02-22 00:30:55 +08:00
The number of columns in the sprite sheet.
2017-09-13 04:42:36 +08:00
</member>
2020-02-12 16:59:06 +08:00
<member name= "normal_map" type= "Texture2D" setter= "set_normal_map" getter= "get_normal_map" >
2020-03-31 00:22:57 +08:00
The normal map gives depth to the Sprite2D.
2020-05-05 04:18:05 +08:00
[b]Note:[/b] Godot expects the normal map to use X+, Y-, and Z+ coordinates. See [url=http://wiki.polycount.com/wiki/Normal_Map_Technical_Details#Common_Swizzle_Coordinates]this page[/url] for a comparison of normal map coordinates expected by popular engines.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "offset" type= "Vector2" setter= "set_offset" getter= "get_offset" default= "Vector2( 0, 0 )" >
2017-09-24 00:11:51 +08:00
The texture's drawing offset.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "region_enabled" type= "bool" setter= "set_region" getter= "is_region" default= "false" >
2019-06-29 21:24:23 +08:00
If [code]true[/code], texture is cut from a larger atlas texture. See [member region_rect].
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "region_filter_clip" type= "bool" setter= "set_region_filter_clip" getter= "is_region_filter_clip_enabled" default= "false" >
2018-12-20 20:46:54 +08:00
If [code]true[/code], the outermost pixels get blurred out.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "region_rect" type= "Rect2" setter= "set_region_rect" getter= "get_region_rect" default= "Rect2( 0, 0, 0, 0 )" >
2017-10-07 00:33:16 +08:00
The region of the atlas texture to display. [member region_enabled] must be [code]true[/code].
2017-09-13 04:42:36 +08:00
</member>
2020-02-12 16:59:06 +08:00
<member name= "shininess" type= "float" setter= "set_shininess" getter= "get_shininess" default= "1.0" >
2020-03-31 00:22:57 +08:00
Strength of the specular light effect of this [Sprite2D].
2020-02-12 16:59:06 +08:00
</member>
<member name= "specular_color" type= "Color" setter= "set_specular_color" getter= "get_specular_color" default= "Color( 1, 1, 1, 1 )" >
2020-03-04 02:21:21 +08:00
The color of the specular light effect.
2020-02-12 16:59:06 +08:00
</member>
<member name= "specular_map" type= "Texture2D" setter= "set_specular_map" getter= "get_specular_map" >
2020-03-04 02:21:21 +08:00
The specular map is used for more control on the shininess effect.
2020-02-12 16:59:06 +08:00
</member>
<member name= "texture" type= "Texture2D" setter= "set_texture" getter= "get_texture" >
[Texture2D] object to draw.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "vframes" type= "int" setter= "set_vframes" getter= "get_vframes" default= "1" >
2017-10-07 00:33:16 +08:00
The number of rows in the sprite sheet.
2017-09-13 04:42:36 +08:00
</member>
</members>
<signals >
<signal name= "frame_changed" >
<description >
2017-10-07 00:33:16 +08:00
Emitted when the [member frame] changes.
2017-09-13 04:42:36 +08:00
</description>
</signal>
<signal name= "texture_changed" >
<description >
2017-10-07 00:33:16 +08:00
Emitted when the [member texture] changes.
2017-09-13 04:42:36 +08:00
</description>
</signal>
</signals>
<constants >
</constants>
</class>