Difference between revisions of "LlSetTouch"

From Second Life Wiki
Jump to navigation Jump to search
m
Line 2: Line 2:
|func_id
|func_id
|mode=request
|mode=request
|func_sleep
|func_sleep=0.0
|func_energy
|func_energy=10.0
|func=llSetTouch
|func=llSetTouch
|sort=SetTouch
|sort=SetTouch

Revision as of 14:50, 24 September 2007

Emblem-important-yellow.png LSL Feature Request
The described function does not exist. This article is a feature request.

Summary

Function: llSetTouch( key id );
0.0 Forced Delay
10.0 Energy

This would be a nice function to add control over the touch event, and to limit the touch to certain specified avatars. If the passed id is NULL_KEY all touches are granted. If no llSetTouch() is specified all touches are granted too.

• key id Avatar key

Specification

This limits the possibility to touch an object to the passed key id. Useful to prevent simultaneous clicks by different Avatars on the same moment on the same object.

Caveats

This should also work on touch_start and touch_end events...

Examples

default
 {
  state_entry()
   {
     llSetTouch(llGetOwner()); 
     // only the boss may click the object
   }
  touch(integer num_detected); 
     // if another avatar touches as first nothing happens!
     // only responds to click of the owner
   { 
     llSay(0, "Hi Owner!");
     state all;
   }
 }
 state all
 {
   state_entry()
   {
     llSetTouch(NULL_KEY); // or shorter syntax: llSetTouch() : ALL avatars granted to click
                           // The owner has clicked and authorized others to click ..
   }
   touch(integer num_detected) // Now everybody can click ..
   {
     llSay(0,"Hi, Avatar");  // chatted to avatar who clicked
   }
 }

Deep Notes

Signature

//function void llSetTouch( key id );