1
0
Fork 0

Compositor: Added shadow mapping to the ALS pipeline

This commit is contained in:
Fernando García Liñán 2019-11-03 20:52:22 +01:00
parent d1ab981110
commit daeea22999
246 changed files with 1365 additions and 79 deletions

View file

@ -10,13 +10,6 @@
<height>screen</height>
<format>rgba8</format>
</buffer>
<buffer>
<name>depth</name>
<type>2d</type>
<width>screen</width>
<height>screen</height>
<format>depth32f</format>
</buffer>
<buffer>
<name>sun-shadowmap-atlas</name>
<type>2d</type>
@ -33,8 +26,6 @@
</buffer>
<!-- Shadow mapping pre-passes -->
<pass include="csm.xml">
<name>csm0</name>
@ -50,7 +41,7 @@
<pass include="csm.xml">
<name>csm1</name>
<near-m>3.0</near-m>
<far-m>30.0</far-m>
<far-m>50.0</far-m>
<viewport>
<x>0.5</x>
<y>0.0</y>
@ -60,8 +51,8 @@
</pass>
<pass include="csm.xml">
<name>csm2</name>
<near-m>30.0</near-m>
<far-m>300.0</far-m>
<near-m>50.0</near-m>
<far-m>150.0</far-m>
<viewport>
<x>0.0</x>
<y>0.5</y>
@ -71,8 +62,8 @@
</pass>
<pass include="csm.xml">
<name>csm3</name>
<near-m>300.0</near-m>
<far-m>3000.0</far-m>
<near-m>150.0</near-m>
<far-m>1500.0</far-m>
<viewport>
<x>0.5</x>
<y>0.5</y>
@ -80,67 +71,42 @@
<height>0.5</height>
</viewport>
</pass>
<pass>
<name>forward</name>
<type>scene</type>
<effect-scheme>als-lighting</effect-scheme>
<!--
<clustered-shading>
<tile-size>128</tile-size>
<num-threads>4</num-threads>
<depth-slices>16</depth-slices>
</clustered-shading>
-->
<!--
<clustered-shading>
<tile-size>128</tile-size>
<num-threads>4</num-threads>
<depth-slices>16</depth-slices>
</clustered-shading>
-->
<use-shadow-pass>csm0</use-shadow-pass>
<use-shadow-pass>csm1</use-shadow-pass>
<use-shadow-pass>csm2</use-shadow-pass>
<use-shadow-pass>csm3</use-shadow-pass>
<binding>
<buffer>sun-shadowmap-atlas</buffer>
<unit>10</unit>
</binding>
<attachment>
<buffer>color</buffer>
<component>color0</component>
<!--
<multisample-samples>4</multisample-samples>
<multisample-color-samples>4</multisample-color-samples>
-->
</attachment>
<attachment>
<buffer>depth</buffer>
<component>depth</component>
</attachment>
</pass>
<pass>
<name>display</name>
<type>quad</type>
<binding>
<buffer>color</buffer>
<unit>0</unit>
</binding>
</pass>
<pass>
<name>depth-debug</name>
<type>quad</type>
<clear-mask>depth</clear-mask>
<geometry>
<left>0.8</left>
<bottom>0.0</bottom>
<width>0.2</width>
<height>0.2</height>
<scale>1.0</scale>
</geometry>
<binding>
<buffer>depth</buffer>
<unit>0</unit>
</binding>
<name>display</name>
<type>quad</type>
<binding>
<buffer>color</buffer>
<unit>0</unit>
</binding>
</pass>
</PropertyList>

View file

@ -7,12 +7,10 @@
<lighting>false</lighting>
<color-mask type="vec4d">0 0 0 0</color-mask>
<cull-face>back</cull-face>
<!--
<program>
<vertex-shader>Compositor/Shaders/shadow-pass.vert</vertex-shader>
<fragment-shader>Compositor/Shaders/shadow-pass.frag</fragment-shader>
</program>
-->
<vertex-shader>Shaders/Default/trivial.vert</vertex-shader>
<fragment-shader>Shaders/Default/trivial.frag</fragment-shader>
</program>
</pass>
</technique>
</PropertyList>

View file

@ -433,12 +433,14 @@
<program>
<vertex-shader>Shaders/ALS/terrain-ultra.vert</vertex-shader>
<vertex-shader>Shaders/ALS/filters.vert</vertex-shader>
<vertex-shader>Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader>Shaders/ALS/agriculture.frag</fragment-shader>
<fragment-shader>Shaders/ALS/cloud-shadowfunc.frag</fragment-shader>
<fragment-shader>Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader>Shaders/ALS/hazes.frag</fragment-shader>
<fragment-shader>Shaders/ALS/secondary_lights.frag</fragment-shader>
<fragment-shader>Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader>Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>grain_strength</name>
@ -1147,6 +1149,27 @@
<value>2</value>
<!-- AMBIENT_AND_DIFFUSE -->
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
<depth>
<function>lequal</function>
</depth>

View file

