http://blog.csdn.net/onafioo/article/details/46403801

http://www.winig.cc/archives/348

好久没有写文章了,最近在做项目是用的unity最新的ui系统UGUI,项目需要做一个摇杆,网上大部分都是用的插件和NGUI做的摇杆,unity自带的摇杆也不怎么好用,而最新的unity4.6.x来了,加入了最新的UI系统“UGUI”,那我们怎么用UGUI来制作摇杆呢~大神勿喷,本人是技术渣渣。

比较出色的摇杆插件《Easy Touch》(很强大)

还是主要讲讲我们自己怎么做。

  1. 首先在unity场景里面新建一个空物体和两个Image,把空物体放在创建Image自动生成的Canvas里面,再把两个Image放在空物体里

    Image建立方式:GameObject->UI->Image   或者直接在“Hierarchy”右键然后UI->Image,看喜好。

    空物体和两个Image的命名看个人喜好。

    威恩的节点是这样的:

    节点中的joystack是刚刚建立的空节点。

    Backgound是摇杆的背景。

    JoystackControl是真实的可以拖动的摇杆。

  2. 把Backgound和JoystackControl的SourceImage替换成自己喜欢的图片,并且把JoystackControl的图片缩小点,这里我就用系统自带的图片了,威恩这两个节点的inspector如下(我修改过得地方用红框标注了,其他都没改):

    最终样子如下:

  3. 那么样子有了就需要让他动起来,需要三个类“EventTriggerListener”、“JoystackCc”、“PlayerMoveControl”。

    EventTriggerListener:在NGUI开发的时候处理事件都会用到UIEventListener,我们已经用的习惯的不得了,而UGUI则不是这种机制,

    并且我觉得这种是最合理的方式,所以自己写一套类似的。

    只是一个帮助类,不需要挂在任何的游戏对象上。

    JoystackCc:这是主要来控制摇杆的。

    挂在JoystackControl节点上

    PlayerMoveControl:这是主要来通过摇杆来控制角色的。

    挂在你想控制的物体上

    直接上代码,写了注释,就不哔哔了。

    EventTriggerListener.cs

    1. using UnityEngine;
    2. using System.Collections;
    3. using UnityEngine.EventSystems;
    4. using System.Collections.Generic;
    5. /// <summary>
    6. /// UGUI事件监听类
    7. /// </summary>
    8. public class EventTriggerListener : UnityEngine.EventSystems.EventTrigger{
    9. publicdelegate void VoidDelegate (GameObject go);
    10. publicdelegate void VectorDelegate(GameObject go, Vector2 delta);
    11. publicVoidDelegate onClick;
    12. publicVoidDelegate onDown;
    13. publicVoidDelegate onEnter;
    14. publicVoidDelegate onExit;
    15. publicVoidDelegate onUp;
    16. publicVoidDelegate onSelect;
    17. publicVoidDelegate onUpdateSelect;
    18. publicVectorDelegate onDrag;
    19. publicVoidDelegate onDragOut;
    20. staticpublic EventTriggerListener Get (GameObject go)
    21. {
    22. if(go==null){
    23. Debug.LogError("EventTriggerListener_go_is_NULL");
    24. return null;
    25. }
    26. else{
    27. EventTriggerListener listener = go.GetComponent<EventTriggerListener>();
    28. if (listener == null) listener = go.AddComponent<EventTriggerListener>();
    29. return listener;
    30. }
    31. }
    32. publicoverride void OnDrag(PointerEventData eventData)
    33. {
    34. if(onDrag != null) onDrag(gameObject, eventData.delta);
    35. }
    36. publicoverride void OnEndDrag(PointerEventData eventData)
    37. {
    38. if(onDragOut != null) onDragOut(gameObject);
    39. }
    40. publicoverride void OnPointerClick(PointerEventData eventData)
    41. {
    42. if(onClick !=null)  onClick(gameObject);
    43. }
    44. publicoverride void OnPointerDown (PointerEventData eventData){
    45. if(onDown !=null) onDown(gameObject);
    46. }
    47. publicoverride void OnPointerEnter (PointerEventData eventData){
    48. if(onEnter !=null) onEnter(gameObject);
    49. }
    50. publicoverride void OnPointerExit (PointerEventData eventData){
    51. if(onExit !=null) onExit(gameObject);
    52. }
    53. publicoverride void OnPointerUp (PointerEventData eventData){
    54. if(onUp !=null) onUp(gameObject);
    55. }
    56. publicoverride void OnSelect (BaseEventData eventData){
    57. if(onSelect !=null) onSelect(gameObject);
    58. }
    59. publicoverride void OnUpdateSelected (BaseEventData eventData){
    60. if(onUpdateSelect !=null) onUpdateSelect(gameObject);
    61. }
    62. }
     
     
  4. JoystackCc.cs

    1. using UnityEngine;
    2. using System.Collections;
    3. public class JoystackCc : MonoBehaviour {
    4. privateVector3 Origin;
    5. Transform mTrans;
    6. privateVector3 _deltaPos;
    7. privatebool _drag = false;
    8. privateVector3 deltaPosition;
    9. floatdis;
    10. [SerializeField]
    11. privatefloat MoveMaxDistance = 80;            //最大拖动距离
    12. [HideInInspector]
    13. publicVector3 FiexdMovePosiNorm; //固定8个角度移动的距离
    14. [HideInInspector]
    15. publicVector3 MovePosiNorm;  //标准化移动的距离
    16. [SerializeField]
    17. privatefloat ActiveMoveDistance = 1;              //激活移动的最低距离
    18. voidAwake()
    19. {
    20. EventTriggerListener.Get(gameObject).onDrag = OnDrag;
    21. EventTriggerListener.Get(gameObject).onDragOut = OnDragOut;
    22. EventTriggerListener.Get(gameObject).onDown = OnMoveStart;
    23. }
    24. // Use this for initialization
    25. voidStart () {
    26. Origin = transform.localPosition;//设置原点
    27. mTrans = transform;
    28. }
    29. // Update is called once per frame
    30. voidUpdate()
    31. {
    32. dis = Vector3.Distance(transform.localPosition, Origin);//拖动距离,这不是最大的拖动距离,是根据触摸位置算出来的
    33. if(dis >= MoveMaxDistance)       //如果大于可拖动的最大距离
    34. {
    35. Vector3 vec = Origin + (transform.localPosition - Origin) * MoveMaxDistance / dis;  //求圆上的一点:(目标点-原点) * 半径/原点到目标点的距离
    36. transform.localPosition = vec;
    37. }
    38. if(Vector3.Distance(transform.localPosition, Origin) > ActiveMoveDistance) //距离大于激活移动的距离
    39. {
    40. MovePosiNorm = (transform.localPosition - Origin).normalized;
    41. MovePosiNorm = new Vector3(MovePosiNorm.x, 0, MovePosiNorm.y);
    42. }
    43. else
    44. MovePosiNorm = Vector3.zero;
    45. }
    46. voidMiouseDown()
    47. {
    48. if((Input.touchCount > 0 && Input.GetTouch(0).phase == TouchPhase.Moved))
    49. {
    50. }
    51. else
    52. mTrans.localPosition = Origin;
    53. }
    54. Vector3 result;
    55. privateVector3 _checkPosition(Vector3 movePos, Vector3 _offsetPos)
    56. {
    57. result = movePos + _offsetPos;
    58. returnresult;
    59. }
    60. voidOnDrag(GameObject go, Vector2 delta)
    61. {
    62. if(!_drag)
    63. {
    64. _drag = true;
    65. }
    66. _deltaPos = delta;
    67. mTrans.localPosition +=new Vector3(_deltaPos.x, _deltaPos.y, 0);
    68. }
    69. voidOnDragOut(GameObject go)
    70. {
    71. _drag =false;
    72. mTrans.localPosition = Origin;
    73. if(PlayerMoveControl.moveEnd != null) PlayerMoveControl.moveEnd();
    74. }
    75. voidOnMoveStart(GameObject go)
    76. {
    77. if(PlayerMoveControl.moveStart != null) PlayerMoveControl.moveStart();
    78. }
    79. }
  5.  
     

    PlayerMoveControl.cs

    1. using UnityEngine;
    2. using System.Collections;
    3. public class PlayerMoveControl : MonoBehaviour {
    4. privateTransform _mTransform;
    5. publicJoystackCc _mJoystackCc;
    6. publicfloat moveSpeed = 50;
    7. publicdelegate void MoveDelegate();
    8. publicstatic MoveDelegate moveEnd;
    9. publicstatic MoveDelegate moveStart;
    10. publicstatic PlayerMoveControl Instance;
    11. // Use this for initialization
    12. voidAwake()
    13. {
    14. Instance =this;
    15. _mTransform = transform;
    16. moveEnd = OnMoveEnd;
    17. moveStart = OnMoveStart;
    18. }
    19. voidStart () {
    20. }
    21. voidOnMoveEnd()
    22. {
    23. _turnBase =false;
    24. }
    25. voidOnMoveStart()
    26. {
    27. _turnBase =true;
    28. }
    29. // Update is called once per frame
    30. privatefloat angle;
    31. privatebool _turnBase = false;
    32. voidUpdate()
    33. {
    34. if(_turnBase)
    35. {
    36. Vector3 vecMove = _mJoystackCc.MovePosiNorm*Time.deltaTime*moveSpeed/10;
    37. _mTransform.localPosition+=vecMove;
    38. angle = Mathf.Atan2 (_mJoystackCc.MovePosiNorm.x, _mJoystackCc.MovePosiNorm.z) * Mathf.Rad2Deg - 10;
    39. _mTransform.localRotation = Quaternion.Euler(Vector3.up*angle);
    40. }
    41. }
    42. }
     
     

    建好这三个类之后,把他们绑定到相应的节点上。都挂在哪,代码上面有写

  6. 测试一下,威恩新建了一个cube来作为测试对象,加了个plane作为“伪”地面,太黑了再打个灯….

    下面是测试效果:

