Difference between revisions of "LlTeleportAgent"

From Second Life Wiki
Jump to navigation Jump to search
m (Is the "llRequestPermissions" language prefered?)
Line 1: Line 1:
{{KBwarning|This function is still under development and is subject to change at any time.}}
{{LSL_Function
{{LSL_Function
|inject-1={{LSL Generic/pre-release|3=RC Magnum channel}}
|inject-2={{LSL Function/avatar|avatar|region=*}}
|inject-3={{LSL_Function/permission|PERMISSION_TELEPORT|grant=<code>{{LSL Param|avatar}}</code>}}
|func=llTeleportAgent
|func=llTeleportAgent
|sort=TeleportAgent
|sort=TeleportAgent
|p1_type=key|p1_name=avatar|p1_desc=The key of the avatar for which to request a teleport.
|p1_type=key|p1_name=avatar|p1_desc=&#32;(the avatar to teleport)
|p2_type=string|p2_name=landmark|p2_desc=The name of a landmark in the object's inventory; landmarks may be used to teleport to any valid location in Second Life. This string may be left blank for teleporting within the same region.
|p2_type=string|p2_name=landmark|p2_desc=The name of a landmark in the object's inventory; landmarks may be used to teleport to any valid location in Second Life. This string may be left blank for teleporting within the same region.
|p3_type=vector|p3_name=position|p3_desc=The position within the local region to teleport the avatar to if no landmark was provided.
|p3_type=vector|p3_name=position|p3_desc=The position within the local region to teleport the avatar to if no landmark was provided.
|p4_type=vector|p4_name=look_at|p4_desc=The position within the target region that the avatar should be turned to face upon arrival.
|p4_type=vector|p4_name=look_at|p4_desc=The position within the target region that the avatar should be turned to face upon arrival.
|func_desc=Requests a teleport of <code>avatar</code> to a <code>landmark</code> stored in the object's inventory.  If no landmark is provided (an empty string), the avatar is teleported to the location <code>position</code> in the current region. In either case, the avatar is turned to face the position given by <code>look_at</code> in local coordinates.
|func_desc=Requests a teleport of <code>avatar</code> to a <code>landmark</code> stored in the object's inventory.  If no landmark is provided (an empty string), the avatar is teleported to the location <code>position</code> in the current region. In either case, the avatar is turned to face the position given by <code>look_at</code> in local coordinates.
|func_footnote=This call requires [[PERMISSION_TELEPORT]], which must be requested with [[llRequestPermissions]].
|func_footnote
|caveats=* Use of this call requires the target avatar to have granted [[PERMISSION_TELEPORT]], which must be requested using [[llRequestPermissions]].
|caveats=
* Sitting avatars cannot be teleported using this function.
* Sitting avatars cannot be teleported using this function. You must [[llUnSit]] them first.
|examples=
|examples=
'''Without a landmark in the object's inventory'''
'''Without a landmark in the object's inventory'''
Line 65: Line 67:
|also_functions= *[[llRequestPermissions]]
|also_functions= *[[llRequestPermissions]]
|notes=
|notes=
|cat1=Teleport
|cat2
|cat3
|cat4
}}
}}

Revision as of 22:30, 29 May 2012

Emblem-important-red.png Pre-release Documentation Warning!

This function is only available in RC Magnum channel. This documentation was written prior to its final release so it may not match the final implementation.

Summary

Function: llTeleportAgent( key avatar, string landmark, vector position, vector look_at );

Requests a teleport of avatar to a landmark stored in the object's inventory. If no landmark is provided (an empty string), the avatar is teleported to the location position in the current region. In either case, the avatar is turned to face the position given by look_at in local coordinates.

• key avatar avatar UUID that is in the same region (the avatar to teleport)
• string landmark The name of a landmark in the object's inventory; landmarks may be used to teleport to any valid location in Second Life. This string may be left blank for teleporting within the same region.
• vector position The position within the local region to teleport the avatar to if no landmark was provided.
• vector look_at The position within the target region that the avatar should be turned to face upon arrival.

To run this function the script must request the PERMISSION_TELEPORT permission with llRequestPermissions and it must be granted by avatar.

Caveats

Permissions
  • Once the PERMISSION_TELEPORT permission is granted there is no way to revoke it except from inside the script (for example, with a new llRequestPermissions call) or the script is reset or deleted.
  • Sitting avatars cannot be teleported using this function. You must llUnSit them first.

Examples

Without a landmark in the object's inventory <lsl>key teleportee;

default {

   state_entry()
   {
       llSay(0, "Touch to teleport");
   }
   touch_start(integer total_num)
   {
       teleportee = llDetectedKey(0);
       llRequestPermissions(teleportee, PERMISSION_TELEPORT);
   }
   
   run_time_permissions(integer perm)
   {
       if(PERMISSION_TELEPORT & perm)
       {
           llTeleportAgent(teleportee, "", <13.0, 38.0, 23.5>, <13.0, 12.0, 23.5>);
       }
   }

} </lsl> With a landmark in the objects inventory <lsl> key teleportee;

default {

   state_entry()
   {
       llSay(0, "Touch to teleport");
   }
   touch_start(integer total_num)
   {
       teleportee = llDetectedKey(0);
       llRequestPermissions(teleportee, PERMISSION_TELEPORT);
   }
   
   run_time_permissions(integer perm)
   {
       if(PERMISSION_TELEPORT & perm)
       {
           llTeleportAgent(teleportee, "Experience Tools 1", <0.0, 0.0, 0.0>, <0.0, 0.0, 0.0>);
       }
   }

}

</lsl>

See Also

Events

•  run_time_permissions Permission receiving event

Functions

•  llGetPermissions Get the permissions granted
•  llGetPermissionsKey Get the agent who granted permissions
•  llRequestPermissions Request permissions

Articles

•  Script permissions

Deep Notes

Signature

function void llTeleportAgent( key avatar, string landmark, vector position, vector look_at );