【实例简介】利用html5实现的360度全景图浏览(带天地)

【实例截图】

【核心代码】

var camera, scene, renderer;

var texture_placeholder,

isUserInteracting = false,

onMouseDownMouseX = 0, onMouseDownMouseY = 0,

lon = 90, onMouseDownLon = 0,

lat = 0, onMouseDownLat = 0,

phi = 0, theta = 0,

target = new THREE.Vector3();

init();

function init() {

var container, mesh;

container = document.getElementById( 'container' );

camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 1, 1100 );

scene = new THREE.Scene();

scene.add( camera );

texture_placeholder = document.createElement( 'canvas' );

texture_placeholder.width = 128;

texture_placeholder.height = 128;

var context = texture_placeholder.getContext( '2d' );

context.fillStyle = 'rgb( 200, 200, 200 )';

context.fillRect( 0, 0, texture_placeholder.width, texture_placeholder.height );

var materials = [

loadTexture( 'images/textures/cube/skybox/px.jpg' ), // right

loadTexture( 'images/textures/cube/skybox/nx.jpg' ), // left

loadTexture( 'images/textures/cube/skybox/py.jpg' ), // top

loadTexture( 'images/textures/cube/skybox/ny.jpg' ), // bottom

loadTexture( 'images/textures/cube/skybox/pz.jpg' ), // back

loadTexture( 'images/textures/cube/skybox/nz.jpg' )  // front

];

mesh = new THREE.Mesh( new THREE.CubeGeometry( 300, 300, 300, 7, 7, 7, materials ), new THREE.MeshFaceMaterial() );

mesh.scale.x = - 1;

scene.add( mesh );

renderer = new THREE.CanvasRenderer();

renderer.setSize( window.innerWidth, window.innerHeight );

container.appendChild( renderer.domElement );

document.addEventListener( 'mousedown', onDocumentMouseDown, false );

document.addEventListener( 'mousemove', onDocumentMouseMove, false );

document.addEventListener( 'mouseup', onDocumentMouseUp, false );

document.addEventListener( 'mousewheel', onDocumentMouseWheel, false );

document.addEventListener( 'touchstart', onDocumentTouchStart, false );

document.addEventListener( 'touchmove', onDocumentTouchMove, false );

}

function loadTexture( path ) {

var texture = new THREE.Texture( texture_placeholder );

var material = new THREE.MeshBasicMaterial( { map: texture, overdraw: true } );

var image = new Image();

image.onload = function () {

texture.needsUpdate = true;

material.map.image = this;

render();

};

image.src = path;

return material;

}

function onDocumentMouseDown( event ) {

event.preventDefault();

isUserInteracting = true;

onPointerDownPointerX = event.clientX;

onPointerDownPointerY = event.clientY;

onPointerDownLon = lon;

onPointerDownLat = lat;

}

function onDocumentMouseMove( event ) {

if ( isUserInteracting ) {

lon = ( onPointerDownPointerX - event.clientX ) * 0.1 onPointerDownLon;

lat = ( event.clientY - onPointerDownPointerY ) * 0.1 onPointerDownLat;

render();

}

}

function onDocumentMouseUp( event ) {

isUserInteracting = false;

render();

}

function onDocumentMouseWheel( event ) {

camera.fov -= event.wheelDeltaY * 0.05;

camera.updateProjectionMatrix();

render();

}

function onDocumentTouchStart( event ) {

if ( event.touches.length == 1 ) {

event.preventDefault();

onPointerDownPointerX = event.touches[ 0 ].pageX;

onPointerDownPointerY = event.touches[ 0 ].pageY;

onPointerDownLon = lon;

onPointerDownLat = lat;

}

}

function onDocumentTouchMove( event ) {

if ( event.touches.length == 1 ) {

event.preventDefault();

lon = ( onPointerDownPointerX - event.touches[0].pageX ) * 0.1 onPointerDownLon;

lat = ( event.touches[0].pageY - onPointerDownPointerY ) * 0.1 onPointerDownLat;

render();

}

}

function render() {

lat = Math.max( - 85, Math.min( 85, lat ) );

phi = ( 90 - lat ) * Math.PI / 180;

theta = lon * Math.PI / 180;

target.x = 500 * Math.sin( phi ) * Math.cos( theta );

target.y = 500 * Math.cos( phi );

target.z = 500 * Math.sin( phi ) * Math.sin( theta );

camera.lookAt( target );

renderer.render( scene, camera );

}

全景效果图html5,利用html5实现的360度全景图浏览(带天地)相关推荐

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

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

  2. HTML5 Canvas实现360度全景图

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

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

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

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

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

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

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

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

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

  7. unity 使用360度全景图

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

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

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

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

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

最新文章

  1. 【转】浅谈php://filter的妙用
  2. mysql5_pn卸载_windows mySql(5.7.30) 卸载及重装
  3. 猜数字游戏_FLEX版
  4. 语音识别:时间序列的匹配算法(Needleman-Wunsch 算法)
  5. mysql两个字段相减_MySQL 中NULL和空值的区别?
  6. MATLAB教程(1) MATLAB 基础知识(2)
  7. javascript encodeURI和encodeURIComponent的比较
  8. Struts2学习笔记(七) 结果(Result)(下)
  9. 银行家算法检测死锁c语言,[算法]操作系统进程调度与通信算法 Dijkstra银行家算法 C语言实现 | 李大仁博客...
  10. php写入word文档内容,如何在PHP中读取和写入WORD文档
  11. 产品沉思录 V3.0 试读
  12. html怎么存储历史记录,设置网页在历史记录中保存10天
  13. 批量删除文件名前的数字编号
  14. 剑指Offer 46.把数字翻译成字符串(Python)
  15. JdbcTemplate数据库连接耗尽问题排查
  16. 科技发展快速,VR、AR概念要怎么区分?
  17. 《Total Commander:万能文件管理器》——12.6. 附录
  18. 韩顺平老师讲解13个自学编程的坑
  19. utils.data的使用
  20. Python 字典(Dictionary. items()方法

热门文章

  1. Glance支持镜像的格式
  2. OSGL 工具库 - IO 操作的艺术
  3. JAVA类加载机制之Classloader以及打破加载机制的方式
  4. 【华为机试真题 JAVA】奥运会排行榜-100
  5. Linux C/C++网络编程实战-陈硕-笔记10-网络时间同步
  6. dalvik(清除dalvik)
  7. 加法计算-parseFloat
  8. word 编辑过程中变为只读_秒会的全能PDF编辑神器:PDFelement 7 Pro使用介绍
  9. windows凭据密码怎么查看_怎么查看wifi密码
  10. 犀牛 Rhinoceros 5.5.4 for Mac 中文共享版 – 3D设计建模软件