[Unity插件]DOTween基础

时间:2023-03-09 15:13:36
[Unity插件]DOTween基础

官方文档链接:http://dotween.demigiant.com/documentation.PHP#globalSettings

普通版下载地址:http://dotween.demigiant.com/download.php

pro版下载地址:http://pan.baidu.com/s/1dEzTQkL

(pro版提供DOTween Animation和DOTween Path这两个组件,支持可视化编辑)

移动类型:http://robertpenner.com/easing/easing_demo.html

DOTween真的比iTween好很多:

1.编写方面更加人性化

2.效率高很多,其中有一点是因为iTween使用的是unity内置的SendMessage

DOTween一般的样子是这样滴:

using DG.Tweening;

transform.DOMoveX(45, 1).SetDelay(2).SetEase(Ease.OutQuad).OnComplete(MyCallback);

好了,正式开始!

一些名词:

Tweener:补间动画

Sequence:相当于一个Tweener的链表,可以通过执行一个Sequence来执行一串Tweener

Tween:Tweener + Sequence

Nested tween:Sequence中的一个Tweener称为一个Nested tween

主要的方法(就是最常用的):

1.以DO开头的方法:就是补间动画的方法。例如:transform.DOMoveX(100,1)

2.以Set开头的方法:设置补间动画的一些属性。例如:myTween.SetLoops(4, LoopType.Yoyo)

3.以On开头的方法:补间动画的回调方法。例如:myTween.OnStart(myStartFunction)

DOTween初始化与全局设置:

当你第一次创建一个Tween时,DOTween就会自动初始化(只初始化一次),使用缺省值。

当然,也可以使用DOTween.Init方法进行自定义,但要在第一次创建一个Tween前。所有创建的Tween都会受DOTween.Init方法的影响。

但之后,你也可以通过DOTween类的一些静态方法或者变量来修改全局设置:

  1. static LogBehaviour DOTween.logBehaviour
  2. static bool DOTween.showUnityEditorReport
  3. static float DOTween.timeScale
  4. static bool DOTween.useSafeMode
  5. static DOTween.SetTweensCapacity(int maxTweeners, int maxSequences)
  6. static bool DOTween.defaultAutoKill
  7. static AutoPlay DOTween.defaultAutoPlay
  8. static float DOTween.defaultEaseOvershootOrAmplitude
  9. static float DOTween.defaultEasePeriod
  10. static Ease DOTween.defaultEaseType
  11. static LoopType DOTween.defaultLoopType
  12. static bool DOTween.defaultRecyclable
  13. static bool DOTween.defaultTimeScaleIndependent
  14. static UpdateType DOTween.defaultUpdateType

static DOTween.Init(bool recycleAllByDefault = false, bool useSafeMode = true, LogBehaviour logBehaviour = LogBehaviour.ErrorsOnly)

recycleAllByDefault :如果为true,则当Tween完成时就会被回收,放到一个池中;否则就会被destroy

useSafeMode :效率会稍微降低,但更安全

logBehaviour :默认值为只打印错误信息

创建Tweener(有三种方法):

1.

  1. static DOTween.To(getter, setter, to, float duration)
  2. 以DOTween.To(() => myVector, x => myVector = x, new Vector3(3, 4, 8), 1);为例,就是对myVector进行插值,目标值为Vector3(3, 4, 8)

2.

  1. transform.DOMove(new Vector3(2,3,4), 1);
  2. rigidbody.DOMove(new Vector3(2,3,4), 1);
  3. material.DOColor(Color.green, 1);

对于unity内置的一些组件,都可以通过".+DO开头的方法"的方式创建补间动画

以transform.DOMove(new Vector3(2,3,4), 1)为例,new Vector3(2,3,4)是最终值,意思是用一秒的时间运动到Vector3(2,3,4)

而transform.DOMove(new Vector3(2, 3, 4), 1).From(),就是从Vector3(2,3,4)运动到当前位置

3.

  1. static DOTween.Punch(getter, setter, Vector3 direction, float duration, int vibrato, float elasticity)
  2. static DOTween.Shake(getter, setter, float duration, float/Vector3 strength, int vibrato, float randomness, bool ignoreZAxis)
  3. static DOTween.ToAlpha(getter, setter, float to, float duration)
  4. static DOTween.ToArray(getter, setter, float to, float duration)
  5. static DOTween.ToAxis(getter, setter, float to, float duration, AxisConstraint axis)
  6. static DOTween.To(setter, float startValue, float endValue, float duration)

创建Sequence:

Sequence可以包含Sequence,当执行一个Sequence时会顺序执行Tweener,可以使用Insert方法实现同时执行。

Sequence的方法:

  1. static DOTween.Sequence()
  2. Append(Tween tween)
  3. AppendCallback(TweenCallback callback)
  4. AppendInterval(float interval)
  5. Insert(float atPosition, Tween tween)
  6. InsertCallback(float atPosition, TweenCallback callback)
  7. Join(Tween tween)
  8. Prepend(Tween tween)
  9. PrependCallback(TweenCallback callback)
  10. PrependInterval(float interval)

例子:

  1. // Grab a free Sequence to use
  2. Sequence mySequence = DOTween.Sequence();
  3. // Add a movement tween at the beginning
  4. mySequence.Append(transform.DOMoveX(1, 1));
  5. // Add a rotation tween as soon as the previous one is finished
  6. mySequence.Append(transform.DORotate(new Vector3(0, 180, 0), 1));
  7. // Delay the whole Sequence by 1 second
  8. mySequence.PrependInterval(1);
  9. // Insert a scale tween for the whole duration of the Sequence
  10. mySequence.Insert(0, transform.DOScale(new Vector3(3, 3, 3), mySequence.Duration()));

