Unity中Oculus分屏相机和普通相机一键切换

一、OCulus 分屏相机介绍

VR开发工程中,总会觉得OC分屏的处理太慢,严重浪费时间啊! 
但是不使用有不好调试,来回切换相机就成为了一个必须。

近来常用,所以就写了一个小功能来实现它。用tab来实现OC分屏相机和普通相机的切换。 
说明:过于频繁切换,会导致Unity崩溃,所以限制了2秒的最短切换频率。

二、具体怎么实现呢?

首先, 
新建一个工程吧。我使用的Unity版本为5.1.1f,64位版本。当然32位也是可以的。 
然后, 
导入了2013插件,导入了OC的0.4.4版本,使用顺手了。要是使用Unity5.3版本,并且不需要对OC相机进行控制处理的,只需所要缩放renderScale等功能的,5.3版本已经集成了,更多请参考 蛮牛的Untiy5.3 翻译

网址:http://www.manew.com/thread-45174-1-1.html?_dsign=ad0f20e3

最后, 
都导入以后,如下图: 

三、相机

创建了一个相机的预制体,包括一个正常的相机,一个是OC的分屏相机。名字为Player。 
如下图:

四、代码:

代码很简单,就是切换显示而已: 
如下:

using UnityEngine;
using System.Collections; namespace SLQJ_VR
{
public class ShiftCamera : MonoBehaviour
{
[Header("相机类型")]
public CameraType cameraType;
[Header("旋转速度")]
public float Speed = 100;
public KeyCode ShiftKey = KeyCode.Tab; private float shiftStartTime;
private float shiftDelayTime = 2.0f; private Transform XRotateObject;
private Transform YRotateObject;
private string nomalCamera = "NormalCamera";
private string stereoCamera = "OVRCameraRig";
private GameObject mCurrentCamera = null; void Awake()
{
shiftStartTime = Time.time;
XRotateObject = this.transform;
CameraChoose();
} public GameObject GetCurrentCamera()
{
CameraChoose();
return mCurrentCamera;
} // Update is called once per frame
void Update()
{
CameraYaw();
CameraPitch();
//
ShiftCameraUseKey();
ShowLookDirect();
}
/// <summary>
/// 键盘控制相机的旋转。
/// </summary>
private void CameraPitch()
{
if(null != YRotateObject)// Vertical
{
YRotateObject.Rotate(new Vector3(Speed * Time.deltaTime * Input.GetAxis("Vertical"), 0, 0));
}
} private void CameraYaw()
{
if (null != XRotateObject)//Horizontal
{
XRotateObject.Rotate(new Vector3(0, Speed * Time.deltaTime * Input.GetAxis("Horizontal"), 0));
}
}
/// <summary>
/// 使用tab键,来切换相机
/// </summary>
private void ShiftCameraUseKey()
{
if (Input.GetKey(ShiftKey) && Time.time - shiftStartTime >= shiftDelayTime)
{
shiftStartTime = Time.time;
cameraType++;
cameraType = (CameraType)((int)cameraType % (int)CameraType.Size);
CameraChoose();
}
} /// <summary>
/// 在编辑器模式下,显示条方向线
/// </summary>
private void ShowLookDirect()
{ #if !UNITY_ANDROID || UNITY_EDITOR
if (Input.GetKey(KeyCode.Escape))
{
Application.Quit();
}
Vector3 StartPt = mCurrentCamera.transform.position;
Vector3 TmpDirector = mCurrentCamera.transform.forward;
Debug.DrawRay(StartPt, TmpDirector * 1000);
#endif
}
/// <summary>
/// 相机选择
/// </summary>
void CameraChoose()
{
if (CameraType.Normal == cameraType)
{
YRotateObject = transform.FindChild(nomalCamera);
mCurrentCamera = YRotateObject.gameObject;
mCurrentCamera.SetActive(true);
transform.FindChild(stereoCamera).gameObject.SetActive(false);
}
else
{
YRotateObject = transform.FindChild(stereoCamera);
mCurrentCamera = YRotateObject.gameObject;
mCurrentCamera.SetActive(true);
transform.FindChild(nomalCamera).gameObject.SetActive(false);
}
}
} public enum CameraType
{
/// <summary>
/// 正常相机
/// </summary>
Normal = 0,
/// /// <summary>
/// OC相机
/// </summary>
Stereo = 1,
/// <summary>
/// 总类型个数
/// </summary>
Size = Stereo + 1
}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131

代码基本都带了注释,不多说了。 
不过,要说的一点,就是代码中,把相机对象的旋转,X方向和Y方向的旋转也就是Pitch和Yaw给分开了,很明显这好处大大的。

五、结论

按下tab 键,不要着急,因为从正常相机切换到双屏渲染,要稍微费些时间。 
当然,切换到正常模式相机还是很迅速的。这个切换时间问题,只能这样。

Unity中Oculus分屏相机和普通相机一键切换的更多相关文章

  1. vim中的分屏操作

    title: vim中的分屏操作 date: 2017-11-14 21:45:11 tags: vim categories: 开发工具 在命令行中: vim -On file1 file2 # O ...

  2. 关于Unity中GrabPass截屏的使用和Shader的组织优化

    GrabPass截屏 可以用来截屏,截屏后把纹理传给下一个通道使用. 1:使用抓屏通道, GrabPass {} 或 GrabPass { “ 纹理名称”}; 使用GrabPass {}后,可以用_G ...

  3. Unity中调用Windows窗口句柄以及根据需求设置并且解决扩展屏窗体显示错乱/位置错误的Bug

    问题背景: 现在在搞PC端应用开发,我们开发中需要调用系统的窗口以及需要最大化最小化,缩放窗口拖拽窗口,以及设置窗口位置,去边框等功能 解决根据: 使用user32.dll解决 具体功能: Unity ...

  4. Android系统的三种分屏显示模式

    Google在Android 7.0中引入了一个新特性——多窗口支持,允许用户一次在屏幕上打开两个应用.在手持设备上,两个应用可以在"分屏"模式中左右并排或上下并排显示.在电视设备 ...

  5. 关于vi 分屏的一些指令

    分屏都是以ctrl + W(大写) 首先,ctrl+ W  , v    为切屏 之后用 :e 打开其他文件 ctrl + W , c 为关闭当前分屏 ctrl + W , h 为切换到左侧分屏   ...

  6. Unity 相机花式分屏

    花式分屏,顾名思义,可以实现各种不规则几何边界的分屏,是无法直接通过调整相机视口能达到效果的(只能实现矩形的分屏),例如斜对角分屏,几何图形分屏: 假设我们有两个相机,需要上面的斜对角分屏画面,和镜子 ...

  7. Unity 多屏(分屏)显示,Muti_Display

    Unity 多屏(分屏)显示,Muti_Display  最近项目有个需求,主要用于在展厅的展示游戏. 比如,在一个很大的展厅,很大的显示屏挂在墙上,我们不可能通过操作墙上那块显示器上的按钮来控制游戏 ...

  8. 我在tmux中最不可少的配置: 用鼠标切换窗口/调节分屏大小

    前两天在给另外一个团队帮忙时,看他们在Rails日志.代码文件.git文件系统里面来回穿梭,觉得他们太累了,于是就介绍了 tmux 给他们用.但只讲了一点基本的开窗口.分屏,没给讲太多技巧,因为一下子 ...

  9. 介绍Unity中相机的投影矩阵与剪切图像、投影概念

    这篇作为上一篇的补充介绍,主要讲Unity里面的投影矩阵的问题: 上篇的链接写给VR手游开发小白的教程:(三)UnityVR插件CardboardSDKForUnity解析(二) 关于Unity中的C ...

随机推荐

  1. C#中关于系统用户信息持久化(接上文)

    首先传几张效果图描述一下功能: 经过上文用户名和密码的验证后,就到了添加用户这一步,登陆后的用户可以添加新的用户,被添加的用户可以登陆系统. 这里会用到C#中的“正则表达式”对用户名格式进行判断,以及 ...

  2. python基础系列教程——Python的安装与测试:python的IDE工具PyDev和pycharm,anaconda

    ---恢复内容开始--- python基础系列教程——Python的安装与测试:python的IDE工具PyDev和pycharm,anaconda 从头开启python的开发环境搭建.安装比较简单, ...

  3. git学习(四):理解git暂存区(stage)

    与一般的版本管理不同的是,git在提交之前要将更改通过git add 添加到暂存区才能提交(git commit).即使是已经交给了git来管理的文件也是如此.这里继续学习git的暂存区. 通过git ...

  4. size_t ssize_t socklen_t

    size_t 解释一:为了增强程序的可移植性,便有了size_t,它是为了方便系统之间的移植而定义的,不同的系统上,定义size_t可能不一样. 在32位系统上 定义为 unsigned int 也就 ...

  5. 科普Spark,Spark核心是什么,如何使用Spark(1)

    科普Spark,Spark是什么,如何使用Spark(1)转自:http://www.aboutyun.com/thread-6849-1-1.html 阅读本文章可以带着下面问题:1.Spark基于 ...

  6. 弄明白html、css3、js这个问题。。。

  7. selenium测试(Java)--执行JS(十八)

    1.  操作滚动条 package com.test.js; import org.openqa.selenium.By; import org.openqa.selenium.Dimension; ...

  8. 第三百一十七节,Django框架,缓存

    第三百一十七节,Django框架,缓存 由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用:缓存,缓存将一个某个views的返 ...

  9. CString常用函数

    转自:http://www.cnblogs.com/Caiqinghua/archive/2009/02/16/1391190.html CString( );例:CString csStr; CSt ...

  10. 下列没有直接采用XML技术的是( )

    A. UDDI B. SOAP C. AJAX D.DCOM 解答:D DCOM(分布式组件对象模型,分布式组件对象模式)是一系列微软的概念和程序接口,利用这个接口,客户端程序对象能够请求来自网络中另 ...