最近看到了一个很新颖的摇杆,就是按下后,会出现在按下的位置,并且拖着走的时候,到一定距离整个摇杆也会跟着走,于是自己测试做了一下这种摇杆

首先,先说一下我的摇杆预设体结构

代码挂在哪里都无所谓,关键是需要知道我写的publice出去的GameObject对应的是哪些,用拖动或者代码查找都可以

到时候代码中会出现这些

public GameObject rockerOnOff;  
public GameObject rockerStick;
public GameObject rockerFather;
public GameObject rockerControlGo;

RockerPosition其实是一张图片,这张图片透明度被我设置成了0,所以看不见,我为了将摇杆激活时候范围控制在这个图片里面

Rocker这个其实才是摇杆,通常状态下将它失活的,但是只要点击在RockerPosition图片范围内,就会被激活,所以rockerOnOff是场景中的Rocker

rockerStick是摇杆移动的那个杆,添加到 public 出来的rockerStick

rockerFather这个public出来的,添加的是场景中的RockerPosition,因为后面有个移动定位需要这个物体

好了,接下来就是代码

using UnityEngine;
using UnityEngine.EventSystems; public class BarGroundMove : MonoBehaviour,IPointerDownHandler, IPointerUpHandler,
IDragHandler
{ public GameObject rockerOnOff; //控制摇杆开关
public GameObject rockerStick; //摇杆的杆
public GameObject rockerFather; //摇杆父对象
public GameObject rockerControlGo; //摇杆需要控制的对象 float radius = ; //摇杆的杆,和摇杆底图的距离 Vector2 dirV2;
Vector3 dirV3; public void OnPointerDown(PointerEventData eventData) //点击事件的函数 IPointerDownHandler接口生成
{
rockerOnOff.SetActive(true); //点击时候,将摇杆激活
Vector2 localPos; //这个Api:public static bool ScreenPointToLocalPointInRectangle(RectTransform rect, Vector2 screenPoint, Camera cam, out Vector2 localPoint);
//rockerFather.transform as RectTransform,rockerFather为父类的本地坐标
//eventData.position这个事件触发的坐标点
//eventData.pressEventCamera这个事件触发时候的相机
//out localPos 这个参数就是相对于 RectTransform rect的Vector2坐标 RectTransformUtility.ScreenPointToLocalPointInRectangle(
rockerFather.transform as RectTransform,
eventData.position,
eventData.pressEventCamera,
out localPos
); rockerOnOff.transform.localPosition = localPos; //激活摇杆的位置,就是相对rockerFather的位置
} public void OnDrag(PointerEventData eventData) //拖拽事件的函数 IDragHandler 接口生成
{
Vector2 localPos; //相对于摇杆的拖拽位置
RectTransformUtility.ScreenPointToLocalPointInRectangle(
rockerOnOff.transform as RectTransform,
eventData.position,
eventData.pressEventCamera,
out localPos
); Vector2 groundPos; //相对于摇杆父类的拖拽位置
RectTransformUtility.ScreenPointToLocalPointInRectangle(
rockerFather.transform as RectTransform,
eventData.position,
eventData.pressEventCamera,
out groundPos
); //得到杆相对摇杆的向量,写全的话是rockerOnOff.transform.localPositio - Vecter2.zero(对于杆,相当于父类摇杆本地坐标是(,))
Vector2 grV2 = rockerOnOff.transform.localPosition; dirV2 = localPos.normalized; //这里是记录拖动得到的单位向量,方便下面移动计算计算 if (localPos.magnitude > radius) //当长度大于半径的时候,则整个摇杆会跟着杆移动
{
rockerOnOff.transform.localPosition = (grV2 - groundPos).normalized * radius + groundPos;
rockerStick.transform.localPosition = localPos.normalized * radius;
}
else
{
rockerStick.transform.localPosition = localPos;
} } public void OnPointerUp(PointerEventData eventData) //松开事件的函数 IPointerUpHandler 接口生成
{
rockerStick.transform.localPosition = Vector3.zero;
dirV2 = Vector2.zero; //这里是抬起时候,将单位向量置0,这样才能使得下面物体也不会根据向量进行移动
rockerOnOff.SetActive(false);
}
void Start()
{ } void Update()
{
dirV3.x = dirV2.x;
dirV3.z = dirV2.y;
dirV3.y = ; rockerControlGo.transform.Translate(new Vector3(, , dirV3.magnitude*Time.deltaTime*.5f)); if (dirV3 != Vector3.zero)
{
rockerControlGo.transform.rotation = Quaternion.Lerp(rockerControlGo.transform.rotation, Quaternion.LookRotation(dirV3),.05f);
} } }

最新文章

  1. 《Note --- Unreal 4 --- B project --- Second UV issue》
  2. Senna.js – 速度极快的单页应用程序引擎
  3. Windows下安装openssl
  4. 一些上流的CSS3图片样式
  5. CSS之浮动那些事
  6. 2014 Super Training #9 E Destroy --树的直径+树形DP
  7. Java课程作业1
  8. Database事件研究
  9. 解构控制反转(IoC)和依赖注入(DI)
  10. spring MVC 整合mongodb
  11. 分享一个牛逼的PHP无限极分类生成树方法,巧用引用(转)
  12. packets
  13. thinkphp实现excel数据的导入导出
  14. [SignalR]异常信息捕获以及处理
  15. CHM文件无法打开的解决方法
  16. 添加网站QQ客服链接
  17. 【转】缓存淘汰算法系列之1——LRU类
  18. curl错误码说明
  19. HandlerThread原理分析
  20. 3;XHTML排列清单控制标记

热门文章

  1. react用脚手架创建一个react单页面项目,react起手式
  2. 【POJ2965】The Pilots Brothers' refrigerator
  3. pdfBox 解析 pdf文件
  4. 【定制开发】经纪人报备软件 全民经纪人系统 房产中介微信小程序分享家恒房通
  5. USB:USB通信中的端点(endpoint)和四种传输模式
  6. CocosCreator之打包android
  7. 同时购入两台同款thinkpad笔记本电脑,分别使用同一账户激活office失败--------------解决方法(账户下有多个Office激活信息,重装后提示“许可证不正确或者最大激活次数”)
  8. 深入学习c++--多线程编程(三)thread的两种死法
  9. Qt开发经验小技巧1-10
  10. IDEA中MyBatis插件的安装及使用