javascript如何实现360度全景照片问题汇总


Posted in Javascript onApril 04, 2016

本文为大家分享了做360度的全景照片的详细步骤,其中要注意以下几个问题:

1、如何在拖图片时,使其加载变快?---注意让图片隐藏的性能比让图片切换的性能高,且在IE9下运行,会出现图片加载的问题
2、如何使图片带有一定的速度转
3、考虑如果x为负数和负数两种情况

代码如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<link rel="stylesheet" type="text/css" href="style.css" />
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script>
window.onload=function ()
{
  var oImg=document.getElementById('img1');//第一张图片
  var aImg=document.getElementsByTagName('img');
  var lastimage=oImg;
  var x=0;//鼠标拖动某一个点,用该点的位置,来改变src
  var speed=0;
  var lastx=0;
  var timer=null;
  var temp=0;
  for(i=0;i<77;i++)
  {
    var oNewImage=document.createElement('img');
    oNewImage.src='img/miaov ('+i+').jpg'; 
    oNewImage.style.display='none';
    document.body.appendChild(oNewImage);//先将77张图片隐藏
  }
  document.onmousedown=function(ev)
  {
    clearInterval(timer);
    var oEvent=ev||event;
    var disx=oEvent.clientX-x;
    document.onmousemove=function(ev)
    {
       var oEvent=ev||event;
       x=oEvent.clientX-disx;
       setMove(); 
       speed=x-lastx;//记录前后两个速度
       lastx=x;
      return false;
    }
    document.onmouseup=function()
    {
       document.onmousemove=null;
       document.onmouseup=null;
       timer=setInterval(function(){
        x+=speed;
        setMove();
         document.title=speed;
       },30);

    }
    function setMove()
    {
       if(speed>0){speed--;}
       else if(speed==0){clearInterval(timer);}
       else {speed++;}
       temp=-x;//temp要设为全局变量
       if(temp>0)
       {
        temp=-x%77;
       }
       else
       {
        temp=-x+(-Math.floor(-x/77)*77);
       }
       //oImg.src='img/miaov ('+temp+').jpg'; //这里外面要用单引号 
       //alert(aImg.length);
       lastimage.style.display='none';//先让最后一张变为none(刚开始也为第一张,鼠标没有移动时,第一张图片是显示的)
       aImg[temp].style.display='block';//当打开页面时,出现的默认为第一张图片
       lastimage=aImg[temp];
     
       document.title=temp;
    }
    return false;
  }  
}
</script>
</head>
<body>
<img id="img1" src="img/miaov (0).jpg" />
<!--<div id="bg"></div>
<div id="prog">
  360度全景展示 载入中......<span>0%</span>
  <div id="bar"></div>
</div>-->
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
JS的参数传递示例介绍
Feb 08 Javascript
JavaScript实现大数的运算
Nov 24 Javascript
基于jQuery实现在线选座之高铁版
Aug 24 Javascript
js实现内容显示并使用json传输数据
Mar 16 Javascript
Javascript的表单验证-提交表单
Mar 18 Javascript
ionic+AngularJs实现获取验证码倒计时按钮
Apr 22 Javascript
JavaScript操作文件_动力节点Java学院整理
Jun 30 Javascript
jQuery+vue.js实现的九宫格拼图游戏完整实例【附源码下载】
Sep 12 jQuery
基于three.js实现的3D粒子动效实例代码
Apr 09 Javascript
vue webpack重写cookie路径的方法
Jul 10 Javascript
解决vue的过渡动画无法正常实现问题
Oct 31 Javascript
uniapp 仿微信的右边下拉选择弹出框的实现代码
Jul 12 Javascript
javascript制作照片墙及制作过程中出现的问题
Apr 04 #Javascript
javascript拖拽效果延伸学习
Apr 04 #Javascript
javascript事件委托的用法及其好处简析
Apr 04 #Javascript
基于javascript制作微博发布栏效果
Apr 04 #Javascript
纯js实现手风琴效果
Apr 17 #Javascript
AngularJS中的$watch(),$digest()和$apply()区分
Apr 04 #Javascript
Angular 根据 service 的状态更新 directive
Apr 03 #Javascript
You might like
全国FM电台频率大全 - 22 重庆市
2020/03/11 无线电
PhpMyAdmin中无法导入sql文件的解决办法
2010/01/08 PHP
php json_encode奇怪问题说明
2011/09/27 PHP
php 字符串中的\n换行符无效、不能换行的解决方法
2014/04/02 PHP
类似框架的js代码
2006/11/09 Javascript
JS 自动安装exe程序
2008/11/30 Javascript
公共js在页面底部加载的注意事项介绍
2013/07/18 Javascript
javascript数组操作(创建、元素删除、数组的拷贝)
2014/04/07 Javascript
jQuery回调函数的定义及用法实例
2014/12/23 Javascript
jquery使用正则表达式验证email地址的方法
2015/01/22 Javascript
基于jQuery实现的扇形定时器附源码下载
2015/10/20 Javascript
jQuery解析Json实例详解
2015/11/24 Javascript
JavaScript获取对象在页面中位置坐标的方法
2016/02/03 Javascript
Vue.js每天必学之Class与样式绑定
2016/09/05 Javascript
概述一个页面从输入URL到页面加载完的过程
2016/12/16 Javascript
angular实现图片懒加载实例代码
2017/06/08 Javascript
angular4 如何在全局设置路由跳转动画的方法
2017/08/30 Javascript
Angular2实现的秒表及改良版示例
2019/05/10 Javascript
JavaScript实现捕获鼠标坐标
2020/04/12 Javascript
Vue封装Axios请求和拦截器的步骤
2020/09/16 Javascript
NodeJS开发人员常见五个错误理解
2020/10/14 NodeJs
[49:20]VG vs TNC Supermajor小组赛B组败者组决赛 BO3 第二场 6.2
2018/06/03 DOTA
python实现画圆功能
2018/01/25 Python
django 外键model的互相读取方法
2018/12/15 Python
详解Python 定时框架 Apscheduler原理及安装过程
2019/06/14 Python
Ubuntu18.04下python版本完美切换的解决方法
2019/06/14 Python
为什么从Python 3.6开始字典有序并效率更高
2019/07/15 Python
Django时区详解
2019/07/24 Python
使用keras实现densenet和Xception的模型融合
2020/05/23 Python
python如何建立全零数组
2020/07/19 Python
工程造价专业大专生求职信
2013/10/06 职场文书
光荣入党自我鉴定
2014/01/22 职场文书
课堂教学改革实施方案
2014/03/17 职场文书
财产公证书格式
2014/04/10 职场文书
骆驼祥子读书笔记
2015/06/26 职场文书
Spring Data JPA框架的核心概念和Repository接口
2022/04/28 Java/Android