Difference between revisions of "LlDetectedLinkNumber"

From Second Life Wiki
Jump to navigation Jump to search
m (formatted example)
m
 
(12 intermediate revisions by 5 users not shown)
Line 1: Line 1:
{{LSL_Function/detected|number|linkNumber}}{{LSL_Function
{{LSL_Function
|inject-2={{Issues/SVC-2996}}{{LSL_Function/detected|number|linkNumber|error={{HoverText|0|zero}}}}
|func_id=40|func_sleep=0.0|func_energy=10.0
|func_id=40|func_sleep=0.0|func_energy=10.0
|func=llDetectedLinkNumber
|func=llDetectedLinkNumber
|return_type=integer
|return_type=integer
|return_subtype=link
|return_subtype_disp=link_number
|Return_text=of the triggered event. If not supported by the event, returns zero.
|p1_type=integer|p1_name=number
|p1_type=integer|p1_name=number
|func_footnote=For {{LSLGC|Touch|touch}} and {{LSLGC|Collision|collision}} categories of events only.
|func_footnote=For {{LSLGC|Touch|touch}} and {{LSLGC|Collision|collision}} categories of events only.
|func_desc
|func_desc
|return_text=that is the link number of the triggered event. If not supported by the event, returns zero.
|spec
|spec
|caveats=*Will not work reliably with [[llVolumeDetect]].
|caveats
|constants
|constants
|examples=
|examples=
<lsl>
<source lang="lsl2">
default
default
{
{
// Drop this script into the root prim of of a build
// Touch any prim to learn its link number
     touch_start(integer num_detected)
     touch_start(integer num_detected)
     {
     {
         integer i = 0;
         llOwnerSay("Link number clicked: " + (string)llDetectedLinkNumber(0) );      
        for(; i<num_detected; ++i)
            llWhisper(0, "Link number clicked: " + (string)llDetectedLinkNumber(i));
     }
     }
}
}
</lsl>
</source>
|helpers
|helpers
|also_functions
|also_functions=
|also_events={{LSL DefineRow||[[touch_start]]|}}
{{LSL DefineRow||[[llDetectedTouchFace]]|}}
|also_events=
{{LSL DefineRow||[[touch_start]]|}}
{{LSL DefineRow||[[touch]]|}}
{{LSL DefineRow||[[touch]]|}}
{{LSL DefineRow||[[touch_end]]|}}
{{LSL DefineRow||[[touch_end]]|}}
Line 31: Line 36:
{{LSL DefineRow||[[collision_end]]|}}
{{LSL DefineRow||[[collision_end]]|}}
|also_articles
|also_articles
|issues
|notes
|notes
|cat1=Link
|cat1=Link
|cat2
|cat2=Touch
|cat3
|cat3
|cat4
|cat4
}}
}}

Latest revision as of 23:54, 21 January 2015

Summary

Function: integer llDetectedLinkNumber( integer number );
0.0 Forced Delay
10.0 Energy

Returns the link_number (an integer) of the triggered event. If not supported by the event, returns zero.

• integer number Index of detection information

number does not support negative indexes. For touch and collision categories of events only.

Specification

llDetected* functions only work if called from within Detection events (collision, collision_start, collision_end, sensor, touch, touch_start, touch_end) or in functions called by Detection events. They will fail silently and return unusable values if called during other events.

Caveats

  • llDetectedLinkNumber will return 0 in collision_start and collision_end events of VolumeDetect objects (SVC-2996).
  • If number is out of bounds this function returns 0 and the script continues to execute without an error message.
  • Events that enable the llDetected* functions always return at least one detected item.
    • Detection events are not raised if there is nothing detected.[1]
    • The detection event's items detected parameter is initially never less than 1.[2]

Examples

default
{
// Drop this script into the root prim of of a build
// Touch any prim to learn its link number
    touch_start(integer num_detected)
    {
        llOwnerSay("Link number clicked: " + (string)llDetectedLinkNumber(0) );       
    }
}

See Also

Events

•  touch_start
•  touch
•  touch_end
•  collision_start
•  collision
•  collision_end

Functions

•  llDetectedTouchFace

Articles

•  Detected

Deep Notes

Footnotes

  1. ^ The exception is no_sensor but it doesn't enable llDetected* functions.
  2. ^ Like all event parameters, the user can overwrite the initial value.

Signature

function integer llDetectedLinkNumber( integer number );