要让一个描点的控件动画移动到一个Position,能够用TweenPosition。可是这个仅仅能用在Position是固定的情况下。并且不能依据分辨率适配来进行移动。

以NGUI自带的演示样例场景"Example 1 - Anchors"为例。如果要让"Left"移动到"Top Right",且无论随意分辨率都须要达到这个效果。这里的方法是改动TweenPosition代码,让其支持传入目标的Transform,而这个目标即是也被描点的控件。


打开TweenPosition.cs,加入例如以下代码:
1

2

3

4

5

6

7
public Transform sourceFrom;

public Transform targetTo;



static public TweenPosition Begin(GameObject go, float duration, Transform targetTo)

{

    return Begin(go, duration, go.transform.parent.InverseTransformPoint(targetTo.position));

}
改动OnUpdate函数为例如以下:
1

2

3

4

5

6

7

8

9

10

11

12

13

14
protected override void OnUpdate (float factor, bool isFinished) 

{

    if (sourceFrom != null)

    {

        from = cachedTransform.parent.InverseTransformPoint(sourceFrom.position);

        sourceFrom = null;

    }

    if (targetTo != null)

    {

        to = cachedTransform.parent.InverseTransformPoint(targetTo.position);

        targetTo = null;

    }

    value = from * (1f - factor) + to * factor; 

}

打开TweenPositionEditor.cs,改动OnInspectorGUI函数为例如以下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28
public class TweenPositionEditor : UITweenerEditor

{

    public override void OnInspectorGUI ()

    {

        GUILayout.Space(6f);

        NGUIEditorTools.SetLabelWidth(120f);



        TweenPosition tw = target as TweenPosition;

        GUI.changed = false;



        Vector3 from = EditorGUILayout.Vector3Field("From", tw.from);

        Transform sourceFrom = EditorGUILayout.ObjectField("Or From", tw.sourceFrom, typeof(Transform), true) as Transform;

        Vector3 to = EditorGUILayout.Vector3Field("To", tw.to);

        Transform targetTo = EditorGUILayout.ObjectField("Or To", tw.targetTo, typeof(Transform), true) as Transform;



        if (GUI.changed)

        {

            NGUIEditorTools.RegisterUndo("Tween Change", tw);

            tw.from = from;

            tw.to = to;

            tw.sourceFrom = sourceFrom;

            tw.targetTo = targetTo;

            NGUITools.SetDirty(tw);

        }



        DrawCommonProperties();

    }

}
如今在检视器能够看到例如以下配置:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvYWtvZjEzMTQ=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

设置其"Or From"和"Or To",然后执行。就可以看到位移动画,例如以下所看到的:

平时能够使用UIPlayTween来控制控件的动画播放。可是其仅支持点击、选中等等须要交互的动作才行,这里为其添加开启时就能够自己主动播放动画。打开AnimationOrTween.cs,为枚举Trigger添加一个枚举值,例如以下:

1

2

3

4

5

6
public enum Trigger

{

    OnClick,

    ……

    OnEnableTrue,

}
打开UIPlayTween.cs,在其OnEnable函数最后。加入例如以下代码:
1

2

3

4

5

6

7

8

9
void OnEnable ()

{

    ……

    

    if (trigger == Trigger.OnEnableTrue)

    {

        Play(true);

    }

}
这样UIPlayTween就能在开启时,直接播放动画了。

