现在的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. GD库知识点

    GD库:PHP的一个扩展库,主要用于绘制动态图,根据数据动态响应的图片 如统计图 验证码 其他的用途如:处理已有图像 图片的缩放 裁剪 图片水印 文字水印 1.安装GD库 2.画图步骤:创建背景图像( ...

  2. 开涛spring3(6.1) - AOP 之 6.1 AOP基础

    6.1.1  AOP是什么 考虑这样一个问题:需要对系统中的某些业务做日志记录,比如支付系统中的支付业务需要记录支付相关日志,对于支付系统可能相当复杂,比如可能有自己的支付系统,也可能引入第三方支付平 ...

  3. SVN如何迁移到Git?

    最近在使用华为软件开发云进行开发项目管理,目前华为软件开发云支持500M的免费项目空间,而且还可以在线编译和构建,不用担心开发环境和生产环境的不同,很好的体现了DevOps的开发理念. 之前一直是用s ...

  4. Java文件流应用:复制文件

    文件复制步骤 代码: package 文件流应用复制文件; import java.io.File; import java.io.FileInputStream; import java.io.Fi ...

  5. Android应用安全学习笔记前言

    Android是基于Linux kernel的一个自由及开放源代码的操作系统,主要用于移动设备.在2011年第一季度超越了塞班系统跃居了全球第一.本系列作为分享的东西吧.比较基础. 文章也不知道会分为 ...

  6. python之路第一篇

    一.python环境的搭建 1.window下环境的搭建 (1).在 https://www.python.org/downloads/ 下载自己系统所需要的python版本 (2).安装python ...

  7. 美丽的CSS图形和HTML5

    1.HTML5基础 文档类型 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "htt ...

  8. Dom 简介

    HTML DOM 简介 DOM 教程 DOM 节点 HTML DOM 定义了访问和操作 HTML 文档的标准. 您应该具备的基础知识 在您继续学习之前,您需要对以下内容拥有基本的了解: HTML CS ...

  9. JavaScript面向对象轻松入门之封装(demo by ES5、ES6、TypeScript)

    本章默认大家已经看过作者的前一篇文章 <JavaScript面向对象轻松入门之抽象> 为什么要封装? 封装(Encapsulation)就是把对象的内部属性和方法隐藏起来,外部代码访问该对 ...

  10. [转] 面向对象原则之GOF是招式,九大原则才是精髓

    只有到了一定层次后才会真正的深入体会到面向对象的一些知识点啊! 不谈具体程序,谈的是你对软件的理解 模式: 每一个模式描述了一个在我们周围不断重复发生的问题,以及该问题的解决方案的核心. “模式”这个 ...