3D全景!这么牛!!

导读 如果你用过网页版的百度地图,你大概3D全景图浏览是一种怎样的酷炫体验:在一个点可以360度环顾周围的建筑、景色,当然也可以四周移动,就像身临其境。

全景图共分为三种:

①球面全景图

利用一张全景图围成一个球,自身位置位于球体内。由于图片是矩形,所以最上和最下的缝合处很明显就能够看得出来。

球面全景图是最接近人眼的构建模式,若利用多个立面构建,拼接方法繁琐,性能消耗高。

因此,本文介绍的是上述通过一张全景图构成的球面全景图。

②立方体全景图

一个立方体,有六个面组成,所以就需要六张图片啦。自身的位置位于立方体中间。这也是最常见的全景图构建模式。

③柱状全景图

这个则是前两种构建模式的结合版啦。

准备

在浏览器中实现3D全景浏览开发,首先需要几样东西:

①支持WebGL和canvas的浏览器

比如说Google Chrome 9+和Mozilla Firefox 4+等。

②Three.js

这里就不介绍这个插件了,所以阅读本文需要Three.js简单的基础 O(∩_∩)O~
下载地址:https://github.com/mrdoob/three.js

③photo-sphere-viewer.js

这是基于Three.js开发的柱状全景图插件

下载地址:https://github.com/JeremyHeleine/Photo-Sphere-Viewer

④全景图

像上图那样的360度全景图,最好是左右能够完美拼接的,这样环顾时才自然。

现在也有能够生成全景图的工具,这里就不介绍啦。

全景图素材站点:http://www.tupian114.com/tupian/quanjing.html

开始

html部分:

需要一个标签元素做为全景图的容器,并引入所需的两个插件。

js部分:

初始化插件,创建一个photosphereviewer对象。

其中,前两个选项panorama和container是必须的,其他都为可选项。

然后,3D全景效果就这样实现啦,简单吧。

那接下来就介绍一下配置参数及方法吧。

配置参数介绍

panorama:(必选)全景图的路径。

container:(必选)放置全景图的容器。

autoload:(默认为true)true为自动加载全景图,false为迟点加载全景图(通.过load方法)。

usexmpdata:(默认值为true)photo sphere viewer是否必须读入xmp数据,false为不必须。

cors_anonymous:(默认值为true)true为不能通过cookies获得用户

pano_size:(默认值为null)全景图的大小,是否裁切。

default_position:(默认值为0)定义默认位置,用户看见的第一个点,例如:{long: math.pi, lat: math.pi/2}。

min_fov:(默认值为30)观察的最小区域,单位degrees,在1-179之间。

max_fov:(默认值为90)观察的最大区域,单位degrees,在1-179之间。

allow_user_interactions:(默认值为true)设置为false,则禁止用户和全景图交互(导航条不可用)。

allow_scroll_to_zoom:(默认值为true)若设置为false,则用户不能通过鼠标滚动进行缩放图片。

tilt_up_max:(默认值为math.pi/2)向上倾斜的最大角度,单位radians。

tilt_down_max:(默认值为math.pi/2)向下倾斜的最大角度,单位radians。

min_longitude:(默认值为0)能够展示的最小经度。

max_longitude:(默认值为2PI)能够展示的最大维度。

zoome_level:(默认值为0)默认的缩放级别,值在0-100之间。

long_offset:(默认值为PI/360)mouse/touch移动时每像素经过的经度值。

lat_offset:(默认值为pi/180)mouse/touch移动时每像素经过的纬度值。

time_anim(默认值为2000)全景图在time_anim毫秒后会自动进行动画。(设置为false禁用它)

reverse_anim:(默认值为true)当水平方向到达最大/最小的经度时,动画方向是否反转(仅仅是不能看到完整的圆)。

anim_speed:(默认值为2rpm)动画每秒/分钟多少的速度。

vertical_anim_speed:(默认值为2rpm)垂直方向的动画每秒/分钟多少的速度。

vertical_anim_target:(默认值为0)当自动旋转时的维度,默认为赤道。

navbar:(默认为false)显示导航条。

navbar_style:(默认值为false)导航条的样式。有效的属性:

backgroundColor:导航条背景色(默认值rgba(61, 61, 61, 0.5));

