Unity3D制作序列帧动画的方法
当我们需要制作动态炫酷科技感很强的UI时,美术一般会给我们提供一些序列图,这时候我们只需在程序里实现序列动画。
一.动画机
unity自带的帧动画机很方便,我们首先选择所要播放序列帧动画的Image,然后在Window下选择Animation,会弹出一个动画制动的界面,我们选择Create,然后进入如下界面:
我们按照如下添加动画控制的属性,
然后将我们美术给我们的序列图(要设置成2DandUI模式哦)拖入到动画帧面板里。
Unity自带的动画机播放序列帧动画很简单也很方便,但是有一定的局限性。因为我们不能很方便的控制动画的进程以及一些我们的要求。(虽然也可以,但是还是需要写代码,然后还要操控动画机,太费劲)。下面就介绍完全用代码控制动画播放的方法。
二.代码控制
这个方法完全用代码实现,不需要在去操作一下动画机了。代码如下:
public class Test : MonoBehaviour { [SerializeField] private Image image; [SerializeField] private List<Sprite> animationSprites = new List<Sprite>(); private int AnimationAmount { get { return animationSprites.Count; } } public void PlayAnimation() { if (image == null) image = GetComponent<Image>(); StartCoroutine(PlayAnimationForwardIEnum()); } private IEnumerator PlayAnimationForwardIEnum() { int index = 0;//可以用来控制起始播放的动画帧索引 gameObject.SetActive(true); while (true) { //当我们需要在整个动画播放完之后 重复播放后面的部分 就可以展现我们纯代码播放的自由性 if (index > AnimationAmount - 1) { index = 50; } image.sprite = animationSprites[index]; index++; yield return new WaitForSeconds(0.03f);//等待间隔 控制动画播放速度 } } }
效果图如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
上一篇:C#基于QRCode实现动态生成自定义二维码图片功能示例
栏 目:C#教程
本文标题:Unity3D制作序列帧动画的方法
本文地址:https://www.xiuzhanwang.com/a1/C_jiaocheng/4901.html
您可能感兴趣的文章
- 01-10C#获取U盘序列号的方法
- 01-10Unity3d获取系统时间
- 01-10Unity3D获取当前键盘按键及Unity3D鼠标、键盘的基本操作
- 01-10C#制作简单的多人在线即时交流聊天室
- 01-10C#实现XML与实体类之间相互转换的方法(序列化与反序列化)
- 01-10C# XML序列化方法及常用特性总结分析
- 01-10C#实现读取指定盘符硬盘序列号的方法
- 01-10C#制作多线程处理强化版网络爬虫
- 01-10浅谈C# 序列化与反序列化几种格式的转换
- 01-10WPF MVVM制作发送短信小按钮
阅读排行
本栏相关
- 01-10C#通过反射获取当前工程中所有窗体并
- 01-10关于ASP网页无法打开的解决方案
- 01-10WinForm限制窗体不能移到屏幕外的方法
- 01-10WinForm绘制圆角的方法
- 01-10C#实现txt定位指定行完整实例
- 01-10WinForm实现仿视频播放器左下角滚动新
- 01-10C#停止线程的方法
- 01-10C#实现清空回收站的方法
- 01-10C#通过重写Panel改变边框颜色与宽度的
- 01-10C#实现读取注册表监控当前操作系统已
随机阅读
- 01-11Mac OSX 打开原生自带读写NTFS功能(图文
- 08-05dedecms(织梦)副栏目数量限制代码修改
- 08-05织梦dedecms什么时候用栏目交叉功能?
- 01-10C#中split用法实例总结
- 01-10使用C语言求解扑克牌的顺子及n个骰子
- 08-05DEDE织梦data目录下的sessions文件夹有什
- 01-11ajax实现页面的局部加载
- 01-10SublimeText编译C开发环境设置
- 01-10delphi制作wav文件的方法
- 04-02jquery与jsp,用jquery