重要类(ButtonMask、Device、Input、Update、DeviceRelation与GetDeviceIndex)
SteamVR_Controller是非Monobehavior的脚本,并没有挂在场景下,其运行是通过SteamVR_Render脚本对于其中Update()函数的调用从而一直循环获取手柄相关信息。而SteamVR_Render脚本是在程序运行时自动加载至场景的。先来看看脚本的全貌吧。
先来看看这几个重要类
data:image/s3,"s3://crabby-images/8f12d/8f12d0e7f9fdbc4ba84fc6709cb95b91df61d43a" alt=""
ButtonMask
data:image/s3,"s3://crabby-images/cc2af/cc2afecbcc1684010675476f46671c39f88fe36c" alt=""
1 - 菜单键
6 - 系统键(按下后手柄断开连接,再次按下手柄再次连接上)
7 - 扳机键
8 - 握持键
9 - 触摸板键
data:image/s3,"s3://crabby-images/92f1e/92f1e1a6af3edbfb8b2ecfca6e2a7caca2090afb" alt=""
Device
首先先看这前面这几个简单函数的解释把
public class Device//最重要的类,封装了跟踪设备的全部名称
{
public Device(uint i) { index = i; }
public uint index { get; private set; }
public bool valid { get; private set; }//GetControllerStateWithPose()函数调用是否成功;
public bool connected { get { Update(); return pose.bDeviceIsConnected; } }//判断设备是否连接
public bool hasTracking { get { Update(); return pose.bPoseIsValid; } }//判断设备是否跟踪正常
//判断设备是否超出范围
public bool outOfRange { get { Update(); return pose.eTrackingResult == ETrackingResult.Running_OutOfRange || pose.eTrackingResult == ETrackingResult.Calibrating_OutOfRange; } }
//判断设备是否正在校正
public bool calibrating { get { Update(); return pose.eTrackingResult == ETrackingResult.Calibrating_InProgress || pose.eTrackingResult == ETrackingResult.Calibrating_OutOfRange; } }
//判断设备是否未初始化
public bool uninitialized { get { Update(); return pose.eTrackingResult == ETrackingResult.Uninitialized; } }
// These values are only accurate for the last controller state change (e.g. trigger release), and by definition, will always lag behind
// the predicted visual poses that drive SteamVR_TrackedObjects since they are sync'd to the input timestamp that caused them to update.
//获取的结果是包含12个元素的一维数组,通过SteamVR_Utils.RigidTransform函数
//将12个元素重组为3X4矩阵并针对Unity的坐标系进行修正,同时添加了对position和rotation方便的引用
public SteamVR_Utils.RigidTransform transform { get { Update(); return new SteamVR_Utils.RigidTransform(pose.mDeviceToAbsoluteTracking); } }
//velocity和angularVelocity :这两个速度也针对Unity的坐标系进行修正,lighthouse跟踪的空间轴方向与Unity存在偏差。
public Vector3 velocity { get { Update(); return new Vector3(pose.vVelocity.v0, pose.vVelocity.v1, -pose.vVelocity.v2); } }
public Vector3 angularVelocity { get { Update(); return new Vector3(-pose.vAngularVelocity.v0, -pose.vAngularVelocity.v1, pose.vAngularVelocity.v2); } }
下面我们再来看看下面这几个按键函数的应用
data:image/s3,"s3://crabby-images/a6b9b/a6b9ba865914f354ac8d3bea18dae6a9a580642f" alt=""
针对按键的三个函数,每种函数有两个重载,参数为ButtonMask或EVRButtonId类,第二种形式会将EVRButtonId转换为ButtonMask后调用第一种得到结果。
针对Touchpad的三个函数,一样的两种形式,同上不解释。
// 按下了扳机按钮调用
if (device.GetTouch(SteamVR_Controller.ButtonMask.Trigger))
{
Debug.Log("GetTouch");
}
//第二种方法
if (device.GetPressDown(Valve.VR.EVRButtonId.k_EButton_SteamVR_Trigger))
{
print("GetPressDown");
}
关于GetAxis
data:image/s3,"s3://crabby-images/ddd86/ddd86dadc40d471f3267e0c7f69c9e47d77023c2" alt=""
关于TriggerHapticPulse
data:image/s3,"s3://crabby-images/2e7ba/2e7ba87eab2c8448aba992ddca31bb1131420d40" alt=""
关于这GetHairTrigger/GetHairTriggerDown/GetHairTriggerUp
data:image/s3,"s3://crabby-images/2dce4/2dce41336972cef55d5ab3978273d9338a58954d" alt=""
检测自定义的一种操作:轻按Trigger ,这三个函数代表的是我们用手指轻轻触碰到触碰板并不需要按下及会产生反应,HairTrigger是检测当你握住扳手超过一个固定值(0.1,可调)时即触发的状态。相当于利用Trigger的变化量来做一个功能的触发,很棒不是吗。轻轻碰一下Trigger使得行程大于0.1即可触发一个功能。
Device中的Update
data:image/s3,"s3://crabby-images/b2c66/b2c665aa707a13586fbd9e579029b3bb97508795" alt=""
网友评论