前言
unity入门小白一个,最近在练习作品中尝试使用双摇杆的操控,来达到以下效果: data:image/s3,"s3://crabby-images/a1b3f/a1b3fad6e28fe9f0e141961404f9b1ebebc8b488" alt="在这里插入图片描述"
一句话内容: easyTouch 自带的 Button 组件会影响虚拟摇杆的事件监听,导致不能实现拖拽后释放技能的效果,所以推荐用UGUI或者FGUI做一个新的 button
EasyTouch5的导入
官网地址:unity商店地址 学习版(v5.0.8)地址:点击前往
现在网络上的版本比较多,最新版本是这个 data:image/s3,"s3://crabby-images/36a3c/36a3cb3c28c902a144b5eec7f7bb02f70314f15b" alt="商店截图" 下载好后可以双击导入摇杆包 data:image/s3,"s3://crabby-images/bd158/bd1589ee7f0f23189f7bd60301998aef6695fed6" alt="红线部分可以不用导入" 红线部分可以不用导入
然后在这边就能看到能使用的组件包了 data:image/s3,"s3://crabby-images/57406/57406d0379765cf052f226505fed9819bd95907d" alt="在这里插入图片描述"
Joystick使用
data:image/s3,"s3://crabby-images/8a8a1/8a8a1fb31148d38587fbbcd8bf6a6804bee3b39e" alt="在这里插入图片描述" 然后在Axes Properties里绑定操作的对象 data:image/s3,"s3://crabby-images/c78dc/c78dc6922d73bdaf2401a4d797b519281a422b4d" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/c1de8/c1de82553ac14c9e5bc6fb2004a474713662c5d2" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/273e4/273e435d660c7a8cc9bff9cce858c0a44bc2c407" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/a9453/a945341288d6f799c4c9975198b7609517e3a965" alt="在这里插入图片描述" 这个就是基本的使用绑定,可以操作的内容和参数非常的多,基本够用。
但我这边人物是用的Uniyt的人物控制器CharacterController 来进行移动的,那么就需要进行绑定关联
private ETCJoystick L_joystick;
void Start()
{
cc = gameObject.GetComponent<CharacterController>();
animator = GetComponent<Animator>();
L_joystick = ETCInput.GetControlJoystick("PlayerMove");
}
这里注意了,ETCInput.GetControlJoystick("PlayerMove") 中的名字是在编辑器这个位置设定的,只能靠名字来确认是哪个摇杆。 data:image/s3,"s3://crabby-images/401f9/401f95183b2e70688afc14b785b352724ed672d9" alt="在这里插入图片描述" 在Awake中写我遇到了报错,估计是没设置好加载顺序的问题。 然后在Update里写控制就好
float lx = L_joystick.axisX.axisValue;
float ly = L_joystick.axisY.axisValue;
Quaternion rota = player.transform.rotation;
if (lx != 0 || ly != 0 && !pitfallMoveBool)
{
moveV3 = new Vector3(lx, 0, ly).normalized;
cc.SimpleMove(moveV3 * speed);
Quaternion finl = Quaternion.LookRotation(new Vector3(lx, 0, ly));
player.transform.rotation = Quaternion.LerpUnclamped(rota, finl, 0.5f);
}
else
{
cc.SimpleMove(Vector3.zero);
}
这里我手动设置了下面向,其实也可以通过绑定摇杆的Rotate Local 来实现
然后是右手的摇杆设置
private ETCJoystick L_joystick;
private ETCJoystick R_joystick;
void Start()
{
R_joystick = ETCInput.GetControlJoystick("Fire&Aim");
R_joystick.onTouchStart.AddListener(R_joystickTouchStar);
R_joystick.onMove.AddListener(R_joystickTouchMove);
R_joystick.onMoveEnd.AddListener(R_joystickTouchEnd);
}
public void R_joystickTouchStar()
{
}
public void R_joystickTouchEnd()
{
}
public void R_joystickTouchMove(Vector2 v2)
{
}
}
然后是技能范围绘制,这部分可以参考:利用Easy Touch实现Moba游戏技能释放(前言)
导入FGUI的Button
导入FGUI设置好的button data:image/s3,"s3://crabby-images/b178c/b178cac5b7bbe6b09e7300d5297703a3cc71fef5" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/a81d2/a81d21dbf33c25de2bc0e49de724b6cb3157a1c4" alt="在这里插入图片描述" 然后获取Button data:image/s3,"s3://crabby-images/d6e8c/d6e8cb1d9c479c0d9ac1ed32dba52009689808cc" alt="在这里插入图片描述"
private CharacterController cc;
public GameObject player;
private ETCJoystick L_joystick;
private ETCJoystick R_joystick;
private bool isCancelAim;
private GButton cancelAim;
void Start()
{
cc = gameObject.GetComponent<CharacterController>();
animator = GetComponent<Animator>();
L_joystick = ETCInput.GetControlJoystick("PlayerMove");
R_joystick = ETCInput.GetControlJoystick("Fire&Aim");
R_joystick.onTouchStart.AddListener(R_joystickTouchStar);
R_joystick.onMove.AddListener(R_joystickTouchMove);
R_joystick.onMoveEnd.AddListener(R_joystickTouchEnd);
cancelAim = GameObject.Find("UIMain").GetComponent<UIPanel>().ui.GetChild("n17").asButton;
cancelAim.visible = false;
}
void Update()
{
cancelAim.onRollOver.Add(CancelAimButtonPress);
cancelAim.onRollOut.Add(CancelAimButtonUp);
}
public void CancelAimButtonPress()
{
isCancelAim = true;
}
public void CancelAimButtonUp()
{
isCancelAim = false;
}
public void R_joystickTouchMove(Vector2 v2)
{
cancelAim.visible = true;
}
public void R_joystickTouchEnd()
{
if (isCancelAim)
{
Debug.Log("取消释放");
}
else
{
}
cancelAim.visible = false;
}
为啥不用自带的button
先新建一个button,并且打开滑动判断 data:image/s3,"s3://crabby-images/9a1cd/9a1cd1b8e90dcb81c9cce70f43969e96c742310f" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/b703f/b703f72c9203568d6aa85b4c016ef48ab87a8cd4" alt="在这里插入图片描述" 当挪入到button时候,摇杆的move会被顶掉,再挪出虽然还是触摸状态,但是摇杆已经归零重置了。
|