setLightAttenuation: Difference between revisions

From Bohemia Interactive Community
m (Text replacement - "<code>([^ ]+) <\/code>" to "<code>$1</code>")
m (Text replacement - "<sqf>([^↵][^<]*↵[^<]*)<\/sqf>" to "<sqf> $1 </sqf>")
 
(3 intermediate revisions by 2 users not shown)
Line 10: Line 10:
|eff= local
|eff= local


|descr= Sets attenuation of light. Standard method of attenuation (1 / (constant + linear*dist + quadratic*dist*dist)). ''start'' param represents distance, where the attenuation starts to take effects (dist <nowiki>=</nowiki> distance - start).
|descr= Sets attenuation of light. Standard method of attenuation (1 / (constant + linear*dist + quadratic*dist*dist)).
''start'' param represents distance where the attenuation starts to take effects (dist = distance - start).


|s1= light [[setLightAttenuation]] [start, constant, linear, quadratic, hardlimitstart, hardlimitend]
|s1= light [[setLightAttenuation]] [start, constant, linear, quadratic, hardlimitstart, hardlimitend]
Line 16: Line 17:
|p1= light: [[Object]]
|p1= light: [[Object]]


|p2= [start, constant, linear, quadratic, hardlimitstart, hardlimitend]: [[Array]]
|p2= start: [[Number]] - distance with 100% intensity, falloff starts here


|p3= start: [[Number]] - distance with 100% intensity, falloff starts here
|p3= constant: [[Number]] - constant attenuation coef


|p4= constant: [[Number]] - constant attenuation coef
|p4= linear: [[Number]] - linear attenuation coef


|p5= linear: [[Number]] - linear attenuation coef
|p5= quadratic: [[Number]] - quadratic attenuation coef


|p6= quadratic: [[Number]] - quadratic attenuation coef
|p6= hardlimitstart: [[Number]] - (Optional) max distance hard limit start (start of fading of intensity to 0) in m


|p7= hardlimitstart (Optional): [[Number]] - max distance hard limit start (start of fading of intensity to 0) in m
|p7= hardlimitend: [[Number]] - (Optional) max distance hard limit end (end of fading of intensity to 0) in m
 
|p8= hardlimitend (Optional): [[Number]] - max distance hard limit end (end of fading of intensity to 0) in m


|r1= [[Nothing]]
|r1= [[Nothing]]
Line 37: Line 36:
}}
}}


<dl class="command_description">
{{Note
 
|user= ffur2007slx2_5
<dt></dt>
|timestamp= 20140325123100
<dd class="notedate">Posted on Mar 25, 2014 - 12:31</dd>
|text= (A3 1.14) [[setLightAttenuation]] array will present fallowing visual effects:<br>
<dt class="note">[[User:ffur2007slx2_5|ffur2007slx2_5]]</dt>
<dd class="note">
(A3 1.14) [[setLightAttenuation]] array will present fallowing visual effects:<br>
<br>
<br>
[start(SCALAR), constant(SCALAR), linear (SCALAR), quadratic(SCALAR)]<br>
[start(SCALAR), constant(SCALAR), linear (SCALAR), quadratic(SCALAR)]<br>
<br>
<br>
'''start(SCALAR)''' – Number can be unlimited, this parameter determines the range that the light source takes effect. Terrain environmental color will be bathed by [[‎setLightAmbient]] within the range and its covered objects will reflect the color by [[‎setLightColor]].<br>
'''start(SCALAR)''' – Number can be unlimited, this parameter determines the range that the light source takes effect. Terrain environmental color will be bathed by [[setLightAmbient]] within the range and its covered objects will reflect the color by [[setLightColor]].<br>
<br>
<br>
'''constant(SCALAR)''' – Support signed number, this parameter determines the brightness proportion of the light source, higher the number is, less the brightness will be, vice versa. Any minus value passed will be treated as 0 (100% brightness). In other words, this parameter is related with [[‎‎setLightBrightness]] and [[‎setLightIntensity]].<br>
'''constant(SCALAR)''' – Support signed number, this parameter determines the brightness proportion of the light source, higher the number is, less the brightness will be, vice versa. Any minus value passed will be treated as 0 (100% brightness). In other words, this parameter is related with [[setLightBrightness]] and [[setLightIntensity]].<br>
<br>
<br>
'''linear (SCALAR)''' – Support signed number, effective range is from 0 ~ 100 (passed minus value will be treated as 0), this parameter determines the concentration of the light source, higher the number is, more will the light concentrate, vice versa. In other words, this parameter will turn the source into spotlight and sharpens its light circle border.<br>
'''linear (SCALAR)''' – Support signed number, effective range is from 0 ~ 100 (passed minus value will be treated as 0), this parameter determines the concentration of the light source, higher the number is, more will the light concentrate, vice versa. In other words, this parameter will turn the source into spotlight and sharpens its light circle border.<br>
Please pay attention to a special value: '''4.31918e-005'''<br>
Please pay attention to a special value: '''4.31918e-005'''<br>
e.g.<br>
e.g.<br>
<code>_light setLightAttenuation [2,4,'''4.31918e-005''',0]; //This value will make the light source reach an ultra high effect range. <br>Any initial param set before will be discarded and overwritten.</code>  
<sqf>
// This value will make the light source reach an ultra high effect range. Any initial param set before will be discarded and overwritten.
_light setLightAttenuation [2, 4, 4.31918e-005, 0];
</sqf>  
<br>
<br>
'''quadratic(SCALAR)''' – Support signed number (range unlimited, passed minus number will be treated as 0), this parameter determines the range that the light source is visible and its visual presentation looks similar to linear. 0 means the maximum visible range. In further explanation, a less bright source can’t be seen out of the range on the land but still visible on the sea, and a bright enough source won’t be effected by the passed range who is still visible out of the range.<br>
'''quadratic(SCALAR)''' – Support signed number (range unlimited, passed minus number will be treated as 0), this parameter determines the range that the light source is visible and its visual presentation looks similar to linear. 0 means the maximum visible range. In further explanation, a less bright source can’t be seen out of the range on the land but still visible on the sea, and a bright enough source won’t be effected by the passed range who is still visible out of the range.<br>
Please pay attention to a special value: '''4.31918e-005'''<br>
Please pay attention to a special value: '''4.31918e-005'''<br>
e.g.<br>
e.g.<br>
<code>_light setLightAttenuation [6,0,0,'''4.31918e-005''']; //This value will make the light source reach an ultra high effect range.<br> Any initial param set before will be discarded and overwritten.</code>
<sqf>
 
// This value will make the light source reach an ultra high effect range. Any initial param set before will be discarded and overwritten.
</dl>
_light setLightAttenuation [6, 0, 0, 4.31918e-005];
</sqf>  
}}

