/**
|
|
*
|
|
* Creator of typical test AnimationClips / KeyframeTracks
|
|
*
|
|
* @author Ben Houston / http://clara.io/
|
|
* @author David Sarno / http://lighthaus.us/
|
|
*/
|
|
|
|
THREE.AnimationClipCreator = function() {
|
|
};
|
|
|
|
THREE.AnimationClipCreator.CreateRotationAnimation = function( period, axis ) {
|
|
|
|
var keys = [];
|
|
keys.push( { time: 0, value: 0 } );
|
|
keys.push( { time: period, value: 360 } );
|
|
|
|
axis = axis || 'x';
|
|
var trackName = '.rotation[' + axis + ']';
|
|
|
|
var track = new THREE.NumberKeyframeTrack( trackName, keys );
|
|
|
|
var clip = new THREE.AnimationClip( 'rotate.x', 10, [ track ] );
|
|
//console.log( 'rotateClip', clip );
|
|
|
|
return clip;
|
|
};
|
|
|
|
THREE.AnimationClipCreator.CreateScaleAxisAnimation = function( period, axis ) {
|
|
|
|
var keys = [];
|
|
keys.push( { time: 0, value: 0 } );
|
|
keys.push( { time: period, value: 360 } );
|
|
|
|
axis = axis || 'x';
|
|
var trackName = '.scale[' + axis + ']';
|
|
|
|
var track = new THREE.NumberKeyframeTrack( trackName, keys );
|
|
|
|
var clip = new THREE.AnimationClip( 'scale.x', 10, [ track ] );
|
|
//console.log( 'scaleClip', clip );
|
|
|
|
return clip;
|
|
};
|
|
|
|
THREE.AnimationClipCreator.CreateShakeAnimation = function( duration, shakeScale ) {
|
|
|
|
var keys = [];
|
|
|
|
for( var i = 0; i < duration * 10; i ++ ) {
|
|
|
|
keys.push( {
|
|
time: ( i / 10.0 ),
|
|
value: new THREE.Vector3( Math.random() * 2.0 - 1.0, Math.random() * 2.0 - 1.0, Math.random() * 2.0 - 1.0 ).multiply( shakeScale )
|
|
} );
|
|
|
|
}
|
|
|
|
var trackName = '.position';
|
|
|
|
var track = new THREE.VectorKeyframeTrack( trackName, keys );
|
|
|
|
var clip = new THREE.AnimationClip( 'shake' + duration, duration, [ track ] );
|
|
//console.log( 'shakeClip', clip );
|
|
|
|
return clip;
|
|
};
|
|
|
|
|
|
THREE.AnimationClipCreator.CreatePulsationAnimation = function( duration, pulseScale ) {
|
|
|
|
var keys = [];
|
|
|
|
for( var i = 0; i < duration * 10; i ++ ) {
|
|
|
|
var scaleFactor = Math.random() * pulseScale;
|
|
keys.push( {
|
|
time: ( i / 10.0 ),
|
|
value: new THREE.Vector3( scaleFactor, scaleFactor, scaleFactor )
|
|
} );
|
|
|
|
}
|
|
|
|
var trackName = '.scale';
|
|
|
|
var track = new THREE.VectorKeyframeTrack( trackName, keys );
|
|
|
|
var clip = new THREE.AnimationClip( 'scale' + duration, duration, [ track ] );
|
|
//console.log( 'scaleClip', clip );
|
|
|
|
return clip;
|
|
};
|
|
|
|
|
|
THREE.AnimationClipCreator.CreateVisibilityAnimation = function( duration ) {
|
|
|
|
var keys = [];
|
|
keys.push( {
|
|
time: 0,
|
|
value: true
|
|
} );
|
|
keys.push( {
|
|
time: duration - 1,
|
|
value: false
|
|
} );
|
|
keys.push( {
|
|
time: duration,
|
|
value: true
|
|
} );
|
|
|
|
var trackName = '.visible';
|
|
|
|
var track = new THREE.BooleanKeyframeTrack( trackName, keys );
|
|
|
|
var clip = new THREE.AnimationClip( 'visible' + duration, duration, [ track ] );
|
|
//console.log( 'scaleClip', clip );
|
|
|
|
return clip;
|
|
};
|
|
|
|
|
|
THREE.AnimationClipCreator.CreateMaterialColorAnimation = function( duration, colors, loop ) {
|
|
|
|
var timeStep = duration / colors.length;
|
|
var keys = [];
|
|
for( var i = 0; i <= colors.length; i ++ ) {
|
|
keys.push( { time: i * timeStep, value: colors[ i % colors.length ] } );
|
|
}
|
|
|
|
var trackName = '.material[0].color';
|
|
|
|
var track = new THREE.ColorKeyframeTrack( trackName, keys );
|
|
|
|
var clip = new THREE.AnimationClip( 'colorDiffuse', 10, [ track ] );
|
|
//console.log( 'diffuseClip', clip );
|
|
|
|
return clip;
|
|
};
|
|
|