<p>
完成VR中的物体交互动作,包括射线移入和移出物体,单击和双击物体时实现对应的功能。(使用SDK为VR_Sample中的VRStandardAssets.Utils,这里主要用到了:VRIput,VREyeRaycaster,Reticle,VRInteractiveItem这几个类)
</p>
一、实现功能
- 射线移入到交互物体时变色,移出恢复原来颜色;
- 移入物体时,单击物体改变颜色,双击物体改变成另外一种颜色;
二、步骤
首先新建Scene,命名为InterActive,保存在Scenes文件夹内。
1.建立准心,用来显示射线的碰撞位置。
准心为一个UI元素,始终和摄像机保持一定的距离,所以把UI作为摄像机的一个子对象来实现,同时把Canvas的render mode设置为space world,其余组件属性如下图:
data:image/s3,"s3://crabby-images/57d26/57d26baa8bb0a61a84e3fddb9716f24fb4b4a53b" alt=""
另外,UI是不需要进行交互的,所以把下图的组件Graphic Raycaster移除:
data:image/s3,"s3://crabby-images/01ca1/01ca1706cf8b033f1e75f80255cd3854820d70aa" alt=""
完成Canvas后,新建准心的Image,属性设置如下图:
data:image/s3,"s3://crabby-images/4cba7/4cba729c776eabb74435007ed3ec8474ecceb2ef" alt=""
2.Camera的脚本关联
完成准心的设置后,进行Camera的设置,将VRIput,VREyeRaycaster,Reticle三个脚本关联上并设置好相应字段的初值,如下图:
data:image/s3,"s3://crabby-images/213b0/213b0dd9403390eb002789ea88c9ecab23c2de5e" alt=""
data:image/s3,"s3://crabby-images/e1733/e1733dd0d925734166d7f74d4dff76fa92e2a558" alt=""
data:image/s3,"s3://crabby-images/b2165/b21657401a3dec3d9646a1e3e91a88c160356e56" alt=""
3.交互物体设置
- 点击、移入和移出设置
首先先新建Materials对应移入移出,点击时的颜色:
data:image/s3,"s3://crabby-images/77ba5/77ba50616df4b6ca370bf68edbcd68e3d7d03113" alt=""
完成后,通过代码订阅相应的事件,新建InterItem脚本:
[SerializeField]//这个修饰标示可以在检视栏中显示
private VRInteractiveItem m_VRInteractiveItem; //声明注册事件的对象
[SerializeField]
Renderer m_Render; //声明Renderer组件
[SerializeField]
private Material m_Normal; //声明Renderer组件,以便做材质颜色的动态变更
[SerializeField]
private Material m_Click; //单击的Material
[SerializeField]
private Material m_DoubleClick; //双击的Material
[SerializeField]
private Material m_Over; //移入时的Material
//向m_VRInteractiveItem中订阅相应的事件
private void OnEnable()
{
m_VRInteractiveItem.OnOver += Over;
m_VRInteractiveItem.OnOut += Out;
m_VRInteractiveItem.OnClick += Click;
m_VRInteractiveItem.OnDoubleClick += DoubleClick;
}
//移入时,Material的相应改变
void Over()
{
m_Render.material = m_Over;
}
//移出时,Material的相应改变
void Out()
{
m_Render.material = m_Normal;
}
//单击时,Material的相应改变
void Click()
{
m_Render.material = m_Click;
}
//双击时,Material的相应改变
void DoubleClick()
{
m_Render.material = m_DoubleClick;
}
然后把InterItem和VRInteractiveItem脚本添加到Cube上,并做好相应的赋值:
data:image/s3,"s3://crabby-images/d1aff/d1afff5654ccfa4e09d8160645e70ac0f7ee0408" alt=""
运行当准心移入时Cube改变颜色:
data:image/s3,"s3://crabby-images/c1497/c1497e764b24f4d6f491ded58c3b0ba1c7869c2c" alt=""
单击时,改变颜色:
data:image/s3,"s3://crabby-images/b6550/b6550ef90126ba8247df69edc3ea52388f78c234" alt=""
双击时,改变颜色:
data:image/s3,"s3://crabby-images/a80cb/a80cbc3441fb266adc968a8adbdd48920b6d39f4" alt=""
移出时,恢复原来颜色:
data:image/s3,"s3://crabby-images/194ef/194ef44945fef01aa2c635209ae66f6cbad272ed" alt=""
三、注意事项
射线和物体交互中主要用到了SDK中的VRIput,VREyeRaycaster,Reticle,VRInteractiveItem几个脚本,其中使用到了大量的事件订阅功能,下面通过Cube的Over事件和Click事件的触发过程来理解:
- Click事件的触发:
VRIput中声明Click事件:
data:image/s3,"s3://crabby-images/808ee/808eeebed720e36f8c0978e90407887f62c0dea5" alt=""
在VREyeRaycaster对Click事件进行订阅,订阅的方法是执行交互物体中的Click事件,
data:image/s3,"s3://crabby-images/29f93/29f931dc8f310547df44a68e38eafca3175b4390" alt=""
data:image/s3,"s3://crabby-images/6628b/6628bd0511bfcb12037a999db26d93d81f674f51" alt=""
最后,在每个交互物体上可以定义具体的点击方法并且订阅VRInteractiveItem中的Click事件,如该例子中的Click方法:
data:image/s3,"s3://crabby-images/72158/72158549a72ada8908469ef08e6112b1f833ce95" alt=""
data:image/s3,"s3://crabby-images/e28b8/e28b83240b7b011a6f920e76f73d8e8da473090c" alt=""
- Over事件的触发:
当射线打到了一个VRInteractiveItem物体时,就会调用当前可交互物体的Over方法:
data:image/s3,"s3://crabby-images/afd23/afd23626f53d069ac909812187a2339906c7036f" alt=""
也就是调用了VRInteractiveItem中的Over方法
data:image/s3,"s3://crabby-images/d590f/d590fd635837ed3cf13cf77dbb4b2ba2843853e4" alt=""
然后在InterItem脚本中订阅了OnOver事件:
data:image/s3,"s3://crabby-images/70886/70886fad61b851d1ca301520d546d396dec50b79" alt=""
所以,调用的事件为InterItem脚本中的Over方法,Cube改变了颜色:
data:image/s3,"s3://crabby-images/683ac/683ac68b6fa7a80cf90d98b409e1cea7748f61d6" alt=""
网友评论