Unity3D 双摇杆 c# JoyStick 实现自己的双摇杆
转载请声明: http://www.cnblogs.com/ADaii/p/3859520.html
Untiy3D 官方摇杆脚本只能完成一个摇杆,要实现双摇杆比较费劲
现在我吧我废了一通宵的结果共享给大家
1.双摇杆是用来控制第一人称控制器的,但第一人称控制器右js和c#有的地方不能通用,所以首先要将所有将本变为c#脚本
http://www.cnblogs.com/ADaii/p/3859527.html
2.建立Joystick.cs脚本,我也在代码中加了注释方便大家理解
3.将GUI摇杆纹理放入脚本,并将脚本关联与第一人称控制器
4.修改第一人称控制器脚本(见2 连接)
/**
* 王天宇 编写于:2014-07-21
* JoyStick.cs
*/ using UnityEngine;
using System.Collections;
//创建枚举类型,可在加载脚本的实体上选择是左摇杆还是右摇杆
public enum JoyStickType
{
leftJoyStick,
rightJoyStick
} //脚本JoyStick类
public class JoyStick : MonoBehaviour
{
public JoyStickType joyStickType; //摇杆类型,左摇杆还是右摇杆
private Vector2 centerPos; //摇杆的中心点位置,屏幕坐标
public GUITexture centerBall; //球型摇杆
public float joyStickRadius; //摇杆移动范围的半径
private Vector2 position; //摇杆要传递出去的参数,就靠他控制移动旋转
private int lastFingerID = -; //最后一次触摸的手指id
private bool centerBallMoving = false; //球型摇杆移动开关
//加载时运行方法
void Start ()
{
//为了让摇杆适配不同分辨率屏幕,设置大小和坐标
centerBall.transform.localScale = new Vector3( centerBall.pixelInset.size.x / Screen.width, centerBall.pixelInset.size.y / Screen.height,);
//因为GUI纹理锚点都是左下角0,0 所以为了让两边摇杆对称摇杆坐标向-x方向移动半个纹理宽的屏幕距离(屏幕距离通过 纹理宽:屏幕分辨率宽 获得)
centerBall.transform.position = new Vector3 (centerBall.transform.position.x - centerBall.pixelInset.size.x//Screen.width,
centerBall.transform.position.y,);
//将摇杆坐标赋给作为摇杆的中心,以后用来复位摇杆用
centerPos = centerBall.transform.position;
}
//每帧运行方法
void Update ()
{
//调用摇杆方法
JoyStickController();
}
//摇杆方法
void JoyStickController()
{
int count = Input.touchCount; //获取触摸点的数量 for (int i = ; i < count; i++) //逐个分析触摸点的操作
{
Touch touch = Input.GetTouch(i); //获取当前处理的触摸点
//将当前的触摸坐标转换为屏幕坐标
Vector2 currentTouchPos = new Vector2(touch.position.x/Screen.width - centerBall.pixelInset.size.x//Screen.width, touch.position.y/Screen.height); Vector2 temp = currentTouchPos - centerPos; //得到方向向量temp(触摸的位置和摇杆的坐标差) if (centerBall.HitTest(touch.position)) //判断是否触摸点在要干范围之内
{
if (temp.magnitude < joyStickRadius) //如果方向向量temp的长度没有超出摇杆的半径,temp.magnitude为求坐标差的距离,及两点间的距离
{
lastFingerID = touch.fingerId; //记录该触摸的id
centerBallMoving = true; //摇杆移动开关打开
}
}
//若中心球移动开关打开,摇杆中心球就会跟随手指移动。但需要加以限制,当手指触摸没有超出摇杆的圆形区域时,中心球完全跟随手指触摸;
//当手指触摸超出圆形区域时,中心球处于触摸位置和摇杆中心点所形成的方向上并且不能超出半径
if (touch.fingerId == lastFingerID && centerBallMoving)
{
if (temp.magnitude < joyStickRadius) //如果手指触摸没有超出摇杆的圆形区域,即摇杆半径,摇杆中心球的位置一直跟随手指
{ centerBall.transform.position = new Vector3 (currentTouchPos.x,currentTouchPos.y,); //设置摇杆的坐标等于触点的坐标
}
else //超出半径
{
Vector2 temp2 = temp; //定义临时变量temp2
temp2.Normalize(); //将temp2标准化
//设置摇杆坐标位置不超过半径
centerBall.transform.position = new Vector3((joyStickRadius * temp2 + centerPos).x, (joyStickRadius * temp2 + centerPos).y, );
} if (temp.x >= )
{
//一下为示例代码:控制旋转方向,主要利用Vector2.Angle(temp, new Vector2(0, 5))得到角度并利用
//initialization_script.current_player_tank_script.BodyRotation(Vector2.Angle(temp, new Vector2(0, 5)));
}
if (temp.x< )
{
//一下为示例代码:控制旋转方向,主要利用Vector2.Angle(temp, new Vector2(0, 5))得到角度并利用
//initialization_script.current_player_tank_script.BodyRotation(-1 * Vector2.Angle(temp1, new Vector2(0, 5)));
}
//控制移动的函数或者控制开火的函数,假设左摇杆控制移动,右摇旋转
switch(joyStickType)
{
case JoyStickType.leftJoyStick:
position = temp*; //移动需坐标
break;
case JoyStickType.rightJoyStick:
position = temp*; //旋转需坐标
break;
}
//当释放触摸的时候中心球位置重置
if (touch.phase == TouchPhase.Ended || touch.phase == TouchPhase.Canceled)
{
centerBall.transform.position = new Vector3(centerPos.x, centerPos.y, ); //摇杆复位
temp = new Vector2(,); //距离差为0
position = temp; //赋值0给需要坐标已停止动作
centerBallMoving = false; //设置不能移动摇杆
lastFingerID = -; //清楚本次手指触摸id
}
}
}
}
//获取传递坐标方法
public Vector2 getPositions()
{
return position;
}
}
Unity3D 双摇杆 c# JoyStick 实现自己的双摇杆的更多相关文章
- Unity5.5+easytouch5双摇杆控制角色移动
第一步:新建两个Joystick,分别改名LeftJoyStick和RightJoyStick 在LeftJoyStick的ETC Joystick-Axes properties中的Horizont ...
- Unity3D插件之Easy Touch 3.1(1): Easy Joystick
先看官方介绍:https://www.assetstore.unity3d.com/#/content/3322 (Allows you to quickly and easily develop a ...
- Unity3D for iOS初级教程:Part 2/3
转自Unity3D for iOS 这篇文章还可以在这里找到 英语 Learn how to use Unity to make a simple 3D iOS game! 这篇教材是来自教程团队成员 ...
- Unity3D 第一人称控制器 C#脚本
CharacterMotor.cs using UnityEngine; using System.Collections; /** * @Author : www.xuanyusong.com */ ...
- unity3d插件Daikon Forge GUI 中文教程1-Daikon Forge介绍
DF-GUI特点: · 深编辑器集成:DF-GUI提供广泛的整合与Unity3D编辑环境,包括自定义检查人员对每个组件向导来简化复杂的多步任务,提高生产力的上下文菜单,编辑控件在一个所见 ...
- [Unity2D]2D Mobile Joystick
效果预览 操作步骤 1.下载素材 http://pan.bai du.com/s/1gdkQz8v 2.新建一个GUITexture(Joystick)及一个Sprite(Nyan) 3.添加背景 ...
- [Unity3D]Unity3D游戏开发之使用EasyTouch虚拟摇杆控制人物移动
大家好,欢迎大家关注我的博客,我是秦元培,我的博客地址是blog.csdn.net/qinyuanpei.今天呢,我们来一起学习在Unity3D中使用EasyTouch虚拟摇杆来控制人物移动.虽然Un ...
- 手机3D游戏开发:自定义Joystick的相关设置和脚本源码
Joystick在手游开发中非常常见,也就是在手机屏幕上的虚拟操纵杆,但是Unity3D自带的Joystick贴图比较原始,所以经常有使用自定义贴图的需求. 下面就来演示一下如何实现自定义JoySti ...
- unity3d插件Daikon Forge GUI 中文教程-1-Daikon Forge介绍
(游戏蛮牛首发)大家好我是孙广东官网提供了专业的视频教程http://www.daikonforge.com/dfgui/tutorials/,只是是在youtube上,要观看是须要FQ的. 只是教程 ...
随机推荐
- oracle 11g 空表也导出
查询空表 并导出修改空表语句 select 'alter table '||table_name||' allocate extent;' from user_tables where num_row ...
- 优化ubuntu桌面
---恢复内容开始--- 此博主写的很全 http://blog.csdn.net/terence1212/article/details/52270210 使用安装Unity Tweak Tool ...
- Rhel6-torque作业调度系统配置文档
系统环境: rhel6 x86_64 iptables and selinux disabled 主机: 192.168.122.121 server21.example.com 计算节点 192.1 ...
- Jmeter—7 测试中使用到的定时器和逻辑控制器
1 测试中提交数据有延时1min,所以查询数据是否提交成功要设置定时器. 固定定时器页面:单位是毫秒 [dinghanhua] 2 集合点.Synchronizing Timer 集合点编辑:集合用户 ...
- 关于servlet的filter
Servlet过滤器 2009-12-08 23:12:44| 分类: Java|举报|字号 订阅 一.什么是Servlet过滤器 过滤器是在数据交互之间过滤数据的中间组件,独立于任何平台或 ...
- C#中的IntPtr类型
本文转自:http://zhidao.baidu.com/question/22825956.html 问: c#中无法将类型“int”隐式转换为“System.IntPtr” 这个是我引用了一个ap ...
- reverse-daily(1)-audio_visual_receiver_code
本人第一篇随笔,就以一篇CTF逆向分析的文章开始吧! 链接:http://pan.baidu.com/s/1eS6xFIa 密码:u14d 因为re的分析比较琐碎,所以主要就挑一些重点东西来说. 据说 ...
- HDU5127 神坑题---vector 、 list 、 deque 的用法区别
题意:三个操作 1 a b : 队列中加入(x = a, y = b); -1 a b : 队列中减去(x = a, y = b); 0 p q :从队列的数对中查询哪一对x,y能够让 p * ...
- Jquery和Javascript 实际项目中写法基础 (1)
一.JS 是什么,jquery 是什么 就不说明了,直接说一般使用是怎么样的 <!DOCTYPE html> <html> <head> <meta cha ...
- 【转】15个无比华丽的HTML5/CSS3动画应用
原文转自:http://www.html5cn.org/article-7089-1.html 前几天,HTML5标准已经尘埃落定,未来的Web将会是由HTML5主导,当然作为开发者对这一喜讯更为动心 ...