123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- using UnityEngine;
- using System.Collections;
- public class TweenRect : Tween
- {
- #region
- protected Vector2 Delta;
- protected Vector2 Origin;
- protected Vector2 Destination;
- protected CanvasGroup CG;
- protected RectTransform Target;
- protected CurveFunctionV Func;
- #endregion
- public TweenRect(RectTransform target, Vector3 origin, Vector3 destination, float duration, bool originActive, bool destActive, Curve curve)
- {
- CG = target.GetComponent<CanvasGroup>();
- Func = ManaAnim.FunctionDicV[curve];
- Target = target;
- IsForward = false;
- IsBackward = false;
- Delta = destination - origin;
- Origin = origin;
- Duration = duration;
- DestActive = destActive;
- Destination = destination;
- OriginActive = originActive;
- OnForwardStart += () =>
- {
- Target.SetActive(true);
- if (CG != null)
- {
- CG.interactable = false;
- }
- };
- OnForwardFinish += () =>
- {
- Target.SetActive(DestActive);
- if (CG != null)
- {
- CG.interactable = DestActive;
- }
- };
- OnBackwardStart += () =>
- {
- Target.SetActive(true);
- if (CG != null)
- {
- CG.interactable = false;
- }
- };
- OnBackwardFinish += () =>
- {
- Target.SetActive(OriginActive);
- if (CG != null)
- {
- CG.interactable = OriginActive;
- }
- };
- }
- public override void StartForward()
- {
- base.StartForward();
- if (IsBackward)
- {
- Timer = Duration - Timer;
- }
- }
- public override void StartBackward()
- {
- base.StartBackward();
- if (IsForward)
- {
- Timer = Duration - Timer;
- }
- }
- public override bool DoForward()
- {
- Timer += Time.fixedDeltaTime;
- if (Timer > Duration)
- {
- Timer = 0;
- Target.sizeDelta = Destination;
- IsForward = false;
- OnForwardFinish.Invoke();
- ManaAnim.TweenForList.Remove(this);
- return true;
- }
- else
- {
- Target.sizeDelta = Func(Timer, Duration, Origin, Delta);
- return false;
- }
- }
- public override bool DoBackward()
- {
- Timer += Time.fixedDeltaTime;
- if (Timer > Duration)
- {
- Timer = 0;
- Target.sizeDelta = Origin;
- IsBackward = false;
- OnBackwardFinish.Invoke();
- ManaAnim.TweenBacList.Remove(this);
- return true;
- }
- else
- {
- Target.sizeDelta = Func(Timer, Duration, Destination, -Delta);
- return false;
- }
- }
- }
|