Difference between revisions of "LlPushObject"

From Second Life Wiki
Jump to navigation Jump to search
(objects can push themselves in no-push areas)
 
(6 intermediate revisions by 5 users not shown)
Line 1: Line 1:
{{LSL_Function
{{LSL_Function
|inject-2={{LSL_Function/uuid|target|sim=*|object=*|group=}}
|func_id=165|func_sleep=0.0|func_energy=10.0
|func_id=165|func_sleep=0.0|func_energy=10.0
|func=llPushObject
|func=llPushObject
|p1_type=key|p1_name=target|p1_desc=Avatar or object [[UUID]] in the sim
|p1_type=key|p1_name=target|p1_desc
|p2_type=vector|p2_name=impulse|p2_desc=Direction and force of push. Direction is affected by '''local'''.
|p2_type=vector|p2_name=impulse|p2_desc=Direction and force of push. Direction is affected by {{LSLP|local}}.|p2_hover=Direction and force of push. Direction is affected by 'local'.
|p3_type=vector|p3_name=ang_impulse|p3_desc=Rotational force.
|p3_type=vector|p3_name=ang_impulse|p3_desc=Rotational force.
|p4_type=integer|p4_name=local|p4_desc=boolean, if TRUE uses the local axis of '''target''', if FALSE uses the region axis.
|p4_type=integer|p4_name=local|p4_desc=boolean, if {{LSL Const|TRUE|integer|1}} uses the [[Viewer coordinate frames#Local|local]] axis of {{LSLP|target}}, if {{LSL Const|FALSE|integer|0}} uses the [[Viewer coordinate frames#Region|region]] axis.|p4_hover=boolean, if TRUE uses the local axis of 'target', if FALSE uses the region axis.
|func_footnote
|func_footnote
|func_desc=Applies '''impulse''' and '''ang_impulse''' to object '''id'''
|func_desc=Applies {{LSLP|impulse}} and {{LSLP|ang_impulse}} to object {{LSLP|target}}
|return_text
|return_text
|spec
|spec
|caveats=*Only works on land where Push is not restricted or where the script is owned by the land owner.
|caveats=*Only works on land where Push is not restricted or where the script is owned by the land owner.
**If the land is owned by a group, the scripted object must be deeded to the same group.
**If the land is owned by a group, the scripted object must be deeded to the same group.
**In no-push areas an object can only push its owner or itself.
*The effectiveness of Push is modulated by the amount of [[Energy|script energy]] available.
*The effectiveness of Push is modulated by the amount of [[Energy|script energy]] available.
**There is a [[LlPushObject/Havok4Implementation|simplified code snippet]] describing how Push is implemented in the Havok4 project and reveals some of the details of how the energy budget affects the final Push magnitude.
**There is a [[LlPushObject/Havok4Implementation|simplified code snippet]] describing how Push is implemented in the Havok4 project and reveals some of the details of how the energy budget affects the final Push magnitude.
*In no-push areas an object can only push its owner.
*{{LSLP|ang_impulse}} is ignored when applying to agents or their attachments.
*'''ang_impulse''' is ignored when applying to agents.
*[[Energy]] is fully depleted by this function when either {{LSLP|impulse}} or {{LSLP|ang_impulse}} is nonzero.  If {{LSLP|impulse}} is nonzero, it will drain all energy in the object before {{LSLP|ang_impulse}} is processed, causing the push to be purely linear.
*[[Energy]] use is calculated as magnitude of '''impulse''' divided by 20,000.
*The push impact is diminished with distance by a factor of distance cubed.
*The push impact is diminished with distance by a factor of distance cubed.
|constants
|constants
|examples=
|examples=
<lsl>// Pushes the collided object or avatar.
<source lang="lsl2">// Pushes the collided object or avatar.
default
default
{
{
Line 27: Line 28:
         llPushObject(llDetectedKey(0),<0,0,100>, <0,0,100>, TRUE);
         llPushObject(llDetectedKey(0),<0,0,100>, <0,0,100>, TRUE);
     }
     }
}</lsl>
}</source>
|helpers
|helpers
|also_functions
|also_functions

Latest revision as of 06:02, 31 May 2024

Summary

Function: llPushObject( key target, vector impulse, vector ang_impulse, integer local );
0.0 Forced Delay
10.0 Energy

Applies impulse and ang_impulse to object target

• key target avatar or object UUID that is in the same region
• vector impulse Direction and force of push. Direction is affected by local.
• vector ang_impulse Rotational force.
• integer local boolean, if TRUE uses the local axis of target, if FALSE uses the region axis.

Caveats

  • Only works on land where Push is not restricted or where the script is owned by the land owner.
    • If the land is owned by a group, the scripted object must be deeded to the same group.
    • In no-push areas an object can only push its owner or itself.
  • The effectiveness of Push is modulated by the amount of script energy available.
    • There is a simplified code snippet describing how Push is implemented in the Havok4 project and reveals some of the details of how the energy budget affects the final Push magnitude.
  • ang_impulse is ignored when applying to agents or their attachments.
  • Energy is fully depleted by this function when either impulse or ang_impulse is nonzero. If impulse is nonzero, it will drain all energy in the object before ang_impulse is processed, causing the push to be purely linear.
  • The push impact is diminished with distance by a factor of distance cubed.

Examples

// Pushes the collided object or avatar.
default
{
    collision_start(integer num_detected)
    {
        llPushObject(llDetectedKey(0),<0,0,100>, <0,0,100>, TRUE);
    }
}

Deep Notes

Signature

function void llPushObject( key target, vector impulse, vector ang_impulse, integer local );