@ -198,12 +198,14 @@
<program>
<vertex-shader>Shaders/ALS/terrain-ultra.vert</vertex-shader>
<vertex-shader>Shaders/ALS/filters.vert</vertex-shader>
<vertex-shader>Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader>Shaders/ALS/airfield.frag</fragment-shader>
<fragment-shader>Shaders/ALS/cloud-shadowfunc.frag</fragment-shader>
<fragment-shader>Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader>Shaders/ALS/hazes.frag</fragment-shader>
<fragment-shader>Shaders/ALS/secondary_lights.frag</fragment-shader>
<fragment-shader>Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader>Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>visibility</name>
@ -859,6 +861,27 @@
<value>2</value>
<!-- AMBIENT_AND_DIFFUSE -->
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
<depth>
<function>lequal</function>
<write-mask type="bool">false</write-mask>

View file

@ -0,0 +1,125 @@
<?xml version="1.0" encoding="utf-8"?>
<PropertyList>
<name>Effects/chrome</name>
<parameters>
<texture n ="0">
<type>transparent</type>
</texture>
<chrome-light><use>/rendering/scene/chrome-light</use></chrome-light>
</parameters>
<technique n="9">
<pass>
<lighting>false</lighting>
<blend>
<active><use>blend/active</use></active>
<source><use>blend/source</use></source>
<destination><use>blend/destination</use></destination>
</blend>
<shade-model><use>shade-model</use></shade-model>
<cull-face><use>cull-face</use></cull-face>
<rendering-hint><use>rendering-hint</use></rendering-hint>
<texture-unit>
<unit>0</unit>
<type><use>texture[0]/type</use></type>
<image><use>texture[0]/image</use></image>
<filter><use>texture[0]/filter</use></filter>
<wrap-s><use>texture[0]/wrap-s</use></wrap-s>
<wrap-t><use>texture[0]/wrap-t</use></wrap-t>
<!--
<internal-format>
<use>texture[0]/internal-format</use>
</internal-format>
-->
<texenv-combine>
<combine-rgb>modulate</combine-rgb>
<source0-rgb>constant</source0-rgb>
<operand0-rgb>src-color</operand0-rgb>
<source1-rgb>texture1</source1-rgb>
<operand1-rgb>src-color</operand1-rgb>
<constant-color><use>chrome-light</use></constant-color>
</texenv-combine>
</texture-unit>
<texture-unit>
<unit>1</unit>
<image><use>chrome-texture</use></image>
<filter>linear-mipmap-linear</filter>
<wrap-s>repeat</wrap-s>
<wrap-t>repeat</wrap-t>
<texenv-combine>
<combine-rgb>interpolate</combine-rgb>
<source0-rgb>texture0</source0-rgb>
<operand0-rgb>src-color</operand0-rgb>
<source1-rgb>previous</source1-rgb>
<operand1-rgb>src-color</operand1-rgb>
<source2-rgb>texture0</source2-rgb>
<operand2-rgb>src-alpha</operand2-rgb>
<!-- Are these used for anything? -->
<combine-alpha>replace</combine-alpha>
<source0-alpha>texture1</source0-alpha>
<operand0-alpha>src-alpha</operand0-alpha>
</texenv-combine>
<texgen>
<mode>sphere-map</mode>
</texgen>
</texture-unit>
</pass>
</technique>
<technique n="19">
<scheme>als-lighting</scheme>
<pass>
<lighting>false</lighting>
<blend>
<active><use>blend/active</use></active>
<source><use>blend/source</use></source>
<destination><use>blend/destination</use></destination>
</blend>
<shade-model><use>shade-model</use></shade-model>
<cull-face><use>cull-face</use></cull-face>
<rendering-hint><use>rendering-hint</use></rendering-hint>
<texture-unit>
<unit>0</unit>
<type><use>texture[0]/type</use></type>
<image><use>texture[0]/image</use></image>
<filter><use>texture[0]/filter</use></filter>
<wrap-s><use>texture[0]/wrap-s</use></wrap-s>
<wrap-t><use>texture[0]/wrap-t</use></wrap-t>
<!--
<internal-format>
<use>texture[0]/internal-format</use>
</internal-format>
-->
<texenv-combine>
<combine-rgb>modulate</combine-rgb>
<source0-rgb>constant</source0-rgb>
<operand0-rgb>src-color</operand0-rgb>
<source1-rgb>texture1</source1-rgb>
<operand1-rgb>src-color</operand1-rgb>
<constant-color><use>chrome-light</use></constant-color>
</texenv-combine>
</texture-unit>
<texture-unit>
<unit>1</unit>
<image><use>chrome-texture</use></image>
<filter>linear-mipmap-linear</filter>
<wrap-s>repeat</wrap-s>
<wrap-t>repeat</wrap-t>
<texenv-combine>
<combine-rgb>interpolate</combine-rgb>
<source0-rgb>texture0</source0-rgb>
<operand0-rgb>src-color</operand0-rgb>
<source1-rgb>previous</source1-rgb>
<operand1-rgb>src-color</operand1-rgb>
<source2-rgb>texture0</source2-rgb>
<operand2-rgb>src-alpha</operand2-rgb>
<!-- Are these used for anything? -->
<combine-alpha>replace</combine-alpha>
<source0-alpha>texture1</source0-alpha>
<operand0-alpha>src-alpha</operand0-alpha>
</texenv-combine>
<texgen>
<mode>sphere-map</mode>
</texgen>
</texture-unit>
</pass>
</technique>
</PropertyList>

View file

