Difference between revisions of "LlSetKeyframedMotion"

From Second Life Wiki
Jump to navigation Jump to search
m
Line 3: Line 3:
|inject-1={{LSL_Generic/proposal|text=It has not yet been scheduled for development.}}
|inject-1={{LSL_Generic/proposal|text=It has not yet been scheduled for development.}}
|func_id=?
|func_id=?
|func_desc=Specify a list of times, positions, and orientations to be followed by an object. The object will be smoothly moved between keyframes by the simulator. Collisions with other nonphysical or keyframed objects will be ignored (no script events will fire and collision processing will not occur).
|func_desc=Specify a list of times, positions, and orientations to be followed by an object. The object will be smoothly moved between keyframes by the simulator. Collisions with other nonphysical or keyframed objects will be ignored (no script events will fire and collision processing will not occur). Collisions with physical objects will be computed and reported, but the keyframed object will be unaffected by those collisions. (The physical object will be affected, however.)
|func_sleep
|func_sleep
|func_energy
|func_energy
Line 9: Line 9:
|func_footnote
|func_footnote
|p1_type=list|p1_name=keyframes|p1_desc=Strided keyframe list of the form:
|p1_type=list|p1_name=keyframes|p1_desc=Strided keyframe list of the form:
* ''float'' time (measured from time of function call)
* ''vector'' position
* ''vector'' position
* ''rotation'' orientation  
* ''rotation'' orientation  
* ''float'' time


Each time value must be at least 0.1s greater than the previous call. Linear and angular velocities will be clamped to limits set by the simulator (values TBD).
Each keyframe is interpreted relative to the previous transform of the object. For example, consider the following list of keyframes: [<0, 0, 10>, [[ZERO_ROTATION]], 5, <0, 0, 0>, [[ZERO_ROTATION]], 5, <0, 0, -10>, [[ZERO_ROTATION]], 5]. This would cause the object to move up 10m over the course of 5s. It would then remain at the location for 5s before moving down 10m over the course of another 5s.
An empty list will terminate any keyframed animation currently playing.
Time values must be greater than 0.1s.
Linear and angular velocities will be clamped to limits set by the simulator (values TBD).
An empty list will terminate any keyframed animation currently playing.  


|p2_type=integer|p2_name=loop|p2_desc=Whether or not the keyframes should be interpreted as a loop. If TRUE, the last keyframe must have the same position and orientation as the first keyframe. If FALSE, the object will be slowed to a stop such that it reaches the final keyframe with zero velocity at the specified time.
|p2_type=list|p2_name=options|p2_desc=modifiers and future options
 
|spec=
The following flags will be supported within the ''options'' list, although the exact way these will be specified is TBD.
*[[PING_PONG]] and [[LOOP]] can be used to specify that the animation should loop (e.g., the order of frames would be 1, 2, 3, 2, 1, 2, 3, 2, 1, etc. or 1, 2, 3, 1, 2, 3, etc. respectively.) The default will be to simply play the frames in the order specified.
*[[ROTATE]] and <u>TRANSLATE</u> can be used to reduce the size of the keyframe list by indicating that the list is of the form [rotation, time, rotation, time, ...] or [translation, time, translation, time, ...]
 
Inter-region animations may be supported depending on development complexity.


|p3_type=list|p3_name=reserved|p3_desc=Reserved for future compatibility. MUST be an empty list.
|caveats=
|caveats=
*This function can only be called on NON-physical objects. In the future it could be extended to support physical objects, but this is more complicated as collisions could prevent the object from reaching its goal positions on time.
*This function can only be called on NON-physical objects. In the future it could be extended to support physical objects, but this is more complicated as collisions could prevent the object from reaching its goal positions on time.

Revision as of 18:36, 6 September 2011

Emblem-important-yellow.png LSL Feature Proposal
The described function does not exist. This article is a function proposal only.

It has not yet been scheduled for development.

Please comment on the the discussion page with any questions or suggestions or to voice support for this feature.

Summary

Function: llSetKeyframedAnimation( list <span title="Strided keyframe list of the form:
  • vector position
  • rotation orientation
  • float time

Each keyframe is interpreted relative to the previous transform of the object. For example, consider the following list of keyframes: [<0, 0, 10>, ZERO_ROTATION, 5, <0, 0, 0>, ZERO_ROTATION, 5, <0, 0, -10>, ZERO_ROTATION, 5]. This would cause the object to move up 10m over the course of 5s. It would then remain at the location for 5s before moving down 10m over the course of another 5s. Time values must be greater than 0.1s. Linear and angular velocities will be clamped to limits set by the simulator (values TBD). An empty list will terminate any keyframed animation currently playing." style="border-bottom:1px dotted; cursor:help;">keyframes, list options );

Specify a list of times, positions, and orientations to be followed by an object. The object will be smoothly moved between keyframes by the simulator. Collisions with other nonphysical or keyframed objects will be ignored (no script events will fire and collision processing will not occur). Collisions with physical objects will be computed and reported, but the keyframed object will be unaffected by those collisions. (The physical object will be affected, however.)

• list keyframes Strided keyframe list of the form:
  • vector position
  • rotation orientation
  • float time

Each keyframe is interpreted relative to the previous transform of the object. For example, consider the following list of keyframes: [<0, 0, 10>, ZERO_ROTATION, 5, <0, 0, 0>, ZERO_ROTATION, 5, <0, 0, -10>, ZERO_ROTATION, 5]. This would cause the object to move up 10m over the course of 5s. It would then remain at the location for 5s before moving down 10m over the course of another 5s. Time values must be greater than 0.1s. Linear and angular velocities will be clamped to limits set by the simulator (values TBD). An empty list will terminate any keyframed animation currently playing.

• list options modifiers and future options

Specification

The following flags will be supported within the options list, although the exact way these will be specified is TBD.

  • PING_PONG and LOOP can be used to specify that the animation should loop (e.g., the order of frames would be 1, 2, 3, 2, 1, 2, 3, 2, 1, etc. or 1, 2, 3, 1, 2, 3, etc. respectively.) The default will be to simply play the frames in the order specified.
  • ROTATE and TRANSLATE can be used to reduce the size of the keyframe list by indicating that the list is of the form [rotation, time, rotation, time, ...] or [translation, time, translation, time, ...]

Inter-region animations may be supported depending on development complexity.

Caveats

  • This function can only be called on NON-physical objects. In the future it could be extended to support physical objects, but this is more complicated as collisions could prevent the object from reaching its goal positions on time.
  • This function can only be called on the root prim of a linkset.
  • All positions must be within the same simulator region.

Examples

Notes

Potential Use Cases:

  • Elevators
  • Moving platforms
  • Trains/Fixed-Track Vehicles
  • Moving doors/walls/gates
  • Windmills and other machines

Deep Notes

Signature

function void llSetKeyframedAnimation( list keyframes, list options );