Animation Clip

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

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

unity animation 没有debug unity animation在哪_帧率


Animation Clip Inspector

Atlas 部分

unity animation 没有debug unity animation在哪_回调方法_02

设置

描述

Use Atlas

这个animation clip全局的atlas。使用这个去为animation clip的所有帧设置相同的atlas。留它为None则会在每个animation clip帧选择指定的atlas。

Maximum Atlas Size

全局atlas的最大大小。只有在全局atlas设置的时候这个才可见。


Clip header部分

unity animation 没有debug unity animation在哪_帧率_03

设置

描述

Animation clip preview

鼠标悬停在纹理上面可以有个快速预览动画

Frame Rate

animation clip的帧率,单位是FPS。如果你想要反转动画,你可以设置这个值为负数。

Wrap Mode

这个设置描述了animation clip以怎样的方式循环。和Unity内建的wrap mode很像:

  • Loop:从第一帧播放到最后一帧,然后回到第一帧继续播放。
  • Ping-Pong:从第一帧播放到最后一帧,然后从最后一帧播回最后一帧。
  • Once:只播放一次,并停在一帧,它是主帧,不一定是动画的第一帧。
  • Clamp Forever:从第一帧播放到最后一帧,并停在最后一帧。


Frame部分

unity animation 没有debug unity animation在哪_帧率_04

设置

描述

unity animation 没有debug unity animation在哪_API_05

点击这两个按钮分别是上移和下移本帧

unity animation 没有debug unity animation在哪_帧率_06

点击这两个按钮分别是在本帧上面和下面添加帧

unity animation 没有debug unity animation在哪_API_07

点击这个按钮删除本帧

Frame Texture

这一帧使用的Texture。None也是合法的。

Use Atlas

这个atlas用于帧texture。只有在没指定了global atlas的时候,这个才是可见的。

Trigger Event

勾选这个复选框,如果你想要Uni2D能在这显示此帧的时候触发事件。更多信息请看Animation API部分。

Frame Infos

自定义本帧附加的信息。代表性的一个用法是这个可以作为事件数据。你能指定一个字符串,int,float或一个Unity对象。更多信息请看Animation API部分。


Action部分

unity animation 没有debug unity animation在哪_API_08

设置

描述

Add frame

在Animation Clip结尾增加新的帧

Apply

点击应用设置。由于生产一个animation clip会花费一定时间,所以不要在每次一有改变的时候就应用。

Revert

取消你的改变

Force Clip Regeneration

重建atlas


嵌入的播放器部分

unity animation 没有debug unity animation在哪_回调方法_09

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


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