现在的VR似乎没有之前那么火热了,于是乎我居然开始了VR征程。。。

  说起VR,对于没有接受过相关知识的人来说可能看起来比较高大上,但是VR的原理却没有想象中那么复杂。总的来说,VR之所以能够产生立体感,是因为人有两只眼睛。其实现在有很多自称VR的视频或者图片严格来讲并不能算是VR,因为它只是将一平面图变成了360°的图,其实和平面图是一样的,并没有深度信息,只是你可以转转小脑袋来全方位观察而已。如下图:

  可以看到图片是扭曲的,至于为什么人眼在VR眼镜中看到的图像是正常的,是因为这张图片并不是直接看的,它需要把整个图像投影到一个球体的内表面(可以想象一下把地球仪展开成一个平面图并且补充裂开的部分),然后摄像头位于球体内部的中心,这时候从VR眼镜中看到的就只是这个球的一小部分,当然,可以转动你的小脑袋来全方位观察,当转动的时候通过陀螺仪的读书来计算相机的转动角度。这种VR的原理大概就是如此了,是不是觉得很简单!

  真正有深度信息的VR图片/视频其实是有两部分的,其中比较多的是左右屏和上下屏,这时候就不能把它直接投影到一个球上了,而是投影到两个球上,并且需要有两个摄像机分别来提供左眼和右眼的图像,此时左眼和右眼看到的图像并不是完全一致的,有一定的错位,就跟我们睁开眼看这个世界一样,所以此时看到的图像就是立体的,有深度信息的。如下图:

(图像比较渣,将就看)

上图中上下看起来是差不多的,但是实际上是有差别的,投影的时候会把上半部分投影到左眼,把下半部分投影到右眼,具体如何实现会在后面讲。除了上下分屏其实还有左右分屏的,原理都差不多了。

  原理讲得差不多了下面讲开发:

  首先你要准备开发环境:Unity#D5.6(最新),安卓SDK(5.1以上),JDK,Visualstudio 2017(可选),Andoridstudio(可选)。Unity插件:EasyMovieTexture3.59(商用就买,个人爱好可以去搜搜其他人的分享)。

  首先来看普通的全景图(没有分屏的),这里强行假设你已经搭建好了所有的环境,打开Unity3D,新建一个3D Project,这时候你将得到一个miancamera和一个平行光,将平行光删掉(喜欢也可以留着)。新建一个球体,然后导入一张全景图,将图片拖到刚刚创建的球体上,可以看到现在的球体已经被你的图片包围了,然后将球的Scale属性xyz分别设置为5,5,-5(其它等比例也行,但是要保证比相机要大). 至于为什么z轴是-5,等会讲到。将相机和该球的位置都设为0,0,0. 这时点击相机,你将会在预览窗口什么都看不到,因为你的图片是贴在了外表面。需要想办法把图片贴到内表面去,感谢王文刚老铁提供的Sharder。

Shader "Unlit/DoubleSided"
{
Properties
{
_Color("Main Color", Color) = (,,,)
_MainTex("Texture", 2D) = "white" {}
}
SubShader
{
//Ambient pass
Pass
{
Name "BASE"
Tags {"LightMode" = "Always" /* Upgrade NOTE: changed from PixelOrNone to Always */}
Color[_PPLAmbient]
SetTexture[_BumpMap]
{
constantColor(.,.,.)
combine constant lerp(texture) previous
}
SetTexture[_MainTex]
{
constantColor[_Color]
Combine texture * previous DOUBLE, texture *constant
}
}
//Vertex lights
Pass{
Name "BASE"
Tags {"LightMode" = "Vertex"}
Material
{
Diffuse[_Color]
Emission[_PPLAmbient]
Shininess[_Shininess]
Specular[_SpecColor]
}
SeparateSpecular On
Lighting On
cull off
SetTexture[_BumpMap]
{
constantColor(.,.,.)
combine constant lerp(texture) previous
}
SetTexture[_MainTex]
{
Combine texture *previous DOUBLE, texture *primary
}
}
}
FallBack "Diffuse",
}

这个Shader的意思其实就是让球两边都贴上纹理。这时候再点击摄像机你就能看到图像了,但是你可能会发现这图像是反的(你可能也会发现不了,但是它确实是反的),所以我们要将球的Scale.z值设基本为负数。到这里基本就完成了,接下来就是打包发布了,点击file-build and setting 选择安卓,点击player setting,在other setting里将VR surport选上,选择一个sdk(建议Google cardboard),然后build就可以了。不出意外的话生成了一个apk文件,安装到你的大手机上就可以看到效果了。这时你会发现和想象中不太一样,顶部和底部的形变比较严重,产生这样的原因是因为Unity自带的球体模型比较粗糙,这时候你可以在3dsmax中自己建一个球,把分段设大一点,建好后还可以将球的法线翻转下,翻转后就可以不用那个DoubleShader了。

  好了,一个简单而不简约的VR图片观察器就完成了,欲知后事如何,且听下回BB!

