AnimationClipCreator.js 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. THREE.AnimationClipCreator = function () {};
  2. THREE.AnimationClipCreator.CreateRotationAnimation = function ( period, axis ) {
  3. var times = [ 0, period ], values = [ 0, 360 ];
  4. axis = axis || 'x';
  5. var trackName = '.rotation[' + axis + ']';
  6. var track = new THREE.NumberKeyframeTrack( trackName, times, values );
  7. return new THREE.AnimationClip( null, period, [ track ] );
  8. };
  9. THREE.AnimationClipCreator.CreateScaleAxisAnimation = function ( period, axis ) {
  10. var times = [ 0, period ], values = [ 0, 1 ];
  11. axis = axis || 'x';
  12. var trackName = '.scale[' + axis + ']';
  13. var track = new THREE.NumberKeyframeTrack( trackName, times, values );
  14. return new THREE.AnimationClip( null, period, [ track ] );
  15. };
  16. THREE.AnimationClipCreator.CreateShakeAnimation = function ( duration, shakeScale ) {
  17. var times = [], values = [], tmp = new THREE.Vector3();
  18. for ( var i = 0; i < duration * 10; i ++ ) {
  19. times.push( i / 10 );
  20. tmp.set( Math.random() * 2.0 - 1.0, Math.random() * 2.0 - 1.0, Math.random() * 2.0 - 1.0 ).
  21. multiply( shakeScale ).
  22. toArray( values, values.length );
  23. }
  24. var trackName = '.position';
  25. var track = new THREE.VectorKeyframeTrack( trackName, times, values );
  26. return new THREE.AnimationClip( null, duration, [ track ] );
  27. };
  28. THREE.AnimationClipCreator.CreatePulsationAnimation = function ( duration, pulseScale ) {
  29. var times = [], values = [], tmp = new THREE.Vector3();
  30. for ( var i = 0; i < duration * 10; i ++ ) {
  31. times.push( i / 10 );
  32. var scaleFactor = Math.random() * pulseScale;
  33. tmp.set( scaleFactor, scaleFactor, scaleFactor ).
  34. toArray( values, values.length );
  35. }
  36. var trackName = '.scale';
  37. var track = new THREE.VectorKeyframeTrack( trackName, times, values );
  38. return new THREE.AnimationClip( null, duration, [ track ] );
  39. };
  40. THREE.AnimationClipCreator.CreateVisibilityAnimation = function ( duration ) {
  41. var times = [ 0, duration / 2, duration ], values = [ true, false, true ];
  42. var trackName = '.visible';
  43. var track = new THREE.BooleanKeyframeTrack( trackName, times, values );
  44. return new THREE.AnimationClip( null, duration, [ track ] );
  45. };
  46. THREE.AnimationClipCreator.CreateMaterialColorAnimation = function ( duration, colors ) {
  47. var times = [], values = [],
  48. timeStep = duration / colors.length;
  49. for ( var i = 0; i <= colors.length; i ++ ) {
  50. times.push( i * timeStep );
  51. values.push( colors[ i % colors.length ] );
  52. }
  53. var trackName = '.material[0].color';
  54. var track = new THREE.ColorKeyframeTrack( trackName, times, values );
  55. return new THREE.AnimationClip( null, duration, [ track ] );
  56. };