3D全景漫游

3D全景漫游

three.js

示例:
​ 打造H5里的“3D全景漫游”秘籍 - 腾讯ISUX
​ QQ物联星球计划

通过pano2vr直接将鱼眼全景图生成立体空间的六个面;也可通过Photoshop或其他的专业3D建模工具,将鱼眼图贴到3D球面上,再将球面转为立方面,获得立体空间的六个面。

使用到的JS库:

  1. three.min.js

  2. CSS3DRenderer.js

源码Demo:http://mrleo.github.io/3DPanorama

设置相机

camera = new THREE.PerspectiveCamera(50, window.innerWidth / window.innerHeight, 1, 1000);

设置场景

scene = new THREE.Scene();

定义3D空间的6个面的背景

var sides = [{
url: '../static/img/gugong/posx.jpg',
position: [-512, 0, 0],
rotation: [0, Math.PI / 2, 0]
}, {
url: '../static/img/gugong/negx.jpg',
position: [512, 0, 0],
rotation: [0, -Math.PI / 2, 0]
}, {
url: '../static/img/gugong/posy.jpg',
position: [0, 512, 0],
rotation: [Math.PI / 2, 0, Math.PI]
}, {
url: '../static/img/gugong/negy.jpg',
position: [0, -512, 0],
rotation: [-Math.PI / 2, 0, Math.PI]
}, {
url: '../static/img/gugong/posz.jpg',
position: [0, 0, 512],
rotation: [0, Math.PI, 0]
}, {
url: '../static/img/gugong/negz.jpg',
position: [0, 0, -512],
rotation: [0, 0, 0]
}];

将定义好的6各面添加到空间中,并为每个空间指定ID

for (var i = 0; i

设置渲染器

renderer = new THREE.CSS3DRenderer();//定义渲染器
renderer.setSize(window.innerWidth, window.innerHeight);//设置尺寸
document.body.appendChild(renderer.domElement);//将场景加入页面

空间实时渲染

function animate() {
requestAnimationFrame(animate);
//lon = Math.max(-180, Math.min(180, lon));//限制固定角度内旋转
//lon += 0.1;//自动旋转
lon += 0;
lat = Math.max(-85, Math.min(85, lat));
phi = THREE.Math.degToRad(90 - lat);
theta = THREE.Math.degToRad(lon);
target.x = Math.sin(phi) Math.cos(theta);
target.y = Math.cos(phi);
target.z = Math.sin(phi)
Math.sin(theta);
camera.lookAt(target);
renderer.render(scene, camera);
}

为每个面构建空间的图标物件

function addIcon(){
var imgIcon = document.createElement('img');
imgIcon.src = '../static/img/arrow_right.png';
imgIcon.classList.add('icon');
document.getElementById('section_4').appendChild(imgIcon);
}
addIcon();

窗体大小改变更新相机

function onWindowResize() {
camera.aspect = window.innerWidth / window.innerHeight;
camera.updateProjectionMatrix();
renderer.setSize(window.innerWidth, window.innerHeight);
}

监听鼠标事件

function onDocumentMouseDown(event) {
event.preventDefault();
document.addEventListener('mousemove', onDocumentMouseMove, false);
document.addEventListener('mouseup', onDocumentMouseUp, false);
}

function onDocumentMouseMove(event) {
var movementX = event.movementX || event.mozMovementX || event.webkitMovementX || 0;
var movementY = event.movementY || event.mozMovementY || event.webkitMovementY || 0;
lon -= movementX 0.1;
lat += movementY
0.1;
}

function onDocumentMouseUp(event) {
document.removeEventListener('mousemove', onDocumentMouseMove);
document.removeEventListener('mouseup', onDocumentMouseUp);
}

/

  • 鼠标滚轮改变相机焦距
    /
    function onDocumentMouseWheel(event) {
    camera.fov -= event.wheelDeltaY
    0.05;
    camera.updateProjectionMatrix();
    }

    监听触摸事件

    function onDocumentTouchStart(event) {
    event.preventDefault();
    var touch = event.touches[0];
    touchX = touch.screenX;
    touchY = touch.screenY;
    }

function onDocumentTouchMove(event) {
event.preventDefault();
var touch = event.touches[0];
lon -= (touch.screenX - touchX) 0.1;
lat += (touch.screenY - touchY)
0.1;
touchX = touch.screenX;
touchY = touch.screenY;
}

WebGL中文网

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

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

使用方法

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

HTML结构

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

初始化插件

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

var PSV = new PhotoSphereViewer({
// Path to the panorama
panorama: '1.jpg',

// Containercontainer: div

});

配置参数

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

  1. panorama:必填参数,全景图的路径。

  2. container:必填参数,放置全景图的div元素。

  3. autoload:可选,默认值为true,true为自动调用全景图,false为在后面加载全景图(通过.load()方法)。

  4. usexmpdata:可选,默认值为true,如果Photo Sphere Viewer必须读入XMP数据则为true。

  5. default_position:可选,默认值为{},定义默认的位置,及用户看见的第一个点,例如:{long: Math.PI, lat: Math.PI/2}。

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

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

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

  9. tilt_up_max:可选,默认值为Math.PI/2,向上倾斜的最大角度,单位radians。

  10. tilt_down_max:可选,默认值为Math.PI/2,向下倾斜的最大角度,单位radians。

  11. zoom_level:可选,默认值为0,默认的缩放级别,值在0-100之间。

  12. long_offset:可选,默认值为PI/360,mouse/touch移动时每像素经过的经度值。

  13. lat_offset:可选,默认值为PI/180,mouse/touch移动时每像素经过的纬度值。

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

  15. theta_offset:过时的选项,可选,默认值为1440,自动动画时水平方向的速度。

  16. anim_speed:可选,默认值为2rpm,动画的速度,每秒/分钟多少radians/degrees/revolutions。

  17. navbar:可选值,默认为false。显示导航条。

  18. navbar_style:可选值,默认为{}。导航条的自定义样式。下面是可用的样式列表:

backgroundColor:导航条的背景颜色,默认值为rgba(61, 61, 61, 0.5)。

  1. buttonsColor:按钮的前景颜色,默认值为transparent。

  2. activeButtonsBackgroundColor:按钮激活状态的背景颜色,默认值为rgba(255, 255, 255, 0.1)。

  3. buttonsHeight:按钮的高度,单位像素,默认值为20。

  4. autorotateThickness:autorotate图标的厚度,单位像素,默认值为1。

  5. zoomRangeWidth:缩放的范围,单位显示,默认值50。

  6. zoomRangeThickness:缩放的范围的厚度,单位像素,默认值1。

  7. zoomRangeDisk:缩放范围的圆盘直径,单位像素,默认值为7。

  8. fullscreenRatio:全屏图标的比例,默认值为3/4。

  9. fullscreenThickness:全屏图标的厚度,单位像素,默认值为2。

  10. loading_msg:可选,默认值为Loading…,图片加载时的提示文字。

  11. loading_img:可选,默认值为null,在加载时显示的图片的路径。

  12. size:可选,默认值null,全景图容器的最终尺寸。例如:{width: 500, height: 300}。

  13. onready:可选值,默认值为null。当全景图准备就绪并且第一张图片显示时的回调函数。

关键字:JavaScript, 默认, math, 可选

版权声明

本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处。如若内容有涉嫌抄袭侵权/违法违规/事实不符,请点击 举报 进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部