基于Three.js的360X180度全景图预览插件

基于Three.js的360X180度全景图预览插件

时间 2015-08-12 10:01:10  HTML5中国

原文  http://www.html5cn.org/article-8621-1.html

主题 Three.js

简要教程 Photo Sphere Viewer是一款基于Three.js的360X180度全景图预览js插件。该js插件可以360度旋转查看全景图,也可以上下180度查看图片。使用该插件的唯一要求是浏览器支持canvas或WebGL。

查看演示      下载插件

使用方法

使用该全景图插件时要引入three.min.js和photo-sphere-viewer.min.js文件。

  1. <script src="js/three.min.js"></script>
  2. <script src="js/photo-sphere-viewer.min.js"></script>

复制代码

HTML结构

可以创建一个空的<div> 来放置全景图,通过CSS来设置它的尺寸。

  1. <div id="container"></div>

复制代码

初始化插件

要初始化该全景图插件,可以创建一个新的PhotoSphereViewer对象,然后在这个对象中插入一个参数对象,有两个参数是必须设置的:

  1. var PSV = new PhotoSphereViewer({
  2. // Path to the panorama
  3. panorama: ‘1.jpg‘,
  4. // Container
  5. container: div
  6. });

复制代码

配置参数

下面是该全景图插件的所有可用配置参数:

  • panorama:必填参数,全景图的路径。
  • container:必填参数,放置全景图的div元素。
  • autoload:可选,默认值为true,true为自动调用全景图,false为在后面加载全景图(通过.load()方法)。
  • us empdata:可选,默认值为true,如果Photo Sphere Viewer必须读入XMP数据则为true。
  • default_position:可选,默认值为{},定义默认的位置,及用户看见的第一个点,例如:{long: Math.PI, lat: Math.PI/2}。
  • min_fov:可选,默认值为30,观察的最小区域,单位degrees,在1-179之间。
  • max_fov:可选,默认值为90,观察的最大区域,单位degrees,在1-179之间。
  • allow_user_interactions:可选,默认值为true,设置为false则禁止用户和全景图交互(导航条不可用)。
  • tilt_up_max:可选,默认值为Math.PI/2,向上倾斜的最大角度,单位radians。
  • tilt_down_max:可选,默认值为Math.PI/2,向下倾斜的最大角度,单位radians。
  • zoom_level:可选,默认值为0,默认的缩放级别,值在0-100之间。
  • long_offset:可选,默认值为PI/360,mouse/touch移动时每像素经过的经度值。
  • lat_offset:可选,默认值为PI/180,mouse/touch移动时每像素经过的纬度值。
  • time_anim:可选,默认值为2000,全景图在time_anim毫秒后会自动进行动画。(设置为false禁用它)
  • theta_offset:过时的选项,可选,默认值为1440,自动动画时水平方向的速度。
  • anim_speed:可选,默认值为2rpm,动画的速度,每秒/分钟多少radians/degrees/revolutions。
  • navbar:可选值,默认为false。显示导航条。
  • navbar_style:可选值,默认为{}。导航条的自定义样式。下面是可用的样式列表:
  • backgroundColor:导航条的背景颜色,默认值为rgba(61, 61, 61, 0.5)。
  • buttonsColor:按钮的前景颜色,默认值为transparent。
  • activeButtonsBackgroundColor:按钮激活状态的背景颜色,默认值为rgba(255, 255, 255, 0.1)。
  • buttonsHeight:按钮的高度,单位像素,默认值为20。
  • autorotateThickness:autorotate图标的厚度,单位像素,默认值为1。
  • zoomRangeWidth:缩放的范围,单位显示,默认值50。
  • zoomRangeThickness:缩放的范围的厚度,单位像素,默认值1。
  • zoomRangeDisk:缩放范围的圆盘直径,单位像素,默认值为7。
  • fullscreenRatio:全屏图标的比例,默认值为3/4。
  • fullscreenThickness:全屏图标的厚度,单位像素,默认值为2。
  • loading_msg:可选,默认值为Loading…,图片加载时的提示文字。
  • loading_img:可选,默认值为null,在加载时显示的图片的路径。
  • size:可选,默认值null,全景图容器的最终尺寸。例如:{width: 500, height: 300}。
  • onready:可选值,默认值为null。当全景图准备就绪并且第一张图片显示时的回调函数。

如果你喜欢这个插件,那么你可能也喜欢:

时间: 2024-10-27 12:01:02

基于Three.js的360X180度全景图预览插件的相关文章

JS实现图片上传预览效果:方法一

<script type="text/javascript"> //处理file input加载的图片文件 $(document).ready(function(e) { //判断浏览器是否有FileReader接口 if(typeof FileReader =='undefined') { /*$("#images_show").css({'background':'none'}).html('亲,您的浏览器还不支持HTML5的FileReader接口

利用js加载本地图片预览功能

直接上代码: 经测试,除safari6包括6以下不支持,其他均可正常显示. 原因:safari6不支持filereader,同时不能使用IE滤镜导致失效. fix: 可以利用canvas,解决safari6的问题 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

基于9款CSS3鼠标悬停相册预览特效

基于9款CSS3鼠标悬停相册预览特效里面包含九款不同方式的相册展开特效代码.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class="albums"> <div class="albums-inner"> <div class="albums-tab"> <div class="albums-tab-thumb sim-anim-1"> <

js实现移动端图片预览:手势缩放, 手势拖动,双击放大...

.katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > .katex-html { display: block; } .katex-display > .katex > .katex-html > .tag { position: absolute; right: 0px; } .katex { font-style: normal; font

上传图片预览插件(转)

/* *名称:图片上传本地预览插件 v1.1 *作者:周祥 *时间:2013年11月26日 *介绍:基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari *插件网站:http://keleyi.com/keleyi/phtml/image/16.htm *参数说明: Img:图片ID;Width:预览宽度;Height:预览高度;ImgType:支持文件类型;Callback:选择文件显示图片后回调方法; *使用方法: <div> <img id

图片上传时预览插件

html代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> <script src="uploadView.js" type="text/javascript"></script> <script> window.

JQuery插件:图片上传本地预览插件,改进案例一则。

/* *名称:图片上传本地预览插件 v1.1 *作者:周祥 *时间:2013年11月26日 *介绍:基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari *插件网站:http://keleyi.com/keleyi/phtml/image/16.htm *参数说明: Img:图片ID;Width:预览宽度;Height:预览高度;ImgType:支持文件类型;Callback:选择文件显示图片后回调方法; *使用方法: <div> <img id

Eclipse安装propertie预览插件

Eclipse安装properties预览插件 在公司做项目都是用的myeclipse,myeclipse都是直接集成了插件不过占用内存非常巨大.Eclipse能比myeclipse省接近一半的内存,好久就想研究eclipse,这两天用了下eclipse,发现很不适应,好多东西得自己下载插件,尤其是页面和配置文件的预览功能,在此就以properties预览来举例,一共两种方法,第一种是自己装Properties Edito成功的方法,第二种是别人的方法,楼主表示自己笨装插件时第二种报错,始终没找

Three.js制作360度全景图

这是个基于three.js的插件,预览地址:戳这里 使用方法: 1.这个插件的用法很简单,引入如下2个js <script src="js/three.min.js"></script> <script src="js/photo-sphere-viewer.min.js"></script> 2.初始化一下,(具体各种参数配置根据情况而定) var PSV = new PhotoSphereViewer({ // 全