UniJoystick
这是一个代码极简但功能相对完善的基于UGUI的摇杆(Joystick)组件。
Summary
- 支持设置摇杆半径范围
- 支持指示器
- 支持配置哪一个轴向使能。
- 支持一键将摇杆设置为动态底座摇杆或者静态底座摇杆
- 事件驱动,使用UnityEvent 使得事件可以在面板上挂载
- 本仓库配备了4个摇杆控制解决方案(Demo,仅供参考):
- 第一人称 Charactor 控制
- 第一人称 character 控制,带TouchPad版本
- 第三人称 Charactor 控制
- 常规Transform.Translate控制
- 适配 Canvas 的 三种 RenderMode。
- 鼠标和Touch拖拽前需要检测是否打到 UI 组件,这里有正确姿势
Installation
Install via git URL
You can add https://github.com/Bian-Sh/UniJoystick.git?path=Packages/Joystick
to Package Manager
If you want to set a target version, uses the tag so you can specify a version like #2.1.0. For example https://github.com/Bian-Sh/UniJoystick.git?path=Packages/Joystick#1.0.0
Requires a version of unity that supports path query parameter for git packages (Unity >= 2019.3.4f1, Unity >= 2020.1a21).
There is a high chance of failure for users in China.
Package development needs to be done in the Package folder,perhaps for avoid GUID conflicts。
How to use?
- Hierarchy 右键选择 “UI/Joystick” 生成摇杆(按需更换 UI 素材)。
- 在关注摇杆数据的地方获取摇杆实例并注册 OnValueChanged 事件
- 点击运行即可。
示例代码
public float speed = 5;
[SerializeField] Joystick joystick;
void Start()
{
joystick.OnValueChanged.AddListener(v =>
{
if (v.magnitude != 0)
{
transform.Translate(v.x * speed, 0, v.y * speed, Space.World);
transform.rotation = Quaternion.LookRotation(new Vector3(v.x, 0, v.y));
}
});
}
功能演示
无论静态 or 动态摇杆,都支持 Canvas 的所有 RenderMode
指向器挂载即可使用,不想用销毁即可(有些同学反映指向器用不到,所以剥离并作为可选挂件提供给大家)。
第一人称解决方案示例
第三人称解决方案示例
第一人称解决方案示例 (TouchPad版)
视频中演示了如下内容:
- 摇杆驱动人物移动
- TouchPad 旋转视角
- TouchPad 的灵敏度调节
- TouchPad UI 检测,UI上开始的拖拽不触发旋转 ,UI的点击操作不会误触视野旋转功能
- TouchPad 测试了响应多个手指的体验,还算正常
友情提醒
如果使用不同的unity导致了控制台各种报错,删除 package.json 即可,路径如下:
结语
因为使用 IpointerXXXHandler 这套事件接口,淡化了 Touch 和 Input API ,所以:
- 这个摇杆理论上是支持各种各样的多点触控设备的
- 支持同屏多个摇杆实例且互不干扰。
- Joystick 支持 Action Input System (示例代码和 touchpad 未做适配) joystick support action input system except example as well as touchpad does not adapt action input system.
ps :在 Microsoft's Surface Pro 、小米Pad 9 测试OK。
My Blog