Difference between revisions of "LlGetOwnerKey"
Jump to navigation
Jump to search
All Issues ~ Search JIRA for related Bugs
Simon Linden (talk | contribs) m |
|||
(10 intermediate revisions by 6 users not shown) | |||
Line 1: | Line 1: | ||
{{LSL_Function | |||
|inject-2={{LSL_Function/prim|id|sim=*}} | |||
|func_id=182|func_sleep=0.0|func_energy=10.0 | |func_id=182|func_sleep=0.0|func_energy=10.0 | ||
|func=llGetOwnerKey|sort=GetOwnerKey | |func=llGetOwnerKey|sort=GetOwnerKey | ||
Line 5: | Line 6: | ||
|func_footnote | |func_footnote | ||
|func_desc | |func_desc | ||
|return_text=that is the owner of prim | |return_text=that is the owner of prim {{LSLP|id}} | ||
|spec | |spec | ||
|caveats= | |caveats= | ||
* Returns | * Returns {{LSLP|id}} if {{LSLP|id}} is not found in the region or is not a prim. | ||
** Owner information becomes unavailable ''immediately'' on derez or detach. For example, if | ** Owner information becomes unavailable ''immediately'' on derez or detach. For example, if a prim chats at derez or detach time, {{LSLP|id}} can be returned even inside [[listen]] events of nearby objects. <sup>{{Jira|SVC-5095}}</sup> | ||
* Also returns | * Also returns {{LSLP|id}} for avatars, use [[llGetAgentSize]] instead to distinguish them from prims that do not exist. | ||
* Returns NULL_KEY if the id passed in is not a valid key | |||
|constants | |constants | ||
|examples=< | |examples= | ||
<source lang="lsl2"> | |||
default | default | ||
{ | { | ||
state_entry() | state_entry() | ||
{ | { | ||
// listen to anything talking on channel 1 | |||
llListen(1, "", "" | llListen(1, "", NULL_KEY, ""); | ||
// Type "/1 " + message (such as "/1 poke") to chat 'message' on channel 1. | |||
} | } | ||
listen(integer channel, string name, key id, string message) | |||
{ | { | ||
key ownerOfThisObject = llGetOwner(); | |||
key ownerOfSpeaker = llGetOwnerKey(id); | |||
// if whoever is talking is the owner of this object | |||
// or if the owner of the object talking is the owner of this object | |||
if (ownerOfSpeaker == ownerOfThisObject) | |||
llOwnerSay(name + " has the same owner as me ^_^"); | { | ||
llOwnerSay("'" + name + "' has the same owner as me ^_^"); | |||
} | } | ||
} | } | ||
}</ | } | ||
</source> | |||
|helpers | |helpers | ||
|also_functions={{LSL DefineRow||[[llKey2Name]]|}} | |also_functions={{LSL DefineRow||[[llKey2Name]]|}} | ||
{{LSL DefineRow||[[llRequestAgentData]]|}} | {{LSL DefineRow||[[llRequestAgentData]]|}} | ||
{{LSL DefineRow||[[llGetObjectDetails]]|}} | {{LSL DefineRow||[[llGetObjectDetails]]|[[OBJECT_OWNER]]}} | ||
{{LSL DefineRow||[[llGetOwner]]|}} | {{LSL DefineRow||[[llGetOwner]]|}} | ||
|also_tests | |also_tests |
Latest revision as of 11:15, 25 September 2017
LSL Portal | Functions | Events | Types | Operators | Constants | Flow Control | Script Library | Categorized Library | Tutorials |
Summary
Function: key llGetOwnerKey( key id );182 | Function ID |
0.0 | Forced Delay |
10.0 | Energy |
Returns a key that is the owner of prim id
• key | id | – | prim UUID that is in the same region |
Caveats
- Returns id if id is not found in the region or is not a prim.
- Also returns id for avatars, use llGetAgentSize instead to distinguish them from prims that do not exist.
- Returns NULL_KEY if the id passed in is not a valid key
Examples
default
{
state_entry()
{
// listen to anything talking on channel 1
llListen(1, "", NULL_KEY, "");
// Type "/1 " + message (such as "/1 poke") to chat 'message' on channel 1.
}
listen(integer channel, string name, key id, string message)
{
key ownerOfThisObject = llGetOwner();
key ownerOfSpeaker = llGetOwnerKey(id);
// if whoever is talking is the owner of this object
// or if the owner of the object talking is the owner of this object
if (ownerOfSpeaker == ownerOfThisObject)
{
llOwnerSay("'" + name + "' has the same owner as me ^_^");
}
}
}
See Also
Functions
• | llKey2Name | |||
• | llRequestAgentData | |||
• | llGetObjectDetails | – | OBJECT_OWNER | |
• | llGetOwner |