等同于:

  1. Sequence mySequence = DOTween.Sequence();
  2. mySequence.Append(transform.DOMoveX(45, 1))
  3. .Append(transform.DORotate(new Vector3(0, 180, 0), 1))
  4. .PrependInterval(1)
  5. .Insert(0, transform.DOScale(new Vector3(3, 3, 3), mySequence.Duration()));

上面我们提到了全局设置,这里我们再说一说针对Tweener和Sequence的局部设置

  1. float timeScale
  2. SetAs(Tween tween \ TweenParams tweenParams)
  3. SetAutoKill(bool autoKillOnCompletion = true)
  4. SetEase(Ease easeType \ AnimationCurve animCurve \ EaseFunction customEase)
  5. SetId(object id)
  6. SetLoops(int loops, LoopType loopType = LoopType.Restart)
  7. SetRecyclable(bool recyclable)
  8. SetUpdate(UpdateType updateType, bool isIndependentUpdate = false)
  9. 注意的一点是SetUpdate方法可以让目标忽略timeScale

回调方法:

  1. OnComplete(TweenCallback callback)
  2. OnKill(TweenCallback callback)
  3. OnPlay(TweenCallback callback)
  4. OnPause(TweenCallback callback)
  5. OnRewind(TweenCallback callback)
  6. OnStart(TweenCallback callback)
  7. OnStepComplete(TweenCallback callback)
  8. OnUpdate(TweenCallback callback)
  9. OnWaypointChange(TweenCallback<int> callback)

还有一些针对部分Tweener的特殊的局部设置:

[Unity插件]DOTween基础

注意SetOptions方法必须紧跟Tweener,就好像这样:

DOTween.To(()=> myVector, x=> myVector = x, new Vector3(2,2,2), 1).SetOptions(AxisConstraint.Y, true);

TweenParams:

就是可以将一些参数应用到多个Tweener中

  1. // Store settings for an infinite looping tween with elastic ease
  2. TweenParams tParms = new TweenParams().SetLoops(-1).SetEase(Ease.OutElastic);
  3. // Apply them to a couple of tweens
  4. transformA.DOMoveX(15, 1).SetAs(tParms);
  5. transformB.DOMoveY(10, 1).SetAs(tParms);

操作Tweener(有三种方法):

1.DOTween静态方法

  1. // Pauses all tweens
  2. DOTween.PauseAll();
  3. // Pauses all tweens that have "badoom" as an id
  4. DOTween.Pause("badoom");
  5. // Pauses all tweens that have someTransform as a target
  6. DOTween.Pause(someTransform);

2.Tweener方法

  1. myTween.Pause();

3.部件.+以DO开头的方法

  1. transform.DOPause();

以上的是Pause方法,以下的是其余的操作方法。上面三种方式中,DOTween和Tweener都有以下的操作方法,而部件的话,要在前面加上"DO"。

  1. CompleteAll/Complete()
  2. FlipAll/Flip()
  3. GotoAll/Goto(float to, bool andPlay = false)
  4. KillAll/Kill(bool complete = true)
  5. PauseAll/Pause()
  6. PlayAll/Play()
  7. PlayBackwardsAll/PlayBackwards()
  8. PlayForwardAll/PlayForward()
  9. RestartAll/Restart(bool includeDelay = true)
  10. RewindAll/Rewind(bool includeDelay = true)
  11. TogglePauseAll/TogglePause()

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

实例:

1.

  1. using UnityEngine;
  2. using System.Collections;
  3. using DG.Tweening;
  4. public class Test : MonoBehaviour {
  5. public RectTransform rt;
  6. private bool isIn = false;
  7. // Use this for initialization
  8. void Start ()
  9. {
  10. //修改的是世界坐标
  11. //Tweener t = rt.DOMove(Vector3.zero, 0.3f);
  12. //修改的是局部坐标
  13. Tweener t = rt.DOLocalMove(Vector3.zero, 0.3f);
  14. //默认动画播放完成会自动销毁
  15. t.SetAutoKill(false);
  16. t.Pause();
  17. }
  18. public void OnClick ()
  19. {
  20. if (!isIn)
  21. {
  22. //将开始该物体的所有Tweener
  23. rt.DOPlayForward();
  24. }
  25. else
  26. {
  27. rt.DOPlayBackwards();
  28. }
  29. isIn = !isIn;
  30. }
  31. }

[Unity插件]DOTween基础

2.

  1. using UnityEngine;
  2. using System.Collections;
  3. using DG.Tweening;
  4. using UnityEngine.UI;
  5. public class Test2 : MonoBehaviour {
  6. public Transform t;
  7. public Text text;
  8. // Use this for initialization
  9. void Start ()
  10. {
  11. //Vector3.zero是绝对位置,表示从Vector3.zero移动到当前位置
  12. //t.DOMove(Vector3.zero, 2).From();
  13. //默认为false
  14. //Vector3.forward是相对位置,表示从Vector3.forward加当前位置移动到当前位置
  15. t.DOMove(Vector3.forward, 2).From(true);
  16. //逐字显示
  17. text.DOText("宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥宏哥", 3);
  18. }
  19. }

[Unity插件]DOTween基础