2024-03-24 20:57:35 +01:00
<?xml version="1.0" encoding="UTF-8" ?>
2024-04-26 17:32:25 +02:00
<class name= "VertexLights2DServer" inherits= "Object" version= "4.4" >
2024-03-24 20:57:35 +01:00
<brief_description >
2024-03-27 08:58:40 +01:00
A server that provides a way to store static lights that can be used to bake lighting information into mesh vertex data, or [CanvasItem]'s color modulation.
2024-03-24 20:57:35 +01:00
</brief_description>
<description >
2024-03-27 08:58:40 +01:00
A server that provides a way to store static lights that can be used to bake lighting information into mesh vertex data, or [CanvasItem]'s color modulation.
With this class extremely complex light information can be stored and used with no additional cost on the GPU side.
After adding lights, you can use [member sample_light] to sample lighting at a specified point in the map's space, then use the resulting [Color] to either further modifty the modulate property of [CanvasItem]s, or you can render meshes using this color in you custom _draw methods.
The drawback of this method is that it's more expensive change lights.
Note that you can use the normal 2D lighting system on top of this if you need dynamic lights (like [Light2D]). That system is better suited for that purpose.
Currently this class stores lights inside quadrants. Their optimal size should be a bit more than the radius of the biggest light you want to have.
2024-03-24 20:57:35 +01:00
</description>
<tutorials >
</tutorials>
<methods >
2024-03-27 08:06:09 +01:00
<method name= "flush_notifications" >
<return type= "void" />
<description >
2024-03-27 08:58:40 +01:00
Flushes map changed notifications. This will get called automatically.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "free" >
<return type= "void" />
<argument index= "0" name= "rid" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Frees an allocated resource.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "get_default_quadrant_size" qualifiers= "const" >
<return type= "Vector2i" />
<description >
2024-03-27 08:58:40 +01:00
Get the default internal quadrant size.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_create" >
<return type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Create a light.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "light_get_attenuation" >
<return type= "float" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's attenuation property.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "light_get_color" >
<return type= "Color" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's color property.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "light_get_is_enabled" >
<return type= "bool" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's enabled property.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "light_get_item_cull_mask" >
<return type= "int" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's item cull mask property.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_get_layer_range" >
<return type= "Vector2i" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's layer range property.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_get_map" >
<return type= "RID" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's map.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_get_mode" >
2024-03-24 21:45:06 +01:00
<return type= "int" enum= "VertexLights2DServer.VertexLight2DMode" />
2024-03-24 20:57:35 +01:00
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's mix mode.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_get_position" >
<return type= "Vector2" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's position.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "light_get_range" >
<return type= "Vector2i" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's range.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "light_get_z_range" >
<return type= "Vector2i" />
<argument index= "0" name= "light" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Get a light's z range property.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "light_set_attenuation" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "attenuation" type= "float" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's attenuation property.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "light_set_color" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "color" type= "Color" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's color property.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "light_set_enabled" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "enabled" type= "bool" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's enabled property.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "light_set_item_cull_mask" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "item_cull_mask" type= "int" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's item cull mask property.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_set_layer_range" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "layer_range" type= "Vector2i" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's layer range property.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_set_map" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "map" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's map.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_set_mode" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
2024-03-24 21:45:06 +01:00
<argument index= "1" name= "mode" type= "int" enum= "VertexLights2DServer.VertexLight2DMode" />
2024-03-24 20:57:35 +01:00
<description >
2024-03-27 08:58:40 +01:00
Set a light's mix mode.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "light_set_position" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "position" type= "Vector2" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's position.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "light_set_range" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "range" type= "Vector2i" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's range.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "light_set_z_range" >
<return type= "void" />
<argument index= "0" name= "light" type= "RID" />
<argument index= "1" name= "z_range" type= "Vector2i" />
<description >
2024-03-27 08:58:40 +01:00
Set a light's z range property.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "map_clear" >
<return type= "void" />
<argument index= "0" name= "map" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Clears a map of all lights.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "map_create" >
<return type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Creates a map.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "map_get_base_color" qualifiers= "const" >
<return type= "Color" />
<argument index= "0" name= "map" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Returns the base color of a map.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "map_get_lights" qualifiers= "const" >
<return type= "Array" />
<argument index= "0" name= "map" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Returns all lights in a map.
2024-03-24 20:57:35 +01:00
</description>
</method>
<method name= "map_get_quadrant_size" qualifiers= "const" >
<return type= "Vector2i" />
<argument index= "0" name= "map" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Returns a map's quadrant size.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "map_set_base_color" >
<return type= "void" />
<argument index= "0" name= "map" type= "RID" />
<argument index= "1" name= "base_color" type= "Color" />
<description >
2024-03-27 08:58:40 +01:00
Sets the base color of a map.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "map_set_quadrant_size" >
<return type= "void" />
<argument index= "0" name= "map" type= "RID" />
<argument index= "1" name= "size" type= "Vector2i" />
<description >
2024-03-27 08:58:40 +01:00
Sets a map's quadrant size.
2024-03-24 20:57:35 +01:00
</description>
</method>
2024-03-27 08:06:09 +01:00
<method name= "sample_light" >
<return type= "Color" />
<argument index= "0" name= "map" type= "RID" />
<argument index= "1" name= "position" type= "Vector2" />
<argument index= "2" name= "item_cull_mask" type= "int" default= "1" />
<argument index= "3" name= "layer" type= "int" default= "0" />
2024-03-27 09:04:59 +01:00
<argument index= "4" name= "z_index" type= "int" default= "0" />
2024-03-27 08:06:09 +01:00
<description >
2024-03-27 08:58:40 +01:00
Sample the lighing information at a specific position.
2024-03-27 08:06:09 +01:00
</description>
</method>
2024-03-24 20:57:35 +01:00
<method name= "set_default_quadrant_size" >
<return type= "void" />
<argument index= "0" name= "size" type= "Vector2i" />
<description >
2024-03-27 08:58:40 +01:00
Set the default internal quadrant size.
2024-03-24 20:57:35 +01:00
</description>
</method>
</methods>
2024-03-27 08:06:09 +01:00
<signals >
<signal name= "map_changed" >
<argument index= "0" name= "map" type= "RID" />
<description >
2024-03-27 08:58:40 +01:00
Emitted after a map changed (only once per frame).
2024-03-27 08:06:09 +01:00
</description>
</signal>
</signals>
2024-03-24 20:57:35 +01:00
<constants >
<constant name= "VERTEX_LIGHT_2D_MODE_ADD" value= "0" enum= "VertexLight2DMode" >
2024-03-27 08:58:40 +01:00
The light's color gets added to the resulting colors.
2024-03-24 20:57:35 +01:00
</constant>
<constant name= "VERTEX_LIGHT_2D_MODE_SUB" value= "1" enum= "VertexLight2DMode" >
2024-03-27 08:58:40 +01:00
The light's color gets substracted to the resulting colors.
2024-03-24 20:57:35 +01:00
</constant>
<constant name= "VERTEX_LIGHT_2D_MODE_MIX" value= "2" enum= "VertexLight2DMode" >
2024-03-27 08:58:40 +01:00
The light's color gets blended with the resulting colors.
2024-03-24 20:57:35 +01:00
</constant>
</constants>
</class>