一.简单的变量插值运算

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动画插件学习的更多相关文章

  1. Unity3D_(插件)DOTween动画插件

    使用DOTween动画插件来实现物体的移动动画 Learn 一.DOTween插件对变量的动画 二.控制Cube和UI面板的动画 三.动画的快捷播放方式 四.动画的前放和后放 五.From Tween ...

  2. DoTween 动画插件简单示例

    .doTween的静态方法 DOTween.To(() => maskImage.color, toColor => maskImage.color = toColor, , , , ), ...

  3. #Plugin 数字滚动累加动画插件

    数字滚动累加动画插件  NumScroll 1.使用前先引入jquery2.前端学习群:814798690 下载地址 https://github.com/chaorenzeng/jquery.num ...

  4. velocity.js 动画插件

    1. velocity.js 插件介绍 Velocity 是独立于jQuery的,但两者可以结合使用的动画插件.用法类似 jq 的 animate ,但是支持更高级动画. ( 颜色动画.转换动画(tr ...

  5. 让网站动起来!12款优秀的 jQuery 动画插件推荐

    如今,大多数设计师和开发人员被要客户要求开发动态的网站.创造视觉震撼和醒目的动态网站是艰巨的任务,因为它需要大量的努力和创造力.在网络上有大量的工具和插件可用于创建网站动画.许多开发人员正在使用 HT ...

  6. uexQQ插件学习心得

    uexQQ插件学习心得 uexQQ插件的作用:通过qq可以分享图文,音乐,应用到相应的qq空间.支持手机客户端分享和手机webQQ分享.下面我们就来看一看他的一些方法. 我们先说一下分享的步骤,这个步 ...

  7. emmet插件学习,练习中遇到一些问题

    emmet插件学习:帮助提高敲代码效率的插件 参考文献:Emmet(Zen coding)HTML代码使用技巧七则http://www.wzsky.net/html/Website/htmlcss/1 ...

  8. Minimit Anima – 硬件加速的 CSS3 动画插件

    Minimit Anima 是一个实现 CSS3 Transforms 和 Transitions 动画的 jQuery 插件.基于硬件加速的 CSS3 动画执行更快,而且它有一个类似于 jQuery ...

  9. Velocity – 另外一款加速的 jQuery 动画插件

    Velocity 是一款 jQuery 插件,重新实现了 $.animate() 方法,提供更高的性能(比 CSS 动画还更快),同时包括一些新的功能,以改进动画工作流程.Velocity 除了包括所 ...

随机推荐

  1. SpringCloud 源码系列(6)—— 声明式服务调用 Feign

    SpringCloud 源码系列(1)-- 注册中心 Eureka(上) SpringCloud 源码系列(2)-- 注册中心 Eureka(中) SpringCloud 源码系列(3)-- 注册中心 ...

  2. Azure Terraform(三)部署 Web 应用程序

    一,引言 上一节关于 Terraform 的文章讲到 Terraform 使用到的一些语法,以及通过演示使用 Terraform 在Azure 上部署资源组,极大的方便了基础设施实施人员,也提高了基础 ...

  3. Spring Cloud实战 | 第十篇 :Spring Cloud + Seata 1.4.1 + Nacos1.4.0 整合实现微服务架构中逃不掉的话题分布式事务

    Seata分布式事务在线体验地址:https://www.youlai.store 本篇完整源码地址:https://github.com/hxrui/youlai-mall 有想加入开源项目开发的童 ...

  4. mysqldump 的-T参数

    /usr/local/mysql/bin/mysqldump -uroot -T /tmp lina xuehao 把lina数据库中的xuehao表在tmp目录下备份出来两个文件,一个是纯数据.tx ...

  5. Test typora

    目录 0. test 0.5 easy test 1. problem 1 2. problem 2 3. problem 3 import numpy as np import matplotlib ...

  6. kafka安装流程

    本文是作者原创,版权归作者所有.若要转载,请注明出处. 安装前的环境准备 1.由于Kafka是用Scala语言开发的,运行在JVM上,在安装之前需要先安装JDK(省略) 2.kafka依赖zookee ...

  7. LeetCode-P53题解【动态规划】

    本文为原创,转载请注明:http://www.cnblogs.com/kylewilson/ 题目出处: https://leetcode.com/problems/maximum-subarray/ ...

  8. IP2726中文规格书

    IP2726_AC_FBR 是一款集成多种协议.用于USB-A 和 TYPE-C 双端口输出的快充协议 IC.支持多种快充协议,包括 USB TypeC DFP,PD2.0/PD3.0/PPS ,HV ...

  9. 数据库性能调优之始: analyze统计信息

    摘要:本文简单介绍一下什么是统计信息.统计信息记录了什么.为什么要收集统计信息.怎么收集统计信息以及什么时候收集统计信息. 1 WHY:为什么需要统计信息 1.1 query执行流程 下图描述了Gau ...

  10. 简易双色球dome分享

    代码如下: <style type="text/css"> div {font-weight: bold;text-align: center;} .tone{widt ...