@ -201,12 +201,14 @@
<program>
<vertex-shader>Shaders/ALS/terrain-ultra.vert</vertex-shader>
<vertex-shader>Shaders/ALS/filters.vert</vertex-shader>
<vertex-shader>Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader>Shaders/ALS/airfield.frag</fragment-shader>
<fragment-shader>Shaders/ALS/cloud-shadowfunc.frag</fragment-shader>
<fragment-shader>Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader>Shaders/ALS/hazes.frag</fragment-shader>
<fragment-shader>Shaders/ALS/secondary_lights.frag</fragment-shader>
<fragment-shader>Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader>Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>visibility</name>
@ -862,6 +864,27 @@
<value>2</value>
<!-- AMBIENT_AND_DIFFUSE -->
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
<depth>
<function>lequal</function>
<write-mask type="bool">false</write-mask>
@ -938,6 +961,7 @@
<fragment-shader n="0">Shaders/ALS/grass.frag</fragment-shader>
<fragment-shader n="1">Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader n="2">Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader n="3">Shaders/ALS/shadows-include.frag</fragment-shader>
<geometry-vertices-out type="int">96</geometry-vertices-out>
<geometry-input-type>triangles</geometry-input-type>
<geometry-output-type>triangle-strip</geometry-output-type>
@ -1123,6 +1147,27 @@
<use>wind_effects</use>
</value>
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
<blend>
<active>true</active>
<source>src-alpha</source>

View file

@ -1081,12 +1081,14 @@ please see Docs/README.model-combined.eff for documentation
</vertex-program-two-side>
<program>
<vertex-shader n="0">Shaders/ALS/model-ultra.vert</vertex-shader>
<vertex-shader n="1">Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader n="0">Shaders/ALS/model-ultra.frag</fragment-shader>
<fragment-shader n="1">Shaders/ALS/cloud-shadowfunc.frag</fragment-shader>
<fragment-shader n="2">Shaders/ALS/hazes.frag</fragment-shader>
<fragment-shader n="3">Shaders/ALS/secondary_lights.frag</fragment-shader>
<fragment-shader n="4">Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader n="5">Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader n="6">Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>BaseTex</name>
@ -1997,6 +1999,27 @@ please see Docs/README.model-combined.eff for documentation
<use>rembrandt</use>
</value>
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
</pass>
</technique>
</PropertyList>

View file

@ -125,6 +125,14 @@
<use>/sim/rendering/shaders/transition</use>
</tquality_level>
<!-- END fog include -->
<!-- BEGIN shadows include -->
<shadows_enabled>
<use>/sim/rendering/als/shadows/enabled</use>
</shadows_enabled>
<sun_atlas_size>
<use>/sim/rendering/als/shadows/sun-atlas-size</use>
</sun_atlas_size>
<!-- END shadows include -->
</parameters>
<technique n="8">
<predicate>
@ -466,11 +474,13 @@
</vertex-program-two-side>
<program>
<vertex-shader>Shaders/ALS/generic-base.vert</vertex-shader>
<vertex-shader>Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader>Shaders/ALS/model-base.frag</fragment-shader>
<fragment-shader>Shaders/ALS/hazes.frag</fragment-shader>
<fragment-shader>Shaders/ALS/secondary_lights.frag</fragment-shader>
<fragment-shader>Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader>Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader>Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>visibility</name>
@ -785,6 +795,27 @@
<use>tquality_level</use>
</value>
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
</pass>
</technique>
</PropertyList>

View file

@ -117,4 +117,81 @@
-->
</pass>
</technique>
<technique n="19">
<scheme>als-lighting</scheme>
<pass>
<lighting>true</lighting>
<depth>
<write-mask type="bool">false</write-mask>
</depth>
<material>
<active>
<use>material/active</use>
</active>
<ambient>
<use>material/ambient</use>
</ambient>
<diffuse>
<use>material/diffuse</use>
</diffuse>
<specular>
<use>material/specular</use>
</specular>
<emissive>
<use>material/emissive</use>
</emissive>
<shininess>
<use>material/shininess</use>
</shininess>
<color-mode>
<use>material/color-mode</use>
</color-mode>
</material>
<blend>
<active>
<use>blend/active</use>
</active>
<source>
<use>blend/source</use>
</source>
<destination>
<use>blend/destination</use>
</destination>
</blend>
<shade-model>
<use>shade-model</use>
</shade-model>
<cull-face>
<use>cull-face</use>
</cull-face>
<render-bin>
<bin-number>111</bin-number>
<bin-name>DepthSortedBin</bin-name>
</render-bin>
<texture-unit>
<unit>0</unit>
<active>
<use>texture[0]/active</use>
</active>
<type>
<use>texture[0]/type</use>
</type>
<image>
<use>texture[0]/image</use>
</image>
<filter>
<use>texture[0]/filter</use>
</filter>
<wrap-s>
<use>texture[0]/wrap-s</use>
</wrap-s>
<wrap-t>
<use>texture[0]/wrap-t</use>
</wrap-t>
<environment>
<mode>modulate</mode>
</environment>
</texture-unit>
</pass>
</technique>
</PropertyList>

View file

