Difference between revisions of "LlGetAccel"

From Second Life Wiki
Jump to navigation Jump to search
m (multi lang)
m
 
(8 intermediate revisions by 6 users not shown)
Line 1: Line 1:
{{Multi-lang}}{{LSL_Function
{{LSL_Function
|func_id=78|func_sleep=0.0|func_energy=10.0
|func_id=78|func_sleep=0.0|func_energy=10.0
|func=llGetAccel|return_type=vector
|func=llGetAccel|return_type=vector
Line 6: Line 6:
|return_text=that is the acceleration of the object in the [[Viewer coordinate frames#Region|region]] frame of reference.
|return_text=that is the acceleration of the object in the [[Viewer coordinate frames#Region|region]] frame of reference.
|spec
|spec
|caveats
|caveats=
*Returns [[ZERO_VECTOR]] in attachments regardless of the avatar's acceleration.
*Returns [[ZERO_VECTOR]] in child prims regardless of the linkset's acceleration.
|constants
|constants
|examples=
|examples=
<pre>
<source lang="lsl2">
//A very simple (and not very effective) way of keeping a physical object in place.
//A very simple (and not very effective) way of keeping a physical object in place.
//If the object is moving when the script is put in the object, then the object will continue to move, so long as it doesn't accelerate.  
//If the object is moving when the script is put in the object, then the object will continue to move, so long as it doesn't accelerate.  
//If you ever want to actually stop an object, use llMoveToTarget(llGetPos(), .1)
//If you ever want to actually stop an object, use llMoveToTarget(llGetPos(), .1)
default {
default {
    state_entry() {
    moving_start(){  
          vector ac;
        vector ac;
          @loop { // Go forever
        // Go forever        
              if (llVecMag(ac = llGetAccel()) > .001) { //We're accelerating...
        while(llVecMag(ac = llGetAccel()) > .001) { //We're accelerating...
                    llApplyImpulse(-ac, 0) //Slow us down.
            llApplyImpulse(-ac, 0); //Slow us down.
              }
        }
          }jump loop;
    }
    }
}</source>
}</pre>
|helpers
|helpers
|also_functions=
|also_functions=
{{LSL DefineRow||[[llGetOmega]]|}}
{{LSL DefineRow||[[llGetOmega]]|}}
{{LSL DefineRow||[[llGetVel]]|}}
{{LSL DefineRow||[[llGetVel]]|}}
{{LSL DefineRow||[[llGetTorque]]|}}
{{LSL DefineRow||[[llGetMass]]|}}
{{LSL DefineRow||[[llGetForce]]|}}
{{LSL DefineRow||[[llSetForce]]|}}
{{LSL DefineRow||[[llSetForce]]|}}
{{LSL DefineRow||[[llSetTorque]]|}}
{{LSL DefineRow||[[llSetTorque]]|}}

Latest revision as of 00:31, 22 January 2015

Summary

Function: vector llGetAccel( );
0.0 Forced Delay
10.0 Energy

Returns a vector that is the acceleration of the object in the region frame of reference.

Caveats

  • Returns ZERO_VECTOR in attachments regardless of the avatar's acceleration.
  • Returns ZERO_VECTOR in child prims regardless of the linkset's acceleration.

Examples

//A very simple (and not very effective) way of keeping a physical object in place.
//If the object is moving when the script is put in the object, then the object will continue to move, so long as it doesn't accelerate. 
//If you ever want to actually stop an object, use llMoveToTarget(llGetPos(), .1)
default {
    moving_start(){ 
        vector ac;
        // Go forever         
        while(llVecMag(ac = llGetAccel()) > .001) { //We're accelerating...
            llApplyImpulse(-ac, 0); //Slow us down.
        }
    }
}

See Also

Functions

•  llGetOmega
•  llGetVel
•  llGetTorque
•  llGetMass
•  llGetForce
•  llSetForce
•  llSetTorque
•  llSetForceAndTorque

Deep Notes

Signature

function vector llGetAccel();