codecamp

three.js AnimationClip

动画剪辑(AnimationClip)是一个可重用的关键帧轨道集,它代表动画。

在使用手册的“下一步”章节中,“动画系统”一文对three.js动画系统中的不同元素作出了概述

构造器

AnimationClip( name : String, duration : Number, tracks : Array )

name - 此剪辑的名称

duration - 持续时间 (单位秒). 如果传入负数, 持续时间将会从传入的数组中计算得到。

tracks - 一个由关键帧轨道(KeyframeTracks)组成的数组。

说明: 与其直接调用构造函数实例化一个动画剪辑, 不如使用其静态方法中的一个来创建: 用JSON (parse), 用变形目标序列(CreateFromMorphTargetSequence, CreateClipsFromMorphTargetSequences)或者用动画层级 (parseAnimation)来创建 - 如果你的模型中几何体的动画数组中还没有保存动画剪辑的话。

属性

.duration : Number

剪辑的持续时间 (单位秒). 可以通过resetDuration从轨道数组(tracks)计算出来。

.name : String

剪辑的名称. 调用findByName根据名称搜索某个剪辑

.tracks : Array

一个包含该剪辑中有动画的所有属性的关键帧轨道(KeyframeTrack)的数组。

.uuid : String

剪辑实例的UUID,自动分配且不可编辑。

方法

.clone () : AnimationClip

.optimize () : this

通过移除等效的顺序键(在变形目标序列中很常见)来优化每一个轨道

.resetDuration () : this

将剪辑的持续时间(duration)设为最长的关键帧轨道(KeyframeTrack)的持续时间。

.toJSON () : Object

Returns a JSON object representing the serialized animation clip.

.trim () : this

修剪所有的轨道到该剪辑的持续时间。

.validate () : Boolean

对剪辑中的每个轨道执行最小验证。如果所有轨道都有效,返回true。

静态方法

.CreateClipsFromMorphTargetSequences ( name : String, morphTargetSequence : Array, fps : Number, noLoop : Boolean ) : Array

返回从几何体的变形目标序列(morph target sequences)创建的新动画剪辑(AnimationClip)数组,并尝试将变形目标名称分类为基于动画组的模式,如“Walk_001、Walk_002、Run_001、Run_002……”。

.CreateFromMorphTargetSequence ( name : String, morphTargetSequence : Array, fps : Number, noLoop : Boolean ) : AnimationClip

返回一个由几何体变形目标数组(morph targets array)得到的新动画剪辑,接收名称和帧率参数。说明: 帧率是必须参数, 但是动画速度可能会在AnimationAction中被animationAction.setDuration方法重写。

.findByName ( objectOrClipArray : Object, name : String ) : AnimationClip

根据名称搜索动画剪辑(AnimationClip), 接收一个动画剪辑数组或者一个包含名为"animation"的数组的网格(或几何体)作为第一个参数。

.parse ( json : Object ) : AnimationClip

解析剪辑的JSON表示,并返回一个动画剪辑(AnimationClip)。

.parseAnimation ( animation : Object, bones : Array ) : AnimationClip

解析动画层级格式并返回动画剪辑。

.toJSON ( clip : AnimationClip ) : Object

接收一个动画剪辑为参数并返回一个JSON对象.

源码

src/animation/AnimationClip.js


three.js AnimationAction
three.js AnimationMixer
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

参考

核心 / BufferAttributes

渲染器 / WebXR

开发者参考

WebGL渲染器

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }