Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bian-sh/unijoystick
It is a powerful joystick and touchpad component for UGUI.
https://github.com/bian-sh/unijoystick
canvas joystick touchpad ugui unity
Last synced: 4 days ago
JSON representation
It is a powerful joystick and touchpad component for UGUI.
- Host: GitHub
- URL: https://github.com/bian-sh/unijoystick
- Owner: Bian-Sh
- License: mit
- Created: 2019-07-07T19:54:08.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2024-11-21T08:09:28.000Z (2 months ago)
- Last Synced: 2025-01-12T13:04:04.848Z (11 days ago)
- Topics: canvas, joystick, touchpad, ugui, unity
- Language: C#
- Homepage:
- Size: 34.8 MB
- Stars: 329
- Watchers: 8
- Forks: 78
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# UniJoystick
这是一个代码极简但功能相对完善的基于UGUI的摇杆(Joystick)组件。
![](./doc/joystick.png)
# Summary
1. 支持设置摇杆半径范围
2. 支持指示器
3. 支持配置哪一个轴向使能。
4. 支持一键将摇杆设置为动态底座摇杆或者静态底座摇杆
5. 事件驱动,使用UnityEvent 使得事件可以在面板上挂载
6. 本仓库配备了4个摇杆控制解决方案(Demo,仅供参考):
* 第一人称 Charactor 控制
* 第一人称 character 控制,带TouchPad版本
* 第三人称 Charactor 控制
* 常规Transform.Translate控制
7. 适配 Canvas 的 三种 RenderMode。
8. 鼠标和Touch拖拽前需要检测是否打到 UI 组件,这里有[正确姿势](https://github.com/Bian-Sh/UniJoystick/blob/master/Packages/Joystick/Runtime/InputExtension.cs)# 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`
> 1. Requires a version of unity that supports path query parameter for git packages (Unity >= 2019.3.4f1, Unity >= 2020.1a21).
>
> 2. There is a high chance of failure for users in China.
>
> 3. Package development needs to be done in the Package folder,perhaps for avoid GUID conflicts。# How to use?
![](./doc/addjoystick.gif)
1. Hierarchy 右键选择 “UI/Joystick” 生成摇杆(按需更换 UI 素材)。
2. 在关注摇杆数据的地方获取摇杆实例并注册 OnValueChanged 事件
3. 点击运行即可。> 示例代码
```csharp
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
![](./doc/CanvasRenderMode.gif)
> 指向器挂载即可使用,不想用销毁即可(有些同学反映指向器用不到,所以剥离并作为可选挂件提供给大家)。
![](./doc/DirectionArrow.gif)
> 第一人称解决方案示例
![](./doc/FirstPersonSolution.gif)
> 第三人称解决方案示例
![](./doc/ThirdPersonSolution.gif)
> 第一人称解决方案示例 (TouchPad版)
![](./doc/FirstPersonSolution-touchpad.gif)
视频中演示了如下内容:
1. 摇杆驱动人物移动
2. TouchPad 旋转视角
3. TouchPad 的灵敏度调节
4. TouchPad UI 检测,UI上开始的拖拽不触发旋转 ,UI的点击操作不会误触视野旋转功能
5. TouchPad 测试了响应多个手指的体验,还算正常# 友情提醒
如果使用不同的unity导致了控制台各种报错,删除 package.json 即可,路径如下:
![](https://user-images.githubusercontent.com/24520547/182322764-9e83d37e-e19f-4e3b-a404-e9a29c57f2ed.png)
# 结语
因为使用 IpointerXXXHandler 这套事件接口,淡化了 Touch 和 Input API ,所以:
1. 这个摇杆理论上是支持各种各样的多点触控设备的
2. 支持同屏多个摇杆实例且互不干扰。
3. 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
[[Unity 3d] 使用UGUI做一个类似王者荣耀的摇杆 - 简书]( https://www.jianshu.com/p/2b2cdccafef4)