如果有任何问题直接留言~尽自己所能帮忙解决~

【转】UGUI实现unity摇杆的更多相关文章

  1. UGUI实现unity摇杆

    http://www.winig.cc/archives/348 好久没有写文章了,最近在做项目是用的unity最新的ui系统UGUI,项目需要做一个摇杆,网上大部分都是用的插件和NGUI做的摇杆,u ...

  2. 【转】Unity3D学习日记(一)使用UGUI制作虚拟摇杆

    http://blog.csdn.net/begonia__z/article/details/51170059 如今手机游戏玩法多种多样,尤其使用虚拟摇杆进行格斗类游戏开发或者是MMORPG成为了主 ...

  3. 用Unity的UGUI实现简单摇杆

    1.在Canvas下新建一个空对象作为我们的摇杆,命名为Joystick. 摇杆由背景和杆两部分组成,所以在Joystick下新建一个Image作为摇杆的背景,命名为BG. 在BG下新建一个Image ...

  4. 【转】Unity3D学习日记(二)使用UGUI制作虚拟摇杆控制摄像机

    http://blog.csdn.net/begonia__z/article/details/51178907 前天撸了一个简单的UGUI虚拟摇杆,今天我就利用前天做的虚拟摇杆做了一个简单的摄像机控 ...

  5. 时光煮雨 Unity3D让物体动起来③—UGUI DoTween&Unity Native2D实现

    本文首发蛮牛,次发博客园.接系列 第一篇,第二篇,本文为第三篇,再次感谢“武装三藏”在前两篇无私且精彩的问题解答 写在最前,时光煮雨,为了怀念 以下引用曾今读过的一些教程文章 其实这3种动画都有它特定 ...

  6. unity使用UGUI创建摇杆

    1.现在unity做一个项目,各种插件各种包,于是项目资源就无限变大了,其实一些简单的功能可以自己写,这里就是试着使用UGUI编写一个摇杆功能 2.脚本如下: using UnityEngine; u ...

  7. Unity UGUI RectTransform图解

    UGUI RectTransform.Unity RectTransform详解 The first:look look API. http://docs.unity3d.com/ScriptRefe ...

  8. 【Unity3D基础教程】给初学者看的Unity教程(六):理解Unity的新GUI系统(UGUI)

    作者:王选易,出处:http://www.cnblogs.com/neverdie/ 欢迎转载,也请保留这段声明.如果你喜欢这篇文章,请点推荐.谢谢! 理解UGUI的基础架构 UGUI是Unity在4 ...

  9. Unity3D_05_理解Unity的新GUI系统(UGUI)

    理解Unity的新GUI系统(UGUI) Unity GUI 链接:UnityEngine.UI系统基础类架构图  Unity GUI 链接:UnityEngine Event & Event ...

