123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778 |
- /**
- * @author alteredq / http://alteredqualia.com/
- */
- import {
- AnimationClip,
- AnimationMixer,
- Mesh
- } from "../../../build/three.module.js";
- var MorphAnimMesh = function ( geometry, material ) {
- Mesh.call( this, geometry, material );
- this.type = 'MorphAnimMesh';
- this.mixer = new AnimationMixer( this );
- this.activeAction = null;
- };
- MorphAnimMesh.prototype = Object.create( Mesh.prototype );
- MorphAnimMesh.prototype.constructor = MorphAnimMesh;
- MorphAnimMesh.prototype.setDirectionForward = function () {
- this.mixer.timeScale = 1.0;
- };
- MorphAnimMesh.prototype.setDirectionBackward = function () {
- this.mixer.timeScale = - 1.0;
- };
- MorphAnimMesh.prototype.playAnimation = function ( label, fps ) {
- if ( this.activeAction ) {
- this.activeAction.stop();
- this.activeAction = null;
- }
- var clip = AnimationClip.findByName( this, label );
- if ( clip ) {
- var action = this.mixer.clipAction( clip );
- action.timeScale = ( clip.tracks.length * fps ) / clip.duration;
- this.activeAction = action.play();
- } else {
- throw new Error( 'THREE.MorphAnimMesh: animations[' + label + '] undefined in .playAnimation()' );
- }
- };
- MorphAnimMesh.prototype.updateAnimation = function ( delta ) {
- this.mixer.update( delta );
- };
- MorphAnimMesh.prototype.copy = function ( source ) {
- Mesh.prototype.copy.call( this, source );
- this.mixer = new AnimationMixer( this );
- return this;
- };
- export { MorphAnimMesh };
|