Difference between revisions of "Talk:LlSetKeyframedMotion"
(Animation Types discussion) |
|||
Line 22: | Line 22: | ||
I must point out a discussion about stopping, how do to about it. At the moment, suggesting use <u>STOP</u>(0x00) with combination of any flag from above? --[[Image:Nacon-tag.jpg]] '''[[User:Vincent_Nacon|₪]]''' 03:07, 31 August 2011 (PDT) | I must point out a discussion about stopping, how do to about it. At the moment, suggesting use <u>STOP</u>(0x00) with combination of any flag from above? --[[Image:Nacon-tag.jpg]] '''[[User:Vincent_Nacon|₪]]''' 03:07, 31 August 2011 (PDT) | ||
:These are great suggestions. I'd make a few tweaks, though: | |||
:*Only [[LOOP]], [[PING_PONG]], and maybe [[REVERSE]] make sense here ([[SMOOTH]] is implicit in the way keyframing works--it is always a smooth interpolation) | |||
:*[[ROTATE]] and <u>TRANSLATE</u> make sense and are a good way to reduce the size of the lists required. However, it would not be feasible to support multiple merging the keyframe sets from different calls (e.g., one call with [[ROTATE]] and one with <u>TRANSLATE</u>) | |||
:*[[SCALE]] is not possibly to implement for physical objects in a way that ensures satisfactory performance. Modifying the scale of a physics shape requires (in simplified terms): (1) rebuilding the shape from scratch, (2) removing the object from the world, (3) applying the new shape to the object, and (4) adding the object back into the world. #1, 2, and 4 are all expensive operations. | |||
:To stop the animation, you could simply pass in an empty list of keyframes. | |||
:[[User:Falcon Linden|Falcon Linden]] 19:11, 6 September 2011 (PDT) | |||
== OMG Future Proofing == | == OMG Future Proofing == | ||
I must be hallucinating, an LSL proposal with some future proofing built in! -- '''[[User:Strife_Onizuka|Strife]]''' <sup><small>([[User talk:Strife_Onizuka|talk]]|[[Special:Contributions/Strife_Onizuka|contribs]])</small></sup> 16:24, 30 August 2011 (PDT) | I must be hallucinating, an LSL proposal with some future proofing built in! -- '''[[User:Strife_Onizuka|Strife]]''' <sup><small>([[User talk:Strife_Onizuka|talk]]|[[Special:Contributions/Strife_Onizuka|contribs]])</small></sup> 16:24, 30 August 2011 (PDT) |
Revision as of 18:11, 6 September 2011
Animation Types
Instead of setting integer Loop, let's reuse animation flags that was built for llSetTextureAnim function as list to combine flags usage.
LOOP REVERSE PING_PONG SMOOTH ROTATE SCALE and maybe add another flag POSITION(0x80)?
- LOOP
- Starts from the beginning to the end and returns back to the beginning to start again.
- REVERSE
- Played backward in following order of the list.
- PING_PONG
- Starts from the beginning to the end and play backward back to the beginning to start again.
- SMOOTH
- Could be used as another suggestion between sliding to the next target instead of "llSetPos"-like frames.
- ROTATE, SCALE, and POSITION
- Allow user to trim list down a bit without the needs to add all three at the same time. (Might be a wishful thinking though.)
Generally allow users to develop system that could have more than one LlSetKeyframedAnimation function call, long as it's not using same axis/scale/position again, which overrides the first of that same flag. One function call use position and second function call use rotation and scale for a type of event call.
I must point out a discussion about stopping, how do to about it. At the moment, suggesting use STOP(0x00) with combination of any flag from above? -- ₪ 03:07, 31 August 2011 (PDT)
- These are great suggestions. I'd make a few tweaks, though:
- Only LOOP, PING_PONG, and maybe REVERSE make sense here (SMOOTH is implicit in the way keyframing works--it is always a smooth interpolation)
- ROTATE and TRANSLATE make sense and are a good way to reduce the size of the lists required. However, it would not be feasible to support multiple merging the keyframe sets from different calls (e.g., one call with ROTATE and one with TRANSLATE)
- SCALE is not possibly to implement for physical objects in a way that ensures satisfactory performance. Modifying the scale of a physics shape requires (in simplified terms): (1) rebuilding the shape from scratch, (2) removing the object from the world, (3) applying the new shape to the object, and (4) adding the object back into the world. #1, 2, and 4 are all expensive operations.
- To stop the animation, you could simply pass in an empty list of keyframes.
- Falcon Linden 19:11, 6 September 2011 (PDT)
OMG Future Proofing
I must be hallucinating, an LSL proposal with some future proofing built in! -- Strife (talk|contribs) 16:24, 30 August 2011 (PDT)