Latest revision as of 19:43, 3 September 2024

Hover & click on the images for description

Description

Description:
Sets attenuation of light. Standard method of attenuation (1 / (constant + linear*dist + quadratic*dist*dist)). start param represents distance where the attenuation starts to take effects (dist = distance - start).
Groups:
Lights

Syntax

Syntax:
light setLightAttenuation [start, constant, linear, quadratic, hardlimitstart, hardlimitend]
Parameters:
light: Object
start: Number - distance with 100% intensity, falloff starts here
constant: Number - constant attenuation coef
linear: Number - linear attenuation coef
quadratic: Number - quadratic attenuation coef
hardlimitstart: Number - (Optional) max distance hard limit start (start of fading of intensity to 0) in m
hardlimitend: Number - (Optional) max distance hard limit end (end of fading of intensity to 0) in m
Return Value:
Nothing

Examples

Example 1:
myLight setLightAttenuation [2, 4, 4, 0, 9, 10];

Additional Information

See also:
setLightAmbient setLightColor lightAttachObject lightDetachObject setLightBrightness setLightIntensity setLightUseFlare setLightFlareSize setLightFlareMaxDistance setLightDayLight

Notes

Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
ffur2007slx2_5 - c
Posted on Mar 25, 2014 - 12:31 (UTC)
(A3 1.14) setLightAttenuation array will present fallowing visual effects:

[start(SCALAR), constant(SCALAR), linear (SCALAR), quadratic(SCALAR)]

start(SCALAR) – Number can be unlimited, this parameter determines the range that the light source takes effect. Terrain environmental color will be bathed by setLightAmbient within the range and its covered objects will reflect the color by setLightColor.

constant(SCALAR) – Support signed number, this parameter determines the brightness proportion of the light source, higher the number is, less the brightness will be, vice versa. Any minus value passed will be treated as 0 (100% brightness). In other words, this parameter is related with setLightBrightness and setLightIntensity.

linear (SCALAR) – Support signed number, effective range is from 0 ~ 100 (passed minus value will be treated as 0), this parameter determines the concentration of the light source, higher the number is, more will the light concentrate, vice versa. In other words, this parameter will turn the source into spotlight and sharpens its light circle border.
Please pay attention to a special value: 4.31918e-005
e.g.
// This value will make the light source reach an ultra high effect range. Any initial param set before will be discarded and overwritten. _light setLightAttenuation [2, 4, 4.31918e-005, 0];

quadratic(SCALAR) – Support signed number (range unlimited, passed minus number will be treated as 0), this parameter determines the range that the light source is visible and its visual presentation looks similar to linear. 0 means the maximum visible range. In further explanation, a less bright source can’t be seen out of the range on the land but still visible on the sea, and a bright enough source won’t be effected by the passed range who is still visible out of the range.
Please pay attention to a special value: 4.31918e-005
e.g.
// This value will make the light source reach an ultra high effect range. Any initial param set before will be discarded and overwritten. _light setLightAttenuation [6, 0, 0, 4.31918e-005];