Unity NGUI 描点控件的位移动画的更多相关文章

  1. uwp - 控件精确移动动画

    原文:uwp - 控件精确移动动画 先看效果图: 一共有8个GRID,黄色的负责移动,其他7个负责定位.新建一个页面page,替换默认代码: <UserControl.Resources> ...

  2. Unity 通过Animation实现控件位置的转换

    Unity版本:4.5.1 NGUI版本:3.6.5 参考链接:http://blog.csdn.net/unity3d_xyz/article/details/23035521,作者:CSDN in ...

  3. NGUI的部分控件无法更改layer?

    http://momowing.diandian.com/post/2012-09-17/40038835795 今天狗日的遇到这样的问题,这是一个imagebutton:,它的层定义为:,NGUI里 ...

  4. Unity中uGUI的控件事件穿透逻辑

    1.正常来说Image和Text是会拦截点击事件的,假设加入EventTrigger的话,就能够响应相应的交互事件. 2.假设Image和Text是一个Button的子控件.那么尽管其会显示在Butt ...

  5. TimePicker控件、帧动画、补间动画

    1.TimePicker控件 最近感觉每个开发平台的控件基本都差不多,在Android中控件的事件和.net控件直接写事件有一定的区别,net事件可以直接界面进行事件的绑定哈.不过在Silverlig ...

  6. 自己定义控件三部曲之动画篇(七)——ObjectAnimator基本使用

    前言: 假如生活欺骗了你, 不要悲伤,不要心急! 忧郁的日子里须要镇静: 相信吧,快乐的日子终将会来临! 心儿永远向往着未来: 如今却常是忧郁. 一切都是瞬息,一切都将会过去: 而那过去了的,就会成为 ...

  7. 自己定义控件三部曲之动画篇(十三)——实现ListView Item进入动画

    前言:宝剑锋从磨砺出,梅花香自苦寒来 相关文章: <Android自己定义控件三部曲文章索引>: http://blog.csdn.net/harvic880925/article/det ...

  8. NGUI 动态添加控件

    本文链接地址: Unity3D NGUI动态创建按钮 本例仅以熟悉NGUI组件功能为目的,想快捷简便的创建按钮或其它游戏物体请参考 “Unity3D 动态实例化Prefab” 以动态创建服务器列表为例 ...

  9. [UNITY 5.4 UGUI] 控件重叠触摸穿透

    问题. imge 和 button重叠时,imge 覆盖在button上面,导致点击事件无法传递到button. 1.给imge 添加 [Canvas Group]组件 2.修改[Canvas Gro ...

随机推荐

  1. .net-C#代码判断

    ylbtech-doc:.net-C#代码判断 C#代码判断 1.A,C#代码判断返回顶部 01.{ C#题目}public static void Main(string[] args){     ...

  2. golang学习遭遇duang...duang...duang

    初学golang时,在windows上使用liteIDE进行,很多语法都能自己调整. 后来使用linux桌面,再次编写时,发现很多东西都忘掉了.这难道就是习惯gocode后的弊端吗?还是人到 前中年 ...

  3. javascript跑马灯抽奖

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. ASM基本操作

    1. 添加一个磁盘组 SQL> create diskgroup recover external redundancy disk 'ORCL:kel3'; Diskgroup created. ...

  5. webstrom11 激活,webstorm 2016.1激活

    http://15.idea.lanyus.com/  webstorm11注册激活,你值得拥有 webstorm 2016.1 最新激活方式:http://blog.lanyus.com/archi ...

  6. LeetCode 232 Implement Queue using Stacks

    Implement the following operations of a queue using stacks. push(x) -- Push element x to the back of ...

  7. java工程师的标准

    1.技术广度方面至少要精通多门开源技术吧,研究过struts\spring\hibernate等的源码. 2.项目经验方面从头到尾跟过几个大项目,头是指需求阶段,包括需求调研.尾是指上线交付之后,包括 ...

  8. 第三百零二天 how can I 坚持

    今天给掌中宝提了几个bug,确实管用,哈哈. 还有就是弟弟买房了,海亮艺术公馆,还好,至少安定下来了,可惜啊,我看好的房子也有的卖了,咋办啊. 看准的东西总是会想法设法的买了,可是无能为力啊. 还有, ...

  9. Spring MVC ControllerClassNameHandlerMapping example

    handler mapping是把url跟控制器关联起来. In Spring MVC, ControllerClassNameHandlerMapping use convention to map ...

  10. 通过源码学Java基础:BufferedReader和BufferedWriter

    准备写一系列Java基础文章,先拿Java.io下手,今天聊一聊BufferedReader和BufferedWriter BufferedReader BufferedReader继承Writer, ...