随机推荐

  1. loj 1021(状压dp+记忆化搜索)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=25887 题目大意:给定的一个某进制下的排列,问它的全排列有多少个能 ...

  2. ARP缓存表的构成ARP协议全面实战协议详解、攻击与防御

    ARP缓存表的构成ARP协议全面实战协议详解.攻击与防御 1.4.3  ARP缓存表的构成 在局域网的任何一台主机中,都有一个ARP缓存表.该缓存表中保存中多个ARP条目.每个ARP条目都是由一个IP ...

  3. 常见的文件上传方法有哪些?Ajax文件上传原理是什么?

    Ajaxfileupload,Ajaxupload,JqueryUploadify无刷新式的文件上传,在一个页面里嵌入一个Iframe,然后在Iframe使用原生的Post表单提交.

  4. 递推DP URAL 1167 Bicolored Horses

    题目传送门 题意:k个马棚,n条马,黑马1, 白马0,每个马棚unhappy指数:黑马数*白马数,问最小的unhappy值是多少分析:dp[i][j] 表示第i个马棚放j只马的最小unhappy值,状 ...

  5. Codeforces 86C Genetic engineering(AC自动机+DP)

    题目大概是给几个DNA片段,求构造一个长度n的字符串的方案数,要求这个字符串每个位置的字符都属于某个包含于此字符串的DNA片段. 把那些DNA片段建一个AC自动机.考虑状态的表示: dp[len][x ...

  6. Splay 伸展树

    废话不说,有篇论文可供参考:杨思雨:<伸展树的基本操作与应用> Splay的好处可以快速分裂和合并. ===============================14.07.26更新== ...

  7. CSS对浏览器的兼容性(IE和Firefox)技巧整理

    CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理技巧并整理了一下.对于web2.0的过度,请尽量用xhtml格 ...

  8. MySQL 记录不存在时插入 记录存在则更新的实现方法

    INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=c+1; INSERT 中 ON DUPLICATE KEY UP ...

  9. react-native 学习

    官网 https://facebook.github.io/react-native/docs/getting-started.html#content 下载 npm install -g react ...

  10. shenyi 语录

    [讲师]沈逸(65480539) 2016-06-08 14:58:42   会centos 转redhat是分分钟的事 [讲师]沈逸(65480539) 2016-06-08 14:58:54 查看 ...