我是靠谱客的博主 活泼小熊猫,这篇文章主要介绍Unity摇杆制作的方法,现在分享给大家,希望可以做个参考。

本文实例为大家分享了Unity摇杆制作方法的具体代码,供大家参考,具体内容如下

一.UI制作

1.首先创建一个空物体,命名为摇杆,锚点调至左下角

2.创建一个image作为摇杆厨盆的有效地方,并命名为tough_place

3.创建一个image放入摇杆的背景图片,并命名为bg。

4.创建一个image放入摇杆的控制点,并命名为point。

5.把tough_place的颜色设置为透明

二.代码编写

创建脚本命名为PEListener,并引入相关接口,并进行封装。

复制代码
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
29
30
31
32
33
using System; using UnityEngine; using UnityEngine.EventSystems; public class PEListener : MonoBehaviour, IPointerDownHandler, IPointerUpHandler, IDragHandler { public Action<PointerEventData> onClickDown;//鼠标按下时触发的事件 public Action<PointerEventData> onClickUp;//鼠标抬起时触发的事件 public Action<PointerEventData> onClickDrag;//鼠标按下时触发的事件 public void OnPointerDown(PointerEventData eventData) { if (onClickDown != null) { onClickDown(eventData); } } public void OnPointerUp(PointerEventData eventData) { if (onClickUp != null) { onClickUp(eventData); } } public void OnDrag(PointerEventData eventData) { if (onClickDrag!=null) { onClickDrag(eventData); } } }

创建脚本命名为Test,进行相关的逻辑操作。

(1)定义相关数据并传入

复制代码
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
using UnityEngine; using UnityEngine.EventSystems; using UnityEngine.UI; public class Test : MonoBehaviour { //轮盘UI public Image imageTough;//轮盘触摸区域 public Image imgDir;//轮盘背景 public Image imaPoint;//轮盘操作点 //轮盘相关数据 Vector2 startPos;//轮盘按下的坐标 Vector2 defulPos;//轮盘按下的坐标 float poinDis=90;// 轮盘中心和边缘的最大距离(数据自己测试) private void Start() { defulPos = imageTough.transform.position; //由于我们的Canvas选择的是Scale with Screen Size,且Match为1,也就是UI缩放受高度影响到大,具体数据见下图 //poinDis实际大小=poinDis *缩放 poinDis = Screen.height * 1.0f / 1334 * poinDis; } }

(2)进行相关逻辑的书写

复制代码
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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
using UnityEngine; using UnityEngine.EventSystems; using UnityEngine.UI; public class Test : MonoBehaviour { //轮盘UI public Image imageTough;//轮盘触摸区域 public Image imgDir;//轮盘背景 public Image imaPoint;//轮盘操作点 //轮盘相关数据 Vector2 startPos;//轮盘按下的坐标 Vector2 defulPos;//轮盘按下的坐标 float poinDis=90;// 轮盘中心和边缘的最大距离(数据自己测试) private void Start() { defulPos = imageTough.transform.position; //由于我们的Canvas选择的是Scale with Screen Size,且Match为1,也就是UI缩放受高度影响到大,具体数据见下图 //poinDis实际大小=poinDis *缩放 poinDis = Screen.height * 1.0f / 1334 * poinDis; RegisterTouchEvts(); } public void RegisterTouchEvts() { PEListener lister = imageTough.gameObject.AddComponent<PEListener>(); lister.onClickDown = (PointerEventData evt) => { //鼠标按下时设置轮盘背景位置 startPos = evt.position; imgDir.transform.position = evt.position; }; lister.onClickUp = (PointerEventData evt) => { //鼠标抬起时设置轮盘背景位置和轮盘操作点为默认位置 imgDir.transform.position = defulPos; imaPoint.transform.localPosition = Vector2.zero; }; lister.onClickDrag = (PointerEventData evt) => { //计算是否超过轮盘中心和边缘的最大距离 Vector2 dir = evt.position - startPos; float len = dir.magnitude; //超过了,限制为最大位置 if (len > poinDis) { Vector2 clampDir = Vector2.ClampMagnitude(dir, poinDis); imaPoint.transform.position = startPos + clampDir; } else { imaPoint.transform.position = evt.position; } }; } }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持靠谱客。

最后

以上就是活泼小熊猫最近收集整理的关于Unity摇杆制作的方法的全部内容,更多相关Unity摇杆制作内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(137)

评论列表共有 0 条评论

立即
投稿
返回
顶部