2017-09-13 04:42:36 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-03-01 08:44:37 +08:00
<class name= "CanvasLayer" inherits= "Node" version= "4.1" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2017-09-13 04:42:36 +08:00
<brief_description >
2017-09-17 10:14:03 +08:00
Canvas drawing layer.
2017-09-13 04:42:36 +08:00
</brief_description>
<description >
2019-03-30 06:37:35 +08:00
Canvas drawing layer. [CanvasItem] nodes that are direct or indirect children of a [CanvasLayer] will be drawn in that layer. The layer is a numeric index that defines the draw order. The default 2D scene renders with index 0, so a [CanvasLayer] with index -1 will be drawn below, and one with index 1 will be drawn above. This is very useful for HUDs (in layer 1+ or above), or backgrounds (in layer -1 or below).
2022-10-14 16:29:28 +08:00
Embedded [Window]s are placed in layer 1024. CanvasItems in layer 1025 or above appear in front of embedded windows, CanvasItems in layer 1023 or below appear behind embedded windows.
2017-09-13 04:42:36 +08:00
</description>
<tutorials >
2021-11-15 17:43:07 +08:00
<link title= "Viewport and canvas transforms" > $DOCS_URL/tutorials/2d/2d_transforms.html</link>
<link title= "Canvas layers" > $DOCS_URL/tutorials/2d/canvas_layers.html</link>
2020-10-01 16:34:47 +08:00
<link title= "2D Dodge The Creeps Demo" > https://godotengine.org/asset-library/asset/515</link>
2017-09-13 04:42:36 +08:00
</tutorials>
<methods >
2018-04-10 16:12:42 +08:00
<method name= "get_canvas" qualifiers= "const" >
2021-07-30 21:28:05 +08:00
<return type= "RID" />
2017-09-13 04:42:36 +08:00
<description >
2018-04-10 16:12:42 +08:00
Returns the RID of the canvas used by this layer.
2017-09-13 04:42:36 +08:00
</description>
</method>
2022-10-07 18:17:10 +08:00
<method name= "get_final_transform" qualifiers= "const" >
<return type= "Transform2D" />
<description >
Returns the transform from the [CanvasLayer]s coordinate system to the [Viewport]s coordinate system.
</description>
</method>
2022-02-15 21:25:18 +08:00
<method name= "hide" >
<return type= "void" />
<description >
Hides any [CanvasItem] under this [CanvasLayer]. This is equivalent to setting [member visible] to [code]false[/code].
</description>
</method>
<method name= "show" >
<return type= "void" />
<description >
Shows any [CanvasItem] under this [CanvasLayer]. This is equivalent to setting [member visible] to [code]true[/code].
</description>
</method>
2017-09-13 04:42:36 +08:00
</methods>
<members >
2019-06-30 03:22:15 +08:00
<member name= "custom_viewport" type= "Node" setter= "set_custom_viewport" getter= "get_custom_viewport" >
2019-06-22 07:04:47 +08:00
The custom [Viewport] node assigned to the [CanvasLayer]. If [code]null[/code], uses the default viewport instead.
2018-01-12 06:38:35 +08:00
</member>
2022-08-13 18:36:59 +08:00
<member name= "follow_viewport_enabled" type= "bool" setter= "set_follow_viewport" getter= "is_following_viewport" default= "false" >
2022-09-06 00:34:52 +08:00
If enabled, the [CanvasLayer] will use the viewport's transform, so it will move when camera moves instead of being anchored in a fixed position on the screen.
Together with [member follow_viewport_scale] it can be used for a pseudo 3D effect.
2019-04-15 20:49:41 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "follow_viewport_scale" type= "float" setter= "set_follow_viewport_scale" getter= "get_follow_viewport_scale" default= "1.0" >
2022-08-13 18:36:59 +08:00
Scales the layer when using [member follow_viewport_enabled]. Layers moving into the foreground should have increasing scales, while layers moving into the background should have decreasing scales.
2019-04-15 20:49:41 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "layer" type= "int" setter= "set_layer" getter= "get_layer" default= "1" >
2022-12-08 00:51:12 +08:00
Layer index for draw order. Lower values are drawn behind higher values.
2017-09-13 04:42:36 +08:00
</member>
2019-09-25 01:45:03 +08:00
<member name= "offset" type= "Vector2" setter= "set_offset" getter= "get_offset" default= "Vector2(0, 0)" >
2017-09-17 10:14:03 +08:00
The layer's base offset.
2017-09-13 04:42:36 +08:00
</member>
2019-06-29 18:38:01 +08:00
<member name= "rotation" type= "float" setter= "set_rotation" getter= "get_rotation" default= "0.0" >
2018-01-12 06:38:35 +08:00
The layer's rotation in radians.
</member>
2019-09-25 01:45:03 +08:00
<member name= "scale" type= "Vector2" setter= "set_scale" getter= "get_scale" default= "Vector2(1, 1)" >
2017-09-17 10:14:03 +08:00
The layer's scale.
2017-09-13 04:42:36 +08:00
</member>
2019-09-25 01:45:03 +08:00
<member name= "transform" type= "Transform2D" setter= "set_transform" getter= "get_transform" default= "Transform2D(1, 0, 0, 1, 0, 0)" >
2018-01-12 06:38:35 +08:00
The layer's transform.
</member>
2021-04-19 02:49:21 +08:00
<member name= "visible" type= "bool" setter= "set_visible" getter= "is_visible" default= "true" >
If [code]false[/code], any [CanvasItem] under this [CanvasLayer] will be hidden.
Unlike [member CanvasItem.visible], visibility of a [CanvasLayer] isn't propagated to underlying layers.
</member>
2017-09-13 04:42:36 +08:00
</members>
2021-04-19 02:49:21 +08:00
<signals >
<signal name= "visibility_changed" >
<description >
Emitted when visibility of the layer is changed. See [member visible].
</description>
</signal>
</signals>
2017-09-13 04:42:36 +08:00
</class>