117 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			117 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
import {
 | 
						|
	AnimationClip,
 | 
						|
	BooleanKeyframeTrack,
 | 
						|
	ColorKeyframeTrack,
 | 
						|
	NumberKeyframeTrack,
 | 
						|
	Vector3,
 | 
						|
	VectorKeyframeTrack
 | 
						|
} from 'three';
 | 
						|
 | 
						|
class AnimationClipCreator {
 | 
						|
 | 
						|
	static CreateRotationAnimation( period, axis = 'x' ) {
 | 
						|
 | 
						|
		const times = [ 0, period ], values = [ 0, 360 ];
 | 
						|
 | 
						|
		const trackName = '.rotation[' + axis + ']';
 | 
						|
 | 
						|
		const track = new NumberKeyframeTrack( trackName, times, values );
 | 
						|
 | 
						|
		return new AnimationClip( null, period, [ track ] );
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	static CreateScaleAxisAnimation( period, axis = 'x' ) {
 | 
						|
 | 
						|
		const times = [ 0, period ], values = [ 0, 1 ];
 | 
						|
 | 
						|
		const trackName = '.scale[' + axis + ']';
 | 
						|
 | 
						|
		const track = new NumberKeyframeTrack( trackName, times, values );
 | 
						|
 | 
						|
		return new AnimationClip( null, period, [ track ] );
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	static CreateShakeAnimation( duration, shakeScale ) {
 | 
						|
 | 
						|
		const times = [], values = [], tmp = new Vector3();
 | 
						|
 | 
						|
		for ( let i = 0; i < duration * 10; i ++ ) {
 | 
						|
 | 
						|
			times.push( i / 10 );
 | 
						|
 | 
						|
			tmp.set( Math.random() * 2.0 - 1.0, Math.random() * 2.0 - 1.0, Math.random() * 2.0 - 1.0 ).
 | 
						|
				multiply( shakeScale ).
 | 
						|
				toArray( values, values.length );
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
		const trackName = '.position';
 | 
						|
 | 
						|
		const track = new VectorKeyframeTrack( trackName, times, values );
 | 
						|
 | 
						|
		return new AnimationClip( null, duration, [ track ] );
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	static CreatePulsationAnimation( duration, pulseScale ) {
 | 
						|
 | 
						|
		const times = [], values = [], tmp = new Vector3();
 | 
						|
 | 
						|
		for ( let i = 0; i < duration * 10; i ++ ) {
 | 
						|
 | 
						|
			times.push( i / 10 );
 | 
						|
 | 
						|
			const scaleFactor = Math.random() * pulseScale;
 | 
						|
			tmp.set( scaleFactor, scaleFactor, scaleFactor ).
 | 
						|
				toArray( values, values.length );
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
		const trackName = '.scale';
 | 
						|
 | 
						|
		const track = new VectorKeyframeTrack( trackName, times, values );
 | 
						|
 | 
						|
		return new AnimationClip( null, duration, [ track ] );
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	static CreateVisibilityAnimation( duration ) {
 | 
						|
 | 
						|
		const times = [ 0, duration / 2, duration ], values = [ true, false, true ];
 | 
						|
 | 
						|
		const trackName = '.visible';
 | 
						|
 | 
						|
		const track = new BooleanKeyframeTrack( trackName, times, values );
 | 
						|
 | 
						|
		return new AnimationClip( null, duration, [ track ] );
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
	static CreateMaterialColorAnimation( duration, colors ) {
 | 
						|
 | 
						|
		const times = [], values = [],
 | 
						|
			timeStep = duration / colors.length;
 | 
						|
 | 
						|
		for ( let i = 0; i < colors.length; i ++ ) {
 | 
						|
 | 
						|
			times.push( i * timeStep );
 | 
						|
 | 
						|
			const color = colors[ i ];
 | 
						|
			values.push( color.r, color.g, color.b );
 | 
						|
 | 
						|
		}
 | 
						|
 | 
						|
		const trackName = '.material.color';
 | 
						|
 | 
						|
		const track = new ColorKeyframeTrack( trackName, times, values );
 | 
						|
 | 
						|
		return new AnimationClip( null, duration, [ track ] );
 | 
						|
 | 
						|
	}
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
export { AnimationClipCreator };
 |