@ -657,6 +657,7 @@
<program>
<vertex-shader n="0">Shaders/ALS/terrain-ultra.vert</vertex-shader>
<vertex-shader n="1">Shaders/ALS/filters.vert</vertex-shader>
<vertex-shader n="2">Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader n="0">Shaders/ALS/runway.frag</fragment-shader>
<fragment-shader n="1">Shaders/ALS/cloud-shadowfunc.frag</fragment-shader>
<fragment-shader n="2">Shaders/ALS/noise.frag</fragment-shader>
@ -664,6 +665,7 @@
<fragment-shader n="4">Shaders/ALS/secondary_lights.frag</fragment-shader>
<fragment-shader n="5">Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader n="6">Shaders/ALS/lightspot.frag</fragment-shader>
<fragment-shader n="7">Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>visibility</name>
@ -1552,6 +1554,27 @@
<value>2</value>
<!-- AMBIENT_AND_DIFFUSE -->
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
<!--<depth>
<function>lequal</function>
<write-mask type="bool">false</write-mask>

View file

@ -355,6 +355,14 @@
<cloud_shadow_flag>
<use>/local-weather/cloud-shadows/cloud-shadow-flag</use>
</cloud_shadow_flag>
<!-- BEGIN shadows include -->
<shadows_enabled>
<use>/sim/rendering/als/shadows/enabled</use>
</shadows_enabled>
<sun_atlas_size>
<use>/sim/rendering/als/shadows/sun-atlas-size</use>
</sun_atlas_size>
<!-- END shadows include -->
</parameters>
<!-- put techniques at a "high" index to allow derived effects to
insert their own techniques first. -->
@ -820,12 +828,14 @@
<program>
<vertex-shader>Shaders/ALS/terrain-ultra.vert</vertex-shader>
<vertex-shader>Shaders/ALS/filters.vert</vertex-shader>
<vertex-shader>Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader>Shaders/ALS/terrain-ultra.frag</fragment-shader>
<fragment-shader>Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader>Shaders/ALS/cloud-shadowfunc.frag</fragment-shader>
<fragment-shader>Shaders/ALS/hazes.frag</fragment-shader>
<fragment-shader>Shaders/ALS/secondary_lights.frag</fragment-shader>
<fragment-shader>Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader>Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>grain_strength</name>
@ -1517,6 +1527,27 @@
<value>2</value>
<!-- AMBIENT_AND_DIFFUSE -->
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
<depth>
<function>lequal</function>
<!-- <write-mask type="bool">false</write-mask> -->
@ -1677,10 +1708,12 @@
<program>
<vertex-shader>Shaders/ALS/terrain-detailed.vert</vertex-shader>
<vertex-shader>Shaders/ALS/filters.vert</vertex-shader>
<vertex-shader>Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader>Shaders/ALS/terrain-detailed.frag</fragment-shader>
<fragment-shader>Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader>Shaders/ALS/hazes.frag</fragment-shader>
<fragment-shader>Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader>Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>visibility</name>
@ -1935,6 +1968,27 @@
<value>2</value>
<!-- AMBIENT_AND_DIFFUSE -->
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
<depth>
<function>lequal</function>
<!--><write-mask type="bool">false</write-mask> -->
@ -2055,10 +2109,12 @@
</texture-unit>
<program>
<vertex-shader>Shaders/ALS/generic-base.vert</vertex-shader>
<vertex-shader>Shaders/ALS/shadows-include.vert</vertex-shader>
<fragment-shader>Shaders/ALS/terrain-base.frag</fragment-shader>
<fragment-shader>Shaders/ALS/hazes.frag</fragment-shader>
<fragment-shader>Shaders/ALS/noise.frag</fragment-shader>
<fragment-shader>Shaders/ALS/filters.frag</fragment-shader>
<fragment-shader>Shaders/ALS/shadows-include.frag</fragment-shader>
</program>
<uniform>
<name>visibility</name>
@ -2226,6 +2282,27 @@
<value>2</value>
<!-- AMBIENT_AND_DIFFUSE -->
</uniform>
<!-- BEGIN shadows include -->
<uniform>
<name>shadow_tex</name>
<type>sampler-2d</type>
<value type="int">10</value>
</uniform>
<uniform>
<name>shadows_enabled</name>
<type>bool</type>
<value>
<use>shadows_enabled</use>
</value>
</uniform>
<uniform>
<name>sun_atlas_size</name>
<type>int</type>
<value>
<use>sun_atlas_size</use>
</value>
</uniform>
<!-- END shadows include -->
<depth>
<function>lequal</function>
<!-- <write-mask type="bool">false</write-mask> -->

View file

@ -92,6 +92,8 @@ vec3 searchlight();
vec3 landing_light(in float offset, in float offsetv);
vec3 filter_combined (in vec3 color) ;
float getShadowing();
// a fade function for procedural scales which are smaller than a pixel
@ -417,13 +419,15 @@ if ((dist < 5000.0)&& (quality_level > 3) && (combined_wetness>0.0))
NdotL = NdotL + 0.05 * noisegrad_1m * detail_fade(1.0, view_angle,dist);
if (NdotL > 0.0) {
float shadowmap = getShadowing();
if (cloud_shadow_flag == 1) {NdotL = NdotL * shadow_func(relPos.x, relPos.y, 0.3 * noise_250m + 0.5 * noise_500m+0.2 * noise_1500m, dist);}
color += diffuse_term * NdotL;
color += diffuse_term * NdotL * shadowmap;
NdotHV = max(dot(n, halfVector), 0.0);
if (gl_FrontMaterial.shininess > 0.0)
specular.rgb = ((gl_FrontMaterial.specular.rgb * 0.1 + (water_factor * vec3 (1.0, 1.0, 1.0)))
* light_specular.rgb
* pow(NdotHV, gl_FrontMaterial.shininess + (20.0 * water_factor)));
* pow(NdotHV, gl_FrontMaterial.shininess + (20.0 * water_factor))
* shadowmap);
}
color.a = 1.0;//diffuse_term.a;
// This shouldn't be necessary, but our lighting becomes very