buttonsColor:按钮前景色(默认值 rgba(255, 255, 255, 0.7));

buttonBackgroundColor:按钮激活时的背景色(默认值 rgba(255, 255, 255, 0.1));

buttonsHeight:按钮高度,单位px(默认值 20);

autorotateThickness:自动旋转图片的层(默认值 1);

zoomRangeWidth:缩放游标的宽度,单位px(默认值 50);

zoomRangeThickness:缩放游标的层(默认值 1);

zoomRangeDisk:缩放游标的放大率,单位px(默认值 7);

fullscreenRatio:全屏图标的比例(默认值 4/3);

fullscreenThickneee:全屏图片的层,单位px(默认值 2)

loading_msg:(默认值为Loading...)加载信息。

loading_img:(默认值 为null)loading图片的路径。

loading_html:(默认值 为null)html加载器(添加到容器中的元素或字符串)。

size:(默认值为null)全景图容器的最终尺寸,例如{width: 500, height: 300}。

onready:(默认值为null)全景图准备好并且第一张图片展示出来后的回调函数。

方法介绍

addAction():添加事件(插件没有提供执行事件的方法,似乎是提供给插件内部使用的)。

fitToContainer():调整全景图容器大小为指定大小。

getPosition():获取坐标经纬度。

getPositionInDegrees():获取经纬度度数。

getZoomLevel():获取缩放级别。

load():加载全景图()。

moveTo(longitude, latitude):根据经纬度移动到某一点。

rotate(dlong, dlat):根据经纬度度数移动到某一点。

toggleAutorotate():是否开启全景图自动旋转。

toggleDeviceOrientation():是否开启重力感应方向控制。

toggleFullscreen():是否开启全景图全屏。

toggleStereo():是否开启立体效果(可用于WebVR哦)。

zoom(level):设置缩放级别。

zoomIn():放大。

zoomOut():缩小。

原文来自:http://www.linuxprobe.com/browser-3d-tours.html

免费提供最新Linux技术教程书籍,为开源技术爱好者努力做得更多更好:http://www.linuxprobe.com/

时间: 2025-01-04 23:43:23

3D全景!这么牛!!的相关文章

浏览器中实现3D全景浏览

如果你用过网页版的百度地图,你大概3D全景图浏览是一种怎样的酷炫体验:在一个点可以360度环顾周围的建筑.景色,当然也可以四周移动,就像身临其境. 科普 全景图共分为三种: ①球面全景图 利用一张全景图围成一个球,自身位置位于球体内.由于图片是矩形,所以最上和最下的缝合处很明显就能够看得出来. 球面全景图是最接近人眼的构建模式,若利用多个立面构建,拼接方法繁琐,性能消耗高. 因此,本文介绍的是上述通过一张全景图构成的球面全景图. ②立方体全景图 一个立方体,有六个面组成,所以就需要六张图片啦.自

打造H5里的“3D全景漫游”秘籍

近来风生水起的VR虚拟现实技术,抽空想起年初完成的“星球计划”项目,总结篇文章与各位分享一下制作基于Html5的3D全景漫游秘籍. QQ物联与深圳市天文台合作,在手Q“发现新设备”-“公共设备”里,连接QQ物联摄像头为用户提供2016年天体大事件的直播,大家可以通过手Q实时观看到世界各地最佳观测点的日食,流星等天体现象.承载整个“星球计划”活动的运营页面,经多方讨论,我们决定尝试3D全景漫游模式的H5运营页进行推广,今天就不详述活动的具体内容,先和大家聊一聊这H5里“3D全景漫游”的制作方法.

vr城市全景(全景智慧城市)3D全景虚拟漫游、VR购物、VR逛街

操控你购物欲望的不是大脑而是VR 据Digi-Capital调查估算,未来的几年里,我们将看到VR产业以难以置信的速度继续增长.该行业的价值将从19亿美元(2016年)上升到200多亿美元,VR将在一定程度上改变消费者的行为.那么VR所带来的改变将会有多大呢?影响往往是多方面的,VR不仅改变了消费者在室内的时间,而且还影响到他们如何看待营销活动,这需要我们从商家和消费者两个角度来分析. VR营销活动 营销活动一直以来都是通过电视.海报.传单.电台广播方式传播的.虽然VR头显销量每天都在提升,一些

