DoTween动画插件学习
一.简单的变量插值运算
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using DG.Tweening; public class GetStart : MonoBehaviour
{
public Vector3 myValue = Vector3.zero;
void Start()
{
//对变量做动画,通过插值去修改值的变化
//变量由0 0 0变化到10 10 10,变化曲线一阶导为正,二阶导为负(即一直增大,增大的速度先快后慢)
//参数:返回myValue值,将x(插值运算的中间值)赋值给myValue,插值运算的最终结果,插值运算的时间
DOTween.To(() => myValue,x => myValue = x, new Vector3(10, 10, 10), 2);
} }
导包using DG.Tweening;,使用DOTween.To方法进行动画的插值运算
二.简单的动画效果
private void Update()
{
//每一帧的立方体的位置和插值运算的结果保持一致
cubeTransform.position = myValue;
}
公开一个transform,新建一个立方体拖动到脚本上赋值,在update函数中使每一帧的立方体的位置和插值运算结果保持一致
三.动画的快捷播放方式
public RectTransform panelTransform;
public bool isIn = false;
public void OnClick()
{
if (!isIn)
{
//对transform的拓展方法,实现物体的移动
//参数:移动的目标位置,移动的时间
//panelTransform.DOMove(Vector3.zero, 1);
Tweener tweener = panelTransform.DOLocalMove(Vector3.zero, 1f);//默认动画会被销毁
//动画的对象为Tweener类型的对象,接收这个对象,并将自动销毁的属性设置为false
tweener.SetAutoKill(false); isIn = true;
}
else
{
//动画未销毁则可以倒放动画
panelTransform.DOPlayBackwards(); isIn = false;
} }
通过拓展Unity原来API中的类的方法实现动画的快捷播放,这里将panel从屏幕外移动到屏幕中央,两个动画播放方法分别对应世界坐标和本地坐标
public RectTransform panelTransform;
public bool isIn = false;
private void Start()
{
//在start里创建并保存一个动画
Tweener tweener = panelTransform.DOLocalMove(Vector3.zero, 1f);//默认动画会被销毁
tweener.SetAutoKill(false);
//暂停动画的播放
tweener.Pause();
}
public void OnClick()
{
if (!isIn)
{
//动画播放,DOPlay方法只会播放一次
//panelTransform.DOPlay();
//动画前放,DOPlayForward方法可以多次播放和回放动画
panelTransform.DOPlayForward();
isIn = true;
}
else
{
//倒放动画,DOPlayBackwards方法和DOPlayForward方法是一对方法
panelTransform.DOPlayBackwards(); isIn = false;
} }
可以现在start中创建好动画,再在合适的时候进行任意次的播放和倒放
四.from方法
通过在动画方法后点上from方法可以实现从目标位置到当前位置播放动画
public RectTransform panelTransform;
public void OnClick()
{
//不加from表示从当前位置运动到up位置,加上from表示从up位置运动到当前位置
//panelTransform.DOLocalMove(Vector3.up, 4).From();
//可以在from中添加一个bool值的参数,表示这个运动目标位置是否是相对位置,不填写默认为false也就是绝对位置
panelTransform.DOLocalMove(Vector3.up, 4).From(true);
}
五.动画的一些设置
动画创建后返回值为tweener对象,调整这个对象的参数即可对动画进行设置(前面已经设置过动画是否自动销毁)
//设置动画曲线,Ease是枚举类型,枚举了内置的各种动画曲线
tweener.SetEase(Ease.InSine);
//设置动画播放的次数
tweener.SetLoops(2);
//设置动画完成后调用的方法,OnTweenComplete是动画结束后调用的方法的方法名,不用引号
tweener.OnComplete(OnTweenComplete);
六.可视化动画组件DOTween Animation

可以方便地管理动画类型、动画曲线和生命周期(Events)等
七.可视化路径编辑器组件DOTween Path

