虚拟成像原理
data:image/s3,"s3://crabby-images/15b0f/15b0f03b62ba34826c03de3da1a06a1aca9af353" alt=""
1、首先SDK里面有什么
data:image/s3,"s3://crabby-images/addad/addada966fc38eea52600cbc3bd3b5514e07130e" alt=""
data:image/s3,"s3://crabby-images/62550/62550d8cc3eb5687d2ce6cf35266c9800b3c8a49" alt=""
Cardboard脚本解析
1-Cardboard.cs
这是提供访问底层方法的类.
data:image/s3,"s3://crabby-images/03090/03090e779d0c4130b53e0b227847a3114c6e433a" alt=""
data:image/s3,"s3://crabby-images/225b0/225b039493673f4a301d38af3a79a30ad506aa1e" alt=""
data:image/s3,"s3://crabby-images/a2442/a24429ec0daaa208516056a71f8beaa0c00b22d3" alt=""
data:image/s3,"s3://crabby-images/77b46/77b46db31768b310b35ae637fd7b3369ca246634" alt=""
data:image/s3,"s3://crabby-images/39579/39579683e010894569b64b3c1c11ce05d87e6e9b" alt=""
data:image/s3,"s3://crabby-images/52e80/52e80f5f16267621bf18396528fea103391782af" alt=""
2-CardboardEye.cs
using UnityEngine;
/// in order to reset its cache.
[RequireComponent(typeof(Camera))]
[AddComponentMenu("Cardboard/CardboardEye")]
public class CardboardEye : MonoBehaviour {
/// Whether this is the left eye or the right eye.
/// Determines which stereo eye to render, that is, which `EyeOffset` and
/// `Projection` matrix to use and which half of the screen to render to.
/// 确定要渲染的立体眼睛,就是用EyeOffset和projecttion 矩阵并且去渲染到屏幕的哪一半
public Cardboard.Eye eye;
/// Allows you to flip on or off specific culling mask layers for just this
/// eye. The mask is a toggle: The eye's culling mask is first copied from
/// the parent mono camera, and then the layers specified here are flipped.
/// Each eye has its own toggle mask.
/// 允许你为这个眼睛打开或关闭特定的剔除层.是一个触发器,这个层首先从父相机复制,然后在此制定那些层被启用,每只眼睛有它自己的剔除层
[Tooltip("Culling mask layers that this eye should toggle relative to the parent camera.")]
public LayerMask toggleCullingMask = 0;
/// The StereoController in charge of this eye (and whose mono camera
/// we will copy settings from).
/// 返回StereoController 控制这个眼睛
public StereoController Controller {
// This property is set up to work both in editor and in player.
get {
if (transform.parent == null) { // Should not happen.
return null;
}
if ((Application.isEditor && !Application.isPlaying) || controller == null) {
// Go find our controller.
return transform.parent.GetComponentInParent<StereoController>();
}
return controller;
}
}
/// Returns the closest ancestor CardboardHead.
/// @note Uses GetComponentInParent(), so the result will be null if no active ancestor is found.
/// 返回父类CardboardHead
public CardboardHead Head {
get {
return GetComponentInParent<CardboardHead>();
}
}
3-CardboardHead.cs
将此脚本附加到任何与用户头部运动相匹配的游戏对象上。也就是说Head模拟了现实中用户的头,Head下的部分都是头的一部分.
里面有:
Main Camera与GazePointer
Main Camera就是我们的视野,左右眼睛.
GazePointer其实就是视野注视点的实体,将这个注视点作为头部的一部分,跟随头部旋转.
data:image/s3,"s3://crabby-images/9e122/9e1229a2adadc582da550e177b2135e3793ce389" alt=""
data:image/s3,"s3://crabby-images/509ac/509ac30f8b16ec3e33b79a866fa9002765c8e57d" alt=""
4-GazeInputModule.cs
提供了一个Unity的BaseInputModule类的实现,使得UGUI可以通过触发与触摸的方式来选择和使用
data:image/s3,"s3://crabby-images/e46e3/e46e360966b815ebd4b4632254d7ec668fa2154a" alt=""
Cardboard 的UI 系统是基于UGUI制作的.
我们在上一篇项目http://www.jianshu.com/p/3696bc837551
里面应该已经看到,我们修改并将GazeInputModule.cs脚本添加到EventSystem中
GazeInputModule:
这个脚本控制人眼视角发射的射线并触发相应的事件。
public override void Process() {
// Save the previous Game Object
GameObject gazeObjectPrevious = GetCurrentGameObject();
CastRayFromGaze(); // 控制射线发射,先将3D坐标转换为2D UI坐标系,发出射线
UpdateCurrentObject(); // 更新选中物体的状态,比如按钮会设置选中状态等
UpdateReticle(gazeObjectPrevious); //
// Get the camera
Camera camera = pointerData.enterEventCamera;
// Handle input
if (!Cardboard.SDK.TapIsTrigger && !Input.GetMouseButtonDown(0) && Input.GetMouseButton(0)) {
// Drag is only supported if TapIsTrigger is false.
HandleDrag(); // 拖动状态
} else if (Time.unscaledTime - pointerData.clickTime < clickTime) {
// Delay new events until clickTime has passed.
} else if (!pointerData.eligibleForClick &&
(Cardboard.SDK.Triggered || !Cardboard.SDK.TapIsTrigger && Input.GetMouseButtonDown(0))) {
HandleTrigger(); //触发事件
if (cardboardPointer != null) {
cardboardPointer.OnGazeTriggerStart(camera);
}
} else if (!Cardboard.SDK.Triggered && !Input.GetMouseButton(0)) {
HandlePendingClick(); // 就是光标选中,啥也没干
}
}
5-StereoController.cs
data:image/s3,"s3://crabby-images/6e401/6e4016a788efa385d2ec9c57b8b47b06e1e791cf" alt=""
data:image/s3,"s3://crabby-images/efd36/efd3696099ca89ef095d5b3788ea1880cecf7140" alt=""
data:image/s3,"s3://crabby-images/5ffed/5ffedc692b7ce484ddeff26da55d71d24fab493c" alt=""
data:image/s3,"s3://crabby-images/640d6/640d6b21e95a9068583376ec8e05423a4694a517" alt=""
data:image/s3,"s3://crabby-images/f6923/f69237ccfc2f2b94e5d895f8caf40707352b0fad" alt=""
data:image/s3,"s3://crabby-images/2dd8b/2dd8bdd67c68e1d876ec242ed35d454a4d2005a3" alt=""
网友评论