summaryrefslogtreecommitdiff
path: root/doc/classes/DirectionalLight.xml
blob: a3ef830d5d7f27849f0870fc25392f543cc16698 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
<?xml version="1.0" encoding="UTF-8" ?>
<class name="DirectionalLight" inherits="Light" version="4.0">
	<brief_description>
		Directional light from a distance, as from the Sun.
	</brief_description>
	<description>
		A directional light is a type of [Light] node that models an infinite number of parallel rays covering the entire scene. It is used for lights with strong intensity that are located far away from the scene to model sunlight or moonlight. The worldspace location of the DirectionalLight transform (origin) is ignored. Only the basis is used to determine light direction.
	</description>
	<tutorials>
		<link>https://docs.godotengine.org/en/latest/tutorials/3d/lights_and_shadows.html</link>
	</tutorials>
	<methods>
	</methods>
	<members>
		<member name="directional_shadow_bias_split_scale" type="float" setter="set_param" getter="get_param" default="0.25">
			Amount of extra bias for shadow splits that are far away. If self-shadowing occurs only on the splits far away, increasing this value can fix them.
		</member>
		<member name="directional_shadow_blend_splits" type="bool" setter="set_blend_splits" getter="is_blend_splits_enabled" default="false">
			If [code]true[/code], shadow detail is sacrificed in exchange for smoother transitions between splits.
		</member>
		<member name="directional_shadow_depth_range" type="int" setter="set_shadow_depth_range" getter="get_shadow_depth_range" enum="DirectionalLight.ShadowDepthRange" default="0">
			Optimizes shadow rendering for detail versus movement. See [enum ShadowDepthRange].
		</member>
		<member name="directional_shadow_fade_start" type="float" setter="set_param" getter="get_param" default="0.8">
		</member>
		<member name="directional_shadow_max_distance" type="float" setter="set_param" getter="get_param" default="100.0">
			The maximum distance for shadow splits.
		</member>
		<member name="directional_shadow_mode" type="int" setter="set_shadow_mode" getter="get_shadow_mode" enum="DirectionalLight.ShadowMode" default="2">
			The light's shadow rendering algorithm. See [enum ShadowMode].
		</member>
		<member name="directional_shadow_normal_bias" type="float" setter="set_param" getter="get_param" default="0.8">
			Can be used to fix special cases of self shadowing when objects are perpendicular to the light.
		</member>
		<member name="directional_shadow_split_1" type="float" setter="set_param" getter="get_param" default="0.1">
			The distance from camera to shadow split 1. Relative to [member directional_shadow_max_distance]. Only used when [member directional_shadow_mode] is [code]SHADOW_PARALLEL_2_SPLITS[/code] or [code]SHADOW_PARALLEL_4_SPLITS[/code].
		</member>
		<member name="directional_shadow_split_2" type="float" setter="set_param" getter="get_param" default="0.2">
			The distance from shadow split 1 to split 2. Relative to [member directional_shadow_max_distance]. Only used when [member directional_shadow_mode] is [code]SHADOW_PARALLEL_2_SPLITS[/code] or [code]SHADOW_PARALLEL_4_SPLITS[/code].
		</member>
		<member name="directional_shadow_split_3" type="float" setter="set_param" getter="get_param" default="0.5">
			The distance from shadow split 2 to split 3. Relative to [member directional_shadow_max_distance]. Only used when [member directional_shadow_mode] is [code]SHADOW_PARALLEL_4_SPLITS[/code].
		</member>
		<member name="shadow_bias" type="float" setter="set_param" getter="get_param" override="true" default="0.1" />
	</members>
	<constants>
		<constant name="SHADOW_ORTHOGONAL" value="0" enum="ShadowMode">
			Renders the entire scene's shadow map from an orthogonal point of view. May result in blockier shadows on close objects.
		</constant>
		<constant name="SHADOW_PARALLEL_2_SPLITS" value="1" enum="ShadowMode">
			Splits the view frustum in 2 areas, each with its own shadow map.
		</constant>
		<constant name="SHADOW_PARALLEL_4_SPLITS" value="2" enum="ShadowMode">
			Splits the view frustum in 4 areas, each with its own shadow map.
		</constant>
		<constant name="SHADOW_DEPTH_RANGE_STABLE" value="0" enum="ShadowDepthRange">
			Keeps the shadow stable when the camera moves, at the cost of lower effective shadow resolution.
		</constant>
		<constant name="SHADOW_DEPTH_RANGE_OPTIMIZED" value="1" enum="ShadowDepthRange">
			Tries to achieve maximum shadow resolution. May result in saw effect on shadow edges.
		</constant>
	</constants>
</class>