基于 HTML5 WebGL 构建智能数字化城市 3D 全景

前言 自 2011 年我国城镇化率首次突破 50% 以来,<新型城镇化发展规划>将智慧城市列为我国城市发展的三大目标之一,并提出到 2020 年,建成一批特色鲜明的智慧城市.截至现今,全国 95% 的副省级以上城市.76% 的地级以上城市,总计约 500 多个城市提出或在建智慧城市. 基于这样的背景,本系统采用 Hightopo 的  HT for Web  产品来构造轻量化的 智慧城市 3D 可视化场景,通过三个角度的转换,更清晰让我们感知到 5G 时代下数字化智能城市的魅力 预览地址:HT

平面之后3D成主流?VR全景表示不服!——全景智慧城市常诚

目前很多人对VR全景这个词汇没有明确的概念,更没有人做过全面的研究,VR全景是什么?VR全景可以做什么?不同于我们经常听到的VR色情,全景智慧城市常诚今天就来为各位做一个系统全面的介绍,深入了解之后,相信各位对VR全景会有一个新的认识,也将了解VR全景是如何超越平面.3D成为主流的. VR全景能让人产生身临其境的感觉,虚拟现实的体验,最早我们应用的多是一些平面或者3D技术,为什么现在的VR全景会超越他们,受到人们青睐呢? 我们先来看这几个简单的问题, 1.市场消费群体是谁? 70?80?90?,

解读360全景能在哪些行业中应用

360全景技术是目前全球范围内迅速发展并逐步流行的一种视觉新技术.它给人们带来全新的真实现场感和交互式的感受.它可广泛应用于三维电子商务,如在线的房地产楼盘展示.虚拟旅游.虚拟教育等领域.我们采用鱼眼镜头拍摄的照片视角可达到180度,在1米的距离以上,景深可达无限远;可使被摄体在画面中显示出非常鲜明的纵深效果,再利用软件专业合成处理,发布为3D全景文件,所显示360全景即为真实场景,与传统的虚拟现实相比更具真实感,更为经济;控制面板工具条,使普通用户操作更为简便.360全景图像源自对真实场景的摄

城市VR全景应用,全景智慧城市与你合作共赢

20VR全景展示初具规模的时候,随着VR技术的日益成熟,越来越多的行业将VR全景应用到日常宣传和营销中,今天要说的就是VR全景展示的具体应用.那么,VR全景究竟会应用到那些场景,哪些行业适合应用VR全景展示昵?我们又会在什么地方可以见到它们的应用呢?   VR全景展示技术从问世到2016年,已经被开始在很多方面进行了大范围的应用,我们也在很多场景中遇到过360度全景的应用实例.但很多时候,有的人还会问,VR全景到底在哪些方面能进行应用呢?今天我就跟大加简单家介绍一下几个VR全景的应用场景. 一.

VR全景到底有何用?

VR全景到底有啥用?其实也面临着"悬浮滑板不悬浮"窘境-不论是GooglCardboard还是SamsungGearVR都没有做到真正意义上的虚拟现实.然而为什么现在有这么多的产品打着VR旗号接受市场的吹捧?小编认为媒体.搜索引擎(比方Googl相关科技公司的市场宣传都应该负起这个责任.悬浮滑板这个概念已经提出很多年了但是至今还没有一台真正意义上的悬浮滑板问世.最近大热的VR技术. 但似乎所有人都已经接受了这个称谓,尽管现在VR技术并不是真正意义上的虚拟现实.并且对它慢慢习以为常.现在

闪云科技VR全景

闪云科技VR全景的720°无死角的展示,还原一个真实的自己.在广阔的互联网平台中,来点不一样,或许,会让你脱颖而出! VR全景以全新的视角,身临其境般的直观感受来全方位展示您的产品.空间.优势 的新技术.用户可通过手机触摸或用鼠标和键盘控制观察全景的方向,可左.可右 .可近.可远,使您感到就像在真实的环境当中浏览景物一样.具有逼真的现场效果,可以在各个空间领域的场景任意漫游,也可以由不同场景切 换或者按特定路线浏览,穿梭于一个个专业领域场景里,并可进行操作控制.宣传 交流.营销.吸引客户,仿佛置