Difference between revisions of "User:Toady Nakamura/Two States Light"
Jump to navigation
Jump to search
m (minor) |
m (minor) |
||
Line 1: | Line 1: | ||
Using two states can sometimes be an elegant solution to on/off. | Using two states can sometimes be an elegant solution to on/off. | ||
*Original framework 04-16-08 by [[User:Toady Nakamura|Toady Nakamura]] | |||
*Light call modified from Simon Kline's classes "Scripting from Scratch" | |||
<lsl> | <lsl> | ||
Line 36: | Line 39: | ||
</lsl> | </lsl> | ||
Revision as of 12:14, 14 May 2012
Using two states can sometimes be an elegant solution to on/off.
- Original framework 04-16-08 by Toady Nakamura
- Light call modified from Simon Kline's classes "Scripting from Scratch"
<lsl>
vector color = <1,1,1>; // Use to change the color of the light float intensity = 1.000; // Use to change the intensity of the light, from 0 up to 1 float radius = 10.000; // Use to change the Radius of the light, from 0 up to 20 float falloff = 0.750; // Use to set the falloff of the light, from 0 up to 2
default {
on_rez(integer param) { llResetScript(); } touch_start(integer total_number) { llSetPrimitiveParams([PRIM_POINT_LIGHT, TRUE, color, intensity, radius, falloff]); llSetPrimitiveParams([PRIM_FULLBRIGHT, ALL_SIDES, TRUE]); state unlit; }
}
state unlit {
touch_start(integer total_number) { llSetPrimitiveParams([PRIM_POINT_LIGHT, FALSE, llSetPrimitiveParams([PRIM_POINT_LIGHT, FALSE, // when this is false, light is off, color, intensity, radius, falloff]); // rest of params don't matter llSetPrimitiveParams([PRIM_FULLBRIGHT, ALL_SIDES, FALSE]); state default; }
}
</lsl>