上一篇 Uni2D 入门 -- Atlas
Animation Clip
一个animation clip是可重用的帧集合,它以给定的帧率显示sprite。每一帧包含的texture和可选事件。
可通过菜单栏“Uni2D > Create > Animation Clip”创建一个Animation Clip。
Animation Clip Inspector
Atlas 部分
设置 | 描述 |
Use Atlas | 这个animation clip全局的atlas。使用这个去为animation clip的所有帧设置相同的atlas。留它为None则会在每个animation clip帧选择指定的atlas。 |
Maximum Atlas Size | 全局atlas的最大大小。只有在全局atlas设置的时候这个才可见。 |
Clip header部分
设置 | 描述 |
Animation clip preview | 鼠标悬停在纹理上面可以有个快速预览动画 |
Frame Rate | animation clip的帧率,单位是FPS。如果你想要反转动画,你可以设置这个值为负数。 |
Wrap Mode | 这个设置描述了animation clip以怎样的方式循环。和Unity内建的wrap mode很像:
|
Frame部分
Action部分
设置 | 描述 |
Add frame | 在Animation Clip结尾增加新的帧 |
Apply | 点击应用设置。由于生产一个animation clip会花费一定时间,所以不要在每次一有改变的时候就应用。 |
Revert | 取消你的改变 |
Force Clip Regeneration | 重建atlas |
嵌入的播放器部分
在这个子窗口,你能预览动画,并使用更多的回放控制。
Animation API
Uni2D提供一些基础方法用于管理你的动画。这些animation API虽然是C#的,不过JavaScript也可以使用。
Uni2DSprite类有一个SpriteAnimation属性,它返回一个Uni2DSpriteAnimation对象的引用。这个对象控制sprite的animation。
属性/方法 | 描述 |
bool playAutomatically | 决定动画是否在sprite awake之后自动播放 |
Uni2DSprite Sprite(只读) | 这个对象正在渲染的sprite |
Uni2DAnimationClip.WrapMode WrapMode | animation怎样循环(看Animation Clip的Inspector) |
float FrameRate | animation clip的帧率。使用这个修改动画播放的方式。负数会反转动画 |
int FrameCount | 当前animation包含了多少帧。这个数量取决于当前animation clip和当前的wrap mode。例如,一个10帧的animation clip,如果是Ping-Pong的wrap mode,它的frame count是18 |
int FrameIndex | 当前绘制帧的索引 |
Uni2DAnimationFrame Frame(只读) | 当前帧 |
float Time | 当前animation的播放时间在0到animation的长度之间。 |
float NormalizedTime | 当前动画播放时间,规范化在0到1之间。 |
float Speed | 使用speed属性控制animation的播放速度。这个将让animation time走的更慢或更快,取决于你选择的参数。你能设置到0来冻结它,-1来往后播放等等。 |
float Length(只读) | 当前播放的animation clip的长度 |
string Name(只读) | 当前播放的animation clip的名字 |
int CurrentClipIndex(只读) | 当前播放的animation clip的索引 |
Uni2DAnimationClip Clip(只读) | 当前播放的animation clip |
int ClipCount(只读) | 附加到sprite上有多少个animation clips |
bool Paused | 如果设置为true则暂停animation。设置为false则恢复动画。 |
void Pause() | 暂停动画 |
void Resume() | 恢复动画 |
void Play() | 从头播放当前选择的animation(默认选中的animation clip是在Sprite的Inspector的Start Clip Index值设置的) |
void Play(string clipName) | 从头播放名字为clipName的clip。它必须已经通过手动或调用方法加到sprite上的,否则没有任何效果。 |
void Play(int clipIndex) | 从头播放第clipIndex个clip。如果索引不对,则没有任何效果。 |
int GetClipIndexByName(string clipName) | 返回名字为clipName的animation clip 的索引。如果没有这个名字的clip,则返回-1 |
void Stop(bool resetToMainFrame=true) | 停止当前动画。如果可选参数设置为false(默认是true),则sprite不会显示它的主texture,而是保持当前动画帧的texture。 |
Animation Events
有两种类型的事件能被animation触发:end animation event和frame animation event
End Animation Event
自动在动画或者loop结束触发。
回调方法签名:void OnAnimationEndEvent(Uni2DAnimationEvent a_oAnimationEvent)
委托:Uni2DSpriteAnimation.onAnimationEndEvent
例子:sprite.spriteAnimation.onAnimationEndEvent += myCallbak;
Frame Animation Event
触发每一帧triggerEvent参数(Animation Clip的Inspector中)设置为true的。
回调方法签名:void OnAnimationFrameEvent(Uni2DAnimationFrameEvent a_oAnimationFrameEvent);
委托:Uni2DSpriteAnimation.onAnimationFrameEvent
例子:sprite.spriteAnimation.onAnimationFrame += myCallbak;
给出的Uni2DAnimationFrameEvent对象允许你访问触发事件的frame。值得注意的是,用户定义的帧信息能从这个event中访问到。
例如,a_oAnimationFrameEvent.frame.eventInfos.stringInfo
下一篇 Uni2D 入门 -- Skeletal Animation