View file

@ -78,6 +78,8 @@ vec3 searchlight();
vec3 landing_light(in float offset, in float offsetv);
vec3 filter_combined (in vec3 color) ;
float getShadowing();
float detail_fade (in float scale, in float angle, in float dist)
{
@ -282,9 +284,10 @@ if (quality_level > 3)
}
if (NdotL > 0.0) {
float shadowmap = getShadowing();
if (cloud_shadow_flag == 1)
{NdotL = NdotL * shadow_func(relPos.x, relPos.y, noise_1500m, dist);}
color += diffuse_term * NdotL;
color += diffuse_term * NdotL * shadowmap;
@ -294,7 +297,8 @@ if (quality_level > 3)
if (gl_FrontMaterial.shininess > 0.0)
specular.rgb = ((gl_FrontMaterial.specular.rgb + (water_factor * vec3 (1.0, 1.0, 1.0)))
* light_specular.rgb
* pow(NdotHV, (gl_FrontMaterial.shininess + 20.0 * water_factor)));
* pow(NdotHV, (gl_FrontMaterial.shininess + 20.0 * water_factor))
* shadowmap);
}
color.a = 1.0;
// This shouldn't be necessary, but our lighting becomes very

View file

@ -37,6 +37,8 @@ uniform float ground_scattering;
uniform float moonlight;
void setupShadows(vec4 eyeSpacePos);
// This is the value used in the skydome scattering shader - use the same here for consistency?
const float EarthRadius = 5800000.0;
const float terminator_width = 200000.0;
@ -239,6 +241,7 @@ else // the faster, full-day version without lightfields
gl_FrontColor.rgb = constant_term.rgb; gl_FrontColor.a = 1.0;
gl_BackColor.rgb = constant_term.rgb; gl_BackColor.a = 0.0;
setupShadows(gl_ModelViewMatrix * gl_Vertex);
}

View file

@ -37,6 +37,8 @@ float rand2D(in vec2 co);
float Noise2D(in vec2 co, in float wavelength);
vec3 filter_combined (in vec3 color) ;
float getShadowing();
float map(float s, float a1, float a2, float b1, float b2)
{
@ -153,7 +155,7 @@ void main()
texel.r = min(1.0, (1.0 + 2.5 * 0.1 * season) * texel.r);
texel.g = texel.g;
texel.b = max(0.0, (1.0 - 4.0 * 0.1 * season) * texel.b);
float intensity = length(texel.rgb) * (1.0 - 0.5 * smoothstep(1.1,2.0,season));
float intensity = length(texel.rgb) * (1.0 - 0.5 * smoothstep(1.1,2.0,season)) * mix(0.3, 1.0, getShadowing());
texel.rgb = intensity * normalize(mix(texel.rgb, vec3(0.23,0.17,0.08), smoothstep(1.1,2.0, season)));
float base_alpha = clamp(0.4 * max_height/0.3, 0.4, 1.0);

View file

@ -15,6 +15,18 @@ varying out float g_distance_to_eye;
varying out float g_layer;
uniform mat4 fg_LightMatrix_csm0;
uniform mat4 fg_LightMatrix_csm1;
uniform mat4 fg_LightMatrix_csm2;
uniform mat4 fg_LightMatrix_csm3;
varying out vec4 lightSpacePos[4];
void setupShadows(vec4 eyeSpacePos)
{
lightSpacePos[0] = fg_LightMatrix_csm0 * eyeSpacePos;
lightSpacePos[1] = fg_LightMatrix_csm1 * eyeSpacePos;
lightSpacePos[2] = fg_LightMatrix_csm2 * eyeSpacePos;
lightSpacePos[3] = fg_LightMatrix_csm3 * eyeSpacePos;
}
float min3(in float a, in float b, in float c)
{
@ -45,6 +57,8 @@ void main()
g_distance_to_eye = distances[i];
g_layer = currDeltaLayer;
setupShadows(gl_ModelViewMatrix * pos);
gl_Position = gl_ModelViewProjectionMatrix * pos;
gl_TexCoord[0] = gl_TexCoordIn[i][0];
EmitVertex();

View file

@ -56,6 +56,8 @@ vec3 searchlight();
vec3 landing_light(in float offset, in float offsetv);
vec3 filter_combined (in vec3 color) ;
float getShadowing();
float luminance(vec3 color)
{
return dot(vec3(0.212671, 0.715160, 0.072169), color);
@ -107,12 +109,14 @@ void main()
NdotL = dot(n, lightDir);
if (NdotL > 0.0) {
color += diffuse_term * NdotL;
float shadowmap = getShadowing();
color += diffuse_term * NdotL * shadowmap;
NdotHV = max(dot(n, halfVector), 0.0);
if (gl_FrontMaterial.shininess > 0.0)
specular.rgb = (gl_FrontMaterial.specular.rgb
* light_specular.rgb
* pow(NdotHV, gl_FrontMaterial.shininess));
* pow(NdotHV, gl_FrontMaterial.shininess)
* shadowmap);
}
color.a = diffuse_term.a;
// This shouldn't be necessary, but our lighting becomes very

View file

@ -119,6 +119,8 @@ vec3 filter_combined (in vec3 color) ;
vec3 moonlight_perception (in vec3 light) ;
vec3 addLights(in vec3 color1, in vec3 color2);
float getShadowing();
float light_func (in float x, in float a, in float b, in float c, in float d, in float e)
{
@ -340,6 +342,8 @@ void main (void)
{pf1 = pow(nDotHV1, 0.5*gl_FrontMaterial.shininess);}
float shadowmap = getShadowing();
light_diffuse *= shadowmap;
if (cloud_shadow_flag == 1)
{
@ -387,6 +391,7 @@ void main (void)
Specular+= gl_FrontMaterial.specular * pow(max(0.0,-dot(N,normalize(vertVec))),gl_FrontMaterial.shininess) * vec4(secondary_light,1.0);
Specular *= refl_d;
Specular *= shadowmap;
vec4 color = gl_Color + Diffuse * gl_FrontMaterial.diffuse;
color = clamp( color, 0.0, 1.0 );

View file

@ -28,6 +28,8 @@ uniform int shader_qual;
// void fog_Func(int type);
////////////////////////////
void setupShadows(vec4 eyeSpacePos);
void rotationMatrixPR(in float sinRx, in float cosRx, in float sinRy, in float cosRy, out mat4 rotmat)
{
rotmat = mat4( cosRy , sinRx * sinRy , cosRx * sinRy, 0.0,
@ -112,4 +114,6 @@ void main(void)
gl_Position = ftransform();
gl_TexCoord[0] = gl_TextureMatrix[0] * gl_MultiTexCoord0;
setupShadows(ecPosition);
}

View file

@ -73,6 +73,8 @@ vec3 rayleigh_out_shift(in vec3 color, in float outscatter);
vec3 get_hazeColor(in float light_arg);
vec3 filter_combined (in vec3 color) ;
float getShadowing();
void main()
{
@ -286,14 +288,16 @@ if ((dist < 5000.0)&& (quality_level > 3) && (wetness>0.0))
}
if (NdotL > 0.0)
{
float shadowmap = getShadowing();
if (cloud_shadow_flag == 1)
{NdotL = NdotL * shadow_func(relPos.x, relPos.y, 1.0, dist);}
color += diffuse_term * NdotL;
color += diffuse_term * NdotL * shadowmap;
NdotHV = max(dot(n, halfVector), 0.0);
fresnel = 1.0 + 5.0 * (1.0-smoothstep(0.0,0.2, dot(E,n)));
specular.rgb = ((vec3 (0.2,0.2,0.2) * fresnel + (water_factor * vec3 (1.0, 1.0, 1.0)))
* light_specular.rgb
* pow(NdotHV, max(4.0, (20.0 * water_factor))));
* pow(NdotHV, max(4.0, (20.0 * water_factor)))
* shadowmap);
}
// raindrops

View file

@ -0,0 +1,120 @@
#version 120
uniform sampler2DShadow shadow_tex;
uniform bool shadows_enabled;
uniform int sun_atlas_size;
varying vec4 lightSpacePos[4];
const float depth_bias = 0.0005;
// Ideally these should be passed as an uniform, but we don't support uniform
// arrays yet
const vec2 uv_shifts[4] = vec2[4](
vec2(0.0, 0.0), vec2(0.5, 0.0),
vec2(0.0, 0.5), vec2(0.5, 0.5));
const vec2 uv_factor = vec2(0.5, 0.5);
float checkWithinBounds(vec2 coords, vec2 bottomLeft, vec2 topRight)
{
vec2 r = step(bottomLeft, coords) - step(topRight, coords);
return r.x * r.y;
}
float sampleOffset(vec4 pos, vec2 offset, vec2 invTexelSize)
{
return shadow2DProj(
shadow_tex, vec4(
pos.xy + offset * invTexelSize * pos.w,
pos.z - depth_bias,
pos.w)).r;
}
// OptimizedPCF from https://github.com/TheRealMJP/Shadows
// Original by Ignacio Castaño for The Witness
// Released under The MIT License
float sampleOptimizedPCF(vec4 pos)
{
vec2 invTexelSize = vec2(1.0 / float(sun_atlas_size));
vec2 uv = pos.xy * sun_atlas_size;
vec2 base_uv = floor(uv + 0.5);
float s = (uv.x + 0.5 - base_uv.x);
float t = (uv.y + 0.5 - base_uv.y);
base_uv -= vec2(0.5);
base_uv *= invTexelSize;
pos.xy = base_uv.xy;
float sum = 0.0;
float uw0 = (4.0 - 3.0 * s);
float uw1 = 7.0;
float uw2 = (1.0 + 3.0 * s);
float u0 = (3.0 - 2.0 * s) / uw0 - 2.0;
float u1 = (3.0 + s) / uw1;
float u2 = s / uw2 + 2.0;
float vw0 = (4.0 - 3.0 * t);
float vw1 = 7.0;
float vw2 = (1.0 + 3.0 * t);
float v0 = (3.0 - 2.0 * t) / vw0 - 2.0;
float v1 = (3.0 + t) / vw1;
float v2 = t / vw2 + 2.0;
sum += uw0 * vw0 * sampleOffset(pos, vec2(u0, v0), invTexelSize);
sum += uw1 * vw0 * sampleOffset(pos, vec2(u1, v0), invTexelSize);
sum += uw2 * vw0 * sampleOffset(pos, vec2(u2, v0), invTexelSize);
sum += uw0 * vw1 * sampleOffset(pos, vec2(u0, v1), invTexelSize);
sum += uw1 * vw1 * sampleOffset(pos, vec2(u1, v1), invTexelSize);
sum += uw2 * vw1 * sampleOffset(pos, vec2(u2, v1), invTexelSize);
sum += uw0 * vw2 * sampleOffset(pos, vec2(u0, v2), invTexelSize);
sum += uw1 * vw2 * sampleOffset(pos, vec2(u1, v2), invTexelSize);
sum += uw2 * vw2 * sampleOffset(pos, vec2(u2, v2), invTexelSize);
return sum / 144.0;
}
float sampleShadowMap(int n)
{
float s = 1.0;
if (n < 4) {
vec4 pos = lightSpacePos[n];
pos.xy *= uv_factor;
pos.xy += uv_shifts[n];
s = sampleOptimizedPCF(pos);
}
return s;
}
// Get a value between 0.0 and 1.0 where 0.0 means shadowed and 1.0 means lit
float getShadowing()
{
if (!shadows_enabled)
return 1.0;
const float band_size = 0.2;
const vec2 bandBottomLeft = vec2(band_size);
const vec2 bandTopRight = vec2(1.0 - band_size);
for (int i = 0; i < 4; ++i) {
if (checkWithinBounds(lightSpacePos[i].xy, vec2(0.0), vec2(1.0)) > 0.0 &&
(lightSpacePos[i].z / lightSpacePos[i].w) <= 1.0) {
if (checkWithinBounds(lightSpacePos[i].xy, bandBottomLeft, bandTopRight) < 1.0) {
vec2 s =
smoothstep(vec2(0.0), bandBottomLeft, lightSpacePos[i].xy) -
smoothstep(bandTopRight, vec2(1.0), lightSpacePos[i].xy);
float blend = 1.0 - s.x * s.y;
return mix(sampleShadowMap(i), sampleShadowMap(i+1), blend);
}
return sampleShadowMap(i);
}
}
return 1.0;
}

View file

@ -0,0 +1,38 @@
#version 120
uniform mat4 fg_LightMatrix_csm0;
uniform mat4 fg_LightMatrix_csm1;
uniform mat4 fg_LightMatrix_csm2;
uniform mat4 fg_LightMatrix_csm3;
varying vec4 lightSpacePos[4];
void setupShadows(vec4 eyeSpacePos)
{
float normalOffset = 0.005;
float costheta = clamp(dot(gl_Normal, gl_LightSource[0].position.xyz), 0.0, 1.0);
float slopeScale = 1.0 - costheta;
normalOffset *= slopeScale;
vec4 offsetPos = gl_ModelViewMatrix *
(gl_Vertex + vec4(gl_Normal, 0.0) * normalOffset);
vec4 offsets[4];
offsets[0] = fg_LightMatrix_csm0 * offsetPos;
offsets[1] = fg_LightMatrix_csm1 * offsetPos;
offsets[2] = fg_LightMatrix_csm2 * offsetPos;
offsets[3] = fg_LightMatrix_csm3 * offsetPos;
lightSpacePos[0] = fg_LightMatrix_csm0 * eyeSpacePos;
lightSpacePos[1] = fg_LightMatrix_csm1 * eyeSpacePos;
lightSpacePos[2] = fg_LightMatrix_csm2 * eyeSpacePos;
lightSpacePos[3] = fg_LightMatrix_csm3 * eyeSpacePos;
// Offset only in UV space
lightSpacePos[0].xy = offsets[0].xy;
lightSpacePos[1].xy = offsets[1].xy;
lightSpacePos[2].xy = offsets[2].xy;
lightSpacePos[3].xy = offsets[3].xy;
}

View file

@ -35,6 +35,8 @@ float fog_func (in float targ, in float alt);
vec3 get_hazeColor(in float light_arg);
vec3 filter_combined (in vec3 color) ;
float getShadowing();
float luminance(vec3 color)
{
return dot(vec3(0.212671, 0.715160, 0.072169), color);
@ -69,12 +71,14 @@ void main()
NdotL = dot(n, lightDir);
if (NdotL > 0.0) {
color += diffuse_term * NdotL;
float shadowmap = getShadowing();
color += diffuse_term * NdotL * shadowmap;
NdotHV = max(dot(n, halfVector), 0.0);
if (gl_FrontMaterial.shininess > 0.0)
specular.rgb = (gl_FrontMaterial.specular.rgb
* light_specular.rgb
* pow(NdotHV, gl_FrontMaterial.shininess));
* pow(NdotHV, gl_FrontMaterial.shininess)
* shadowmap);
}
color.a = diffuse_term.a;
// This shouldn't be necessary, but our lighting becomes very

View file

@ -56,6 +56,7 @@ float fog_func (in float targ, in float alt);
vec3 get_hazeColor(in float light_arg);
vec3 filter_combined (in vec3 color) ;
float getShadowing();
@ -305,12 +306,14 @@ if ((dist < 5000.0)&& (quality_level > 3) && (wetness>0.0))
NdotL = NdotL + 1.0 * (noisegrad_10m + 0.5* noisegrad_5m) * mix_factor/0.8 * (1.0 - smoothstep(1000.0, 2000.0, dist));
}
if (NdotL > 0.0) {
color += diffuse_term * NdotL;
float shadowmap = getShadowing();
color += diffuse_term * NdotL * shadowmap;
NdotHV = max(dot(n, halfVector), 0.0);
if (gl_FrontMaterial.shininess > 0.0)
specular.rgb = ((gl_FrontMaterial.specular.rgb * 0.1 + (water_factor * vec3 (1.0, 1.0, 1.0)))
* light_specular.rgb
* pow(NdotHV, gl_FrontMaterial.shininess + (20.0 * water_factor)));
* pow(NdotHV, gl_FrontMaterial.shininess + (20.0 * water_factor))
* shadowmap);
}
color.a = 1.0;//diffuse_term.a;
// This shouldn't be necessary, but our lighting becomes very

View file

@ -55,6 +55,7 @@ const float EarthRadius = 5800000.0;
const float terminator_width = 200000.0;
vec3 moonlight_perception (in vec3 light);
void setupShadows(vec4 eyeSpacePos);
float light_func (in float x, in float a, in float b, in float c, in float d, in float e)
{
@ -84,7 +85,8 @@ void main()
float scattering;
rawPos = gl_Vertex.xy;
worldPos = (osg_ViewMatrixInverse *gl_ModelViewMatrix * gl_Vertex).xyz;
vec4 eyePos = gl_ModelViewMatrix * gl_Vertex;
worldPos = (osg_ViewMatrixInverse * eyePos).xyz;
steepness = dot(normalize(gl_Normal), vec3 (0.0, 0.0, 1.0));
@ -298,7 +300,8 @@ if (use_IR_vision)
gl_FrontColor.a = mie_angle;
gl_BackColor.a = mie_angle;
}
setupShadows(eyePos);
}

View file

@ -88,6 +88,7 @@ vec3 searchlight();
vec3 landing_light(in float offset, in float offsetv);
vec3 filter_combined (in vec3 color) ;
float getShadowing();
// a fade function for procedural scales which are smaller than a pixel
@ -442,13 +443,15 @@ if ((dist < 5000.0) && (combined_wetness>0.0))
NdotL = NdotL + (1.0-snow_mix_factor) * 0.3* dot_texel.a * (0.5* dotnoisegrad_10m * detail_fade(1.0 * dot_size, view_angle, dist) +0.5 * dotnoisegrad_10m * noise_01m * detail_fade(0.1, view_angle, dist)) ;
if (NdotL > 0.0) {
float shadowmap = getShadowing();
if (cloud_shadow_flag == 1) {NdotL = NdotL * shadow_func(relPos.x, relPos.y, 0.3 * noise_250m + 0.5 * noise_500m+0.2 * noise_1500m, dist);}
color += diffuse_term * NdotL;
color += diffuse_term * NdotL * shadowmap;
NdotHV = max(dot(n, halfVector), 0.0);
if (gl_FrontMaterial.shininess > 0.0)
specular.rgb = ((gl_FrontMaterial.specular.rgb * 0.1 + (water_factor * vec3 (1.0, 1.0, 1.0)))
* light_specular.rgb
* pow(NdotHV, gl_FrontMaterial.shininess + (20.0 * water_factor)));
* pow(NdotHV, gl_FrontMaterial.shininess + (20.0 * water_factor))
* shadowmap);
}
color.a = 1.0;//diffuse_term.a;
// This shouldn't be necessary, but our lighting becomes very