UNITY VR 视频/图片 开发心得(一)的更多相关文章

  1. UNITY VR 视频/图片 开发心得(二)

    上回说到了普通的全景图片,这回讲真正的VR. 由于这种图片分为两部分,所以我们需要两个Camera对象以及两个球体.首先新建一个Camera对象,并将其命名为RightEye(其它名字也无妨,只要你自 ...

  2. NutUI 视频组件开发心得

    引子 说到在项目中引入一个视频,我们肯定会想到 HTML5 为我们提供的 Video 标签,它为我们提供了许多属性和方法,使用起来很方便,当然直接使用也会遇到各种兼容问题,在最初学习 Video 标签 ...

  3. 优分享VR开源啦,优分享VR是基于Google VR开发的一款手机VR视频资源的聚合软件

    欢迎来到优分享VR开源项目 优分享VR 开源中国Git地址: http://git.oschina.net/xumingwang/youkes_vr 优分享VR是 优分享安卓APP VR视频播放开源部 ...

  4. 《转》iOS音频视频初级开发

    代码改变世界 Posts - 73, Articles - 0, Comments - 1539 Cnblogs Dashboard Logout HOME CONTACT GALLERY RSS   ...

  5. NodeJS版本EasyDarwin开源流媒体服务器开发心得

    title: Node版本EasyDarwin开发心得 date: 2018-03-27 22:46:15 tags: 年后着手Node版本EasyDarwin的开发工作,截止到今天2018年03月2 ...

  6. VR视频原理

    VR视频,这里指的是沉浸式全景视频,基本场景是观影者戴上显示头盔(如cardboard),在其中通过头部的转动可以看到全景视频的每个方向的图像.同时也能听到来自各个方向的声音,声音也会随着头部的转动而 ...

  7. 【Java SE】使用Javacv截取视频图片

    [Java Web开发学习]使用Javacv截取视频图片 转载:https://www.cnblogs.com/yangchongxing/p/9482935.html github地址:https: ...

  8. 使用图片视频展示插件blueimp Gallery改造网站的视频图片展示

    在很多情况下,我们网站可能会展示我们的产品图片.以及教程视频等内容,结合一个比较好的图片.视频展示插件,能够使得我们的站点更加方便使用,也更加酷炫,在Github上有很多相关的处理插件可以找来使用,有 ...

  9. Jaunt登陆索尼PSVR,为其提供大量VR视频

    索尼PS VR自从推出就广受用户青睐,当然不仅仅是其低于高端VR头显的价格,还在于PS VR提供的丰富游戏内容.近日,国外视频网站Jaunt还专门为PSVR推出了专版APP,为其提供超过 150 个沉 ...

随机推荐

  1. C语言实验单片机串口发送int型数据

    void SendIint(int n)reentrant { unsigned char s; while(n!=0) { s=(unsigned char)n%10+48; SendByte(s) ...

  2. event对应的各种坐标

    IE8不支持的PageXY   相对于整个页面鼠标的位置 包括溢出的部分 event.pageX; event.pageY; 所有浏览器支持的: 相对于当前浏览器窗口可视区域的坐标event.clie ...

  3. 在JLabel上显示图片,并且图片自适应JLabel的大小

    本文转载地址:       http://blog.csdn.net/xiaoliangmeiny/article/details/7060250 在写<Core Java>上的示例代码时 ...

  4. 前端魔法堂:屏蔽Backspace导致页面回退

    前言  前几天用户反映在录入资料时一不小心错按Backspace键,就会直接回退到是一个页面,导致之前辛辛苦苦录入的资料全部丢失了.哦?居然还有这种情况.下面我们来一起探讨一下吧! Windows系统 ...

  5. NodeJS 入门第二天(EJS模板)

    一.复习 复习:Node.js开发服务器,数据.路由.本地关心的效果,交互: Node.js实际上是极客开发出的一个小玩具,不是银弹.有着别人不具备的怪异特点: 单线程.Non-blocking I/ ...

  6. SimpleDateFormat使用和线程安全问题

    SimpleDateFormat 是一个以国别敏感的方式格式化和分析数据的具体类. 它允许格式化 (date -> text).语法分析 (text -> date)和标准化. Simpl ...

  7. 测试class

    各种断言方法: assertEqual(a,b) a == b assertNotEqual(a,b) a != b assertTrue(x) x == True assertFalse(x) x ...

  8. DOM详解

    浏览器工作的基本流程 1.浏览器开始解析html文档,构建DOM树(DOM tree),DOM树的节点由文档的标签.属性.文本等组成:2.解析外部CSS文件及style标签中的样式信息,这些样式信息将 ...

  9. C#中的委托(一)

    一.委托 把方法作为参数传给其他方法: 二.声明委托 在C#中使用一个类时,分两个阶段.首先,需要去定义一个类,然后实例化类的一个对象(只需要静态方法除外). 使用委托也需要经过这2个步骤,首先必须定 ...

  10. Python教程(2.1)——控制台输入

    这一节,我们来学习如何写一个简单的Python程序. 我们知道,很多编程语言一开始就是学习怎么输出"Hello, world",对吧?那么,现在我们来学习怎么用Python输出&q ...