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 除了包括所 ...
随机推荐
- MMDetection 快速开始,训练自定义数据集
本文将快速引导使用 MMDetection ,记录了实践中需注意的一些问题. 环境准备 基础环境 Nvidia 显卡的主机 Ubuntu 18.04 系统安装,可见 制作 USB 启动盘,及系统安装 ...
- B树与B+树区别辨析
我们都知道,innodb中的索引结构使用的是B+树.B+树是一种B树的变形树,而B树又是来源于平衡二叉树.相较于平衡二叉树,B树更适合磁盘场景下文件索引系统.那为什么B树更适合磁盘场景,B+树又在B树 ...
- 基于CefSharp开发(七)浏览器收藏夹菜单
一.Edge收藏夹菜单分析 如下图所示为Edge收藏夹菜单, 点击收藏夹菜单按钮(红框部分)弹出收藏夹菜单窗体,窗体中包含工具栏(绿框部分)和树型菜单(黄框部分) 工具栏按钮功能分别为添加当前网页到根 ...
- 在微信小程序开发中使用Typescript
Typescript的优势咱不需要赘述太多,有兴趣可以参考(https://www.typescriptlang.org/).今天给大家分享一下如何在微信小程序(或者其他同类小程序)开发中使用Type ...
- oracle 11.2.0.1.0 升级 11.2.0.4.0 并 patch 到11.2.0.4.7
升级步骤: (1) 备份数据库 (2) 运行patchset,升级oracle 软件 (3) 准备新的ORACLE_HOME (4) 运行dbua 或者脚本升级实例 (5) ...
- kill 指令的执行原理
kill 指令有两种写法 " kill query + 线程 id "." kill connection(可缺省) + 线程 id ".分别表示关闭指定线程正 ...
- 技术实践丨React Native 项目 Web 端同构
摘要:尽管 React Native 已经进入开源的第 6 个年头,距离发布 1.0 版本依旧是遥遥无期."Learn once, write anywhere",完全不影响 Re ...
- 在Jetbrain IDE中自定义TODO功能
好的IDE能为开发以及学习源码带来效率的提升,今天要介绍的就是Jetbrain家族中IDE自带的TODO功能,我认为利用好它,能够大大的提升阅读源码的效率. 假设我现在需要去阅读源代码,看了半天我终于 ...
- CTFHub - Misc(流量分析)
数据库类流量: MySQL流量: 1.下载附件,是一个.pcap文件,用wireshark分析, 2.搜索ctfhub字段,即可得到flag, flag: ctfhub{mysql_is_S0_E4s ...
- Python输出有颜色的文字
原创链接: https://www.cnblogs.com/easypython/p/9084426.html 我们在使用python运维与开发的过程中,经常需要打印显示各种信息.海量的信息堆砌在 ...