Uni2D 入门 -- Animation Clip 和 Animation API

上一篇 Uni2D 入门 -- Atlas

Animation Clip

一个animation clip是可重用的帧集合,它以给定的帧率显示sprite。每一帧包含的texture和可选事件。

可通过菜单栏“Uni2D > Create > Animation Clip”创建一个Animation Clip。

Uni2D 入门 -- Animation Clip 和 Animation API_第1张图片


Animation Clip Inspector

Atlas 部分


设置 描述
Use Atlas 这个animation clip全局的atlas。使用这个去为animation clip的所有帧设置相同的atlas。留它为None则会在每个animation clip帧选择指定的atlas。
Maximum Atlas Size 全局atlas的最大大小。只有在全局atlas设置的时候这个才可见。


Clip header部分

Uni2D 入门 -- Animation Clip 和 Animation API_第2张图片

设置 描述
Animation clip preview 鼠标悬停在纹理上面可以有个快速预览动画
Frame Rate animation clip的帧率,单位是FPS。如果你想要反转动画,你可以设置这个值为负数。
Wrap Mode 这个设置描述了animation clip以怎样的方式循环。和Unity内建的wrap mode很像:
  • Loop:从第一帧播放到最后一帧,然后回到第一帧继续播放。
  • Ping-Pong:从第一帧播放到最后一帧,然后从最后一帧播回最后一帧。
  • Once:只播放一次,并停在一帧,它是主帧,不一定是动画的第一帧。
  • Clamp Forever:从第一帧播放到最后一帧,并停在最后一帧。

Frame部分

Uni2D 入门 -- Animation Clip 和 Animation API_第3张图片

设置 描述
点击这两个按钮分别是上移和下移本帧
点击这两个按钮分别是在本帧上面和下面添加帧
点击这个按钮删除本帧
Frame Texture 这一帧使用的Texture。None也是合法的。
Use Atlas 这个atlas用于帧texture。只有在没指定了global atlas的时候,这个才是可见的。
Trigger Event 勾选这个复选框,如果你想要Uni2D能在这显示此帧的时候触发事件。更多信息请看Animation API部分。
Frame Infos 自定义本帧附加的信息。代表性的一个用法是这个可以作为事件数据。你能指定一个字符串,int,float或一个Unity对象。更多信息请看Animation API部分。

Action部分


设置 描述
Add frame 在Animation Clip结尾增加新的帧
Apply 点击应用设置。由于生产一个animation clip会花费一定时间,所以不要在每次一有改变的时候就应用。
Revert 取消你的改变
Force Clip Regeneration 重建atlas

嵌入的播放器部分

Uni2D 入门 -- Animation Clip 和 Animation API_第4张图片

在这个子窗口,你能预览动画,并使用更多的回放控制。


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





你可能感兴趣的:(animation,unity3d,clip,Uni2D)