OsSetRegionWaterHeight
From OpenSimulator
(Difference between revisions)
Line 33: | Line 33: | ||
} | } | ||
</source> | </source> | ||
+ | |||
<source lang="lsl"> | <source lang="lsl"> | ||
// Hochwasser - flooding | // Hochwasser - flooding | ||
Line 83: | Line 84: | ||
</source> | </source> | ||
− | < | + | <source lang="lsl"> |
// Gezeiten Tide V1.0.1 | // Gezeiten Tide V1.0.1 | ||
Revision as of 08:20, 26 August 2023
osSetRegionWaterHeight(float height)
| |
Sets the water height for the current region. | |
Threat Level | High |
Permissions | ESTATE_MANAGER,ESTATE_OWNER |
Extra Delay | 0 seconds |
Example(s) | |
// Region Water Height utility // I know, it's probably horribly inefficient and confusing, but it works. // Arkaniad Exonar, '10 float g_WaterHeight; // <---- Storage Var integer g_ListenChan = 0; list g_ltmp; // <--------Temporary buffer default { state_entry() { llListen(g_ListenChan, "", llGetOwner(), ""); //Prepare listener llSay(0, "Ready for commands"); } listen(integer channel, string name, key id, string message) { g_ltmp = llParseString2List(message, [" "], []); // Split the message into chunks if(llList2String(g_ltmp, 0) == "/waterheight") // Self explanatory { osSetRegionWaterHeight(llList2Float(g_ltmp, 1)); // Set the region water height to the specified value llSay(0, "Setting region water height to "+llList2String(g_ltmp, 1)+"m (In case anyone was wondering)"); g_ltmp = []; // Flush buffers } } } // Hochwasser - flooding integer waterstatus = TRUE; float zaehler = 20.00; float tspeed = 0.25; flooding() { while ( zaehler >= 20.00 ) { llSleep(tspeed); osSetRegionWaterHeight(zaehler); zaehler = zaehler - 0.01; } } drying() { while ( zaehler <= 20.49 ) { llSleep(tspeed); osSetRegionWaterHeight(zaehler); zaehler = zaehler + 0.01; } } default { state_entry() { osSetRegionWaterHeight(20.0); } touch_start(integer total_number) { if ( waterstatus ) { waterstatus = FALSE; flooding(); } else { waterstatus = TRUE; drying(); } llSay(0, " Wasserstand Fertig!"); } } // Gezeiten Tide V1.0.1 integer waterstatus = TRUE; float zaehler = 20.00; float tspeed = 0.1; float gap = 2.0; float counter = 0.0; flooding() { while ( zaehler >= 20.00 ) { llSleep(tspeed); osSetRegionWaterHeight(zaehler); zaehler = zaehler - 0.01; } } drying() { while ( zaehler <= 20.15 ) { llSleep(tspeed); osSetRegionWaterHeight(zaehler); zaehler = zaehler + 0.01; } } default { state_entry() { osSetRegionWaterHeight(20.0); llSetTimerEvent(gap); } timer() { counter = counter + gap; if ( waterstatus ) { waterstatus = FALSE; flooding(); } else { waterstatus = TRUE; drying(); } } } |