View file

@ -51,6 +51,8 @@ uniform mat4 osg_ViewMatrixInverse;
float earthShade;
float yprime_alt;
void setupShadows(vec4 eyeSpacePos);
vec3 moonlight_perception (in vec3 light);
// This is the value used in the skydome scattering shader - use the same here for consistency?
@ -88,7 +90,8 @@ void main()
float scattering;
rawPos = gl_Vertex.xy;
worldPos = (osg_ViewMatrixInverse *gl_ModelViewMatrix * gl_Vertex).xyz;
vec4 eyePos = gl_ModelViewMatrix * gl_Vertex;
worldPos = (osg_ViewMatrixInverse * eyePos).xyz;
steepness = dot(normalize(gl_Normal), vec3 (0.0, 0.0, 1.0));
@ -290,7 +293,7 @@ if (use_IR_vision)
gl_FrontColor.a = mie_angle;
gl_BackColor.a = mie_angle;
setupShadows(eyePos);
}

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -17,4 +17,7 @@
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -15,4 +15,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -16,4 +16,7 @@
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -383,4 +383,7 @@ print("Done.");
</animation>-->
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -30,4 +30,7 @@
</condition>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -12,4 +12,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -12,4 +12,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -12,4 +12,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<object-name>rect</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<object-name>rect</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<object-name>rect</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<object-name>rect</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -13,4 +13,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -12,4 +12,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -12,4 +12,7 @@
<enable-hot type="bool">false</enable-hot>
</animation>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
<object-name>mesh</object-name>
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

View file

@ -14,4 +14,7 @@
</effect>
<animation>
<type>noshadow</type>
</animation>
</PropertyList>

Some files were not shown because too many files have changed in this diff Show more