一、先看下效果图

二、使用

这个是谷歌官方为移动平台下VR解决方案,有兴趣的可以看看

Google VR主页:https://developers.google.com/vr/
github地址:https://github.com/googlevr/gvr-android-sdk

1. 在 build.gradle 文件中添加库依赖:

dependencies {compile 'com.google.vr:sdk-panowidget:1.80.0'
}

2. 创建布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"tools:context=".activitys.OpenGLActivity"><com.bj.bs.utils.GLPanoramaandroid:id="@+id/mgl"android:layout_width="match_parent"android:layout_height="match_parent"/>
</LinearLayout>

3. AndroidManifest中添加权限

    <uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>

4. Activity中初始化组件

private void initVrPaNormalView() {vr_myshow = (VrPanoramaView) findViewById(R.id.vr_myshow);paNormalOptions = new VrPanoramaView.Options();paNormalOptions.inputType = VrPanoramaView.Options.TYPE_STEREO_OVER_UNDER;
//      vr_myshow.setFullscreenButtonEnabled (false); // 隐藏全屏模式按钮vr_myshow.setInfoButtonEnabled(false); // 设置隐藏最左边信息的按钮vr_myshow.setStereoModeButtonEnabled(false); // 设置隐藏立体模型的按钮vr_myshow.setEventListener(new VrPanoramaEventListener() { // 设置监听@Overridepublic void onLoadSuccess() { // 图片加载成功}@Overridepublic void onLoadError(String errorMessage) { // 图片加载失败}@Overridepublic void onClick() { // 当我们点击了VrPanoramaView 时候触发 super.onClick();}@Overridepublic void onDisplayModeChanged(int newDisplayMode) { // 改变显示模式时候触发(全屏模式和纸板模式)super.onDisplayModeChanged(newDisplayMode);}});// 加载本地的图片源vr_myshow.loadImageFromBitmap(BitmapFactory.decodeResource(getResources(), R.drawable.andes), paNormalOptions);// 设置网络图片源// vr_myshow.loadImageFromByteArray();}

好了,接下来点运行就可以了,是不是很简单呢。接下来大体说一下VR全景的原理。

二、原理简述

**1. VR内容制作 **
 全景拍摄的流程

  • 第一步 摄制团队在实景进行视频或全景拍摄,输出全景视频或全景图。
  • 第二步 设计师进行视频剪辑或全景图拼接,不管是拍摄或者建模,得到的图片是分离的,比如6张照片or 12张照片等,这些照片涵盖了一个场景中的所有内容。后期处理的就是使用全景合成软件,对这些分离的素材进行合成,使之成为一张360度的全景图片。
  • 第三步 设计师制作交互动画及VR里的2d界面输出交互动画png序列,2d界面元素切图。

2. VR播放器的简单原理
  首先我们需要了解全景图是什么东西,全景图是一种广角图。通过全景播放器可以让观看者身临其境地进入到全景图所记录的场景中去,通常标准的全景图是一张2:1的图像,其背后的实质就是等距圆柱投影。等距圆柱投影是一种将球体上的各个点投影到圆柱体的侧面上的一种投影方式,投影完之后再将它展开就是一张2:1的长方形的图像。比较常见的就是应用在地图上的投影。

关于全景图一篇文章介绍 在OpenGL ES中基本上所有的立体图像都是通过一个个的小三角形拼接而成我们知道球面上面的每一个点(P(x,y,z))都会满足方程组(球的极坐标方程): x = r sin(a) cos(b) y = r cos(a) z = r sin(a)*sin(b) 其中 r为球的半径,a为线段 OP与 z轴正方向所夹角,b为 OP在xoy平面的投影 OP‘ 与x的正方向所夹角 tim_shadow大佬的示意图 我们可以根据这个方程组,通过控制∠a和∠b的变化,从上到下,逆时针的取得我们需要用来组合称三角形的点,然后我们需要将全景图片上的点与我们在球上面选取的点一一对应起来(注意:球的坐标是3维坐标,图片的坐标是2维坐标) 球上面的点与图片上面的点一一对应起来。

三、源码

里面还包含了一个webview实现VR全景的demo
http://download.csdn.net/download/u010302765/10164674

谷歌VR展示360度全景图相关推荐

  1. html360度视角观赏,360度全景图是如何生成的?

    360度全景图是如何生成的? 360度全景图以其生动的交互和沉浸的体验,一直深受很多摄影爱好者的喜欢.不过对于普通的观赏者而言,这种可以360度自由观看的图片,还是具有神奇的魅力.今天,我就讲一讲一张 ...

  2. 360度全景图是如何生成的?

    360度全景图以其栩栩如生的互动和强沉浸性的感受,一直备受许多摄影爱好者的喜爱.但是针对一般的观赏者来讲,这类能够360度随意收看的照片,還是具备奇妙的风采.今日,小九也讲一讲一张360度全景图是怎样 ...

  3. 360度全景图可以手动旋转的怎么制作?

    随着这2020年肺炎疫情对各个领域的危害,"云生活"这类新奇的方式愈来愈经常的出現在大家的视野中.因为线下推广全世界针对肺炎疫情的防治,大家迫不得已将许多线下推广所举办的主题活动搬 ...

  4. HTML5 Canvas实现360度全景图

    很多购物网站现在都支持360实物全景图像,可以360度任意选择查看样品,这样 对购买者来说是一个很好的消费体验,网上有很多这样的插件都是基于JQuery实现的 有收费的也有免费的,其实很好用的一个叫3 ...

  5. html360全景图原理,HTML5 Canvas实现360度全景图

    HTML5 Canvas实现360度全景图 发布时间:2020-07-22 12:15:07 来源:51CTO 阅读:557 作者:gloomyfish 很多购物网站现在都支持360实物全景图像,可以 ...

  6. 教学|怎样制作360度全景图,更炫更酷3D建模步骤

    怎样制作360度全景图?现在大多数制作360度全景图都是用PS,很少会三维软件3DsMAX渲染出来,因为三维的需要3DMAX来制作和渲染,会更加的复杂,所以,下面这套<如何在3DsMAX中制作3 ...

  7. 全景效果图html5,利用html5实现的360度全景图浏览(带天地)

    [实例简介]利用html5实现的360度全景图浏览(带天地) [实例截图] [核心代码] var camera, scene, renderer; var texture_placeholder, i ...

  8. unity 使用360度全景图

    1.准备好360度全景图 2.全景图去掉Generate Mip Maps的勾选,防止出现接缝线 3.新建Sphere,并且Sphere和Camera坐标 相同(0,0,0) 4.Camera的Cle ...

  9. 360度全景图显著性检测数据库

    360度全景图显著性检测数据库 找这个可难死我了 一般人用不到,但总有像我一样用的到的 有全景图 显著图 头部运动图 扫描路径 下载地址ftp://ftp.ivc.polytech.univ-nant ...

  10. html5全景代码,HTML5 Canvas实现360度全景图的示例代码

    很多购物网站现在都支持360实物全景图像,可以360度任意选择查看样品,这样对购买者来说是一个很好的消费体验,网上有很多这样的插件都是基于jQuery实现的有收费的也有免费的,其实很好用的一个叫3de ...

最新文章

  1. android自定义线程池工具类,妈妈再也不用担心你不会使用线程池了(ThreadUtils)...
  2. Linux脚本传递参数
  3. 在windows下安装python包管理器pip及使用
  4. OpenSSL漏洞补救办法详解(转)
  5. Java面试170题答案解析(1-20题)
  6. Ansible(六)对目标主机进行磁盘分区,创建逻辑卷、格式化并挂载
  7. 一位共阴数码管0至F数码显示
  8. 告别手敲template,自动生成基础模板(Vue)
  9. Django出现Error: 111 connect to 192.168.158.141:22122. Connection refused
  10. 【地图服务-nginx代理】
  11. OAS正式开放注册,元宇宙链游掘金时代震撼来袭
  12. 八卦与六十卦unicode符号python打印
  13. win10能上网显示未连接到服务器,Win10网络正常但浏览网页无法连接到互联网怎么办?...
  14. [推荐书籍]12本程序员必备书籍
  15. 【解决git报错 10054】OpenSSL SSL_read: Connection was reset, errno 10054
  16. 车载 DCAC 电源模块
  17. 用Python 生成个性二维码
  18. vue3 element plus el-input 无法输入问题
  19. 1.2.密码应用安全性评估基本原理
  20. 学习python的不知道第几天,整理一下所学内容

热门文章

  1. [译] APT分析报告:07.拉撒路(Lazarus)使用的两款恶意软件分析
  2. GPS测量误差来源分析
  3. java球的体积计算
  4. 关于网络捐款 (r5笔记第53天)
  5. 计算机磁盘管理打不开,教你怎样轻松解决磁盘打不开的问题
  6. 区分PV、IV、UV
  7. SpringBoot 之 @Transaction注解的类级别和方法级别的区别
  8. u盘重置后计算机不显示了,u盘在电脑上不显示了如何恢复
  9. php公众号回复接口,微信公众平台开发接口教程之公众账号自定义回复功能
  10. js 实现表格合并单元格