设置路径,控制游戏对象按照路径运动
DoTween动画插件学习的更多相关文章
- Unity3D_(插件)DOTween动画插件
使用DOTween动画插件来实现物体的移动动画 Learn 一.DOTween插件对变量的动画 二.控制Cube和UI面板的动画 三.动画的快捷播放方式 四.动画的前放和后放 五.From Tween ...
- DoTween 动画插件简单示例
.doTween的静态方法 DOTween.To(() => maskImage.color, toColor => maskImage.color = toColor, , , , ), ...
- #Plugin 数字滚动累加动画插件
数字滚动累加动画插件 NumScroll 1.使用前先引入jquery2.前端学习群:814798690 下载地址 https://github.com/chaorenzeng/jquery.num ...
- velocity.js 动画插件
1. velocity.js 插件介绍 Velocity 是独立于jQuery的,但两者可以结合使用的动画插件.用法类似 jq 的 animate ,但是支持更高级动画. ( 颜色动画.转换动画(tr ...
- 让网站动起来!12款优秀的 jQuery 动画插件推荐
如今,大多数设计师和开发人员被要客户要求开发动态的网站.创造视觉震撼和醒目的动态网站是艰巨的任务,因为它需要大量的努力和创造力.在网络上有大量的工具和插件可用于创建网站动画.许多开发人员正在使用 HT ...
- uexQQ插件学习心得
uexQQ插件学习心得 uexQQ插件的作用:通过qq可以分享图文,音乐,应用到相应的qq空间.支持手机客户端分享和手机webQQ分享.下面我们就来看一看他的一些方法. 我们先说一下分享的步骤,这个步 ...
- emmet插件学习,练习中遇到一些问题
emmet插件学习:帮助提高敲代码效率的插件 参考文献:Emmet(Zen coding)HTML代码使用技巧七则http://www.wzsky.net/html/Website/htmlcss/1 ...
- Minimit Anima – 硬件加速的 CSS3 动画插件
Minimit Anima 是一个实现 CSS3 Transforms 和 Transitions 动画的 jQuery 插件.基于硬件加速的 CSS3 动画执行更快,而且它有一个类似于 jQuery ...
- Velocity – 另外一款加速的 jQuery 动画插件
Velocity 是一款 jQuery 插件,重新实现了 $.animate() 方法,提供更高的性能(比 CSS 动画还更快),同时包括一些新的功能,以改进动画工作流程.Velocity 除了包括所 ...
随机推荐
- NC65在日常开发中常用的代码写法
标题 NC65开发相关代码 版本 1.0.1 作者 walton 说明 收集NC在日常开发中常用的代码写法,示例展示 1.查询 1.1 通过BaseDAO查询结果集并转换 //通过BaseDAO进行查 ...
- 音视频入门-19-使用giflib处理GIF图片
* 音视频入门文章目录 * GIFLIB The GIFLIB project 上一篇 [手动生成一张GIF图片], 自己生成了一张 GIF 动态图 rainbow.gif. 下面,使用 GIFLIB ...
- 初识sa-token,一行代码搞定登录授权!
前言 在java的世界里,有很多优秀的权限认证框架,如Apache Shiro.Spring Security 等等.这些框架背景强大,历史悠久,其生态也比较齐全. 但同时这些框架也并非十分完美,在前 ...
- Java内存模型与线程(一)
Java内存模型与线程 TPS:衡量一个服务性能的标准,每秒事务处理的总数,表示一秒内服务端平均能够响应的总数,TPS又和并发能力密切相关. 在聊JMM(Java内存模型)之前,先说一下Java为什么 ...
- Linux学习笔记 | 配置Samba
Samba是在Linux和UNIX系统上实现SMB协议的一个免费软件,由服务器及客户端程序构成.SMB(Server Messages Block,信息服务块)是一种在局域网上共享文件和打印机的一种通 ...
- Hbase RIT故障修复
业务场景: RocketMQ+Storm+Hbase 组件版本: RocketMQ:3.4.6 Storm:1.2.1 Hbase:1.2.1 1. 问题描述 4月15号早上发现业务系统前一天数据量明 ...
- 【Linux】fdisk -l发现有加号"+"
今天分区不够了,打算扩下分区,想起当时创建机器的时候还有大约80多个G没有用,今天打算重新利用上 就用了fdisk /dev/sda 创建了两个分区,但是发现分区下面有加号,感到而别的困惑 最后在很多 ...
- 【Oracle】10g查看trace生成文件位置及文件名称
select u_dump.value || '/' || db_name.value || '_ora_' || v$process.spid || nvl2(v$process.trace ...
- ctfhub技能树—sql注入—报错注入
打开靶机 payload 1 Union select count(*),concat((查询语句),0x26,floor(rand(0)*2))x from information_schema.c ...
- python—打开图像文件报错
今天使用python打开一张图像文件的时候报错了 UnicodeDecodeError: 'gbk' codec can't decode byte 0xff in position 0: illeg ...