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 相关文章推荐
JQuery 选择器 xpath 语法应用
May 13 Javascript
复制Input内容的js代码_支持所有浏览器,修正了Firefox3.5以上的问题
Jun 21 Javascript
推荐20家国外的脚本下载网站
Apr 28 Javascript
jQuery控制TR显示隐藏的三种常用方法
Aug 21 Javascript
JS获取图片lowsrc属性的方法
Apr 01 Javascript
vue中如何引入jQuery和Bootstrap
Apr 10 jQuery
深入剖析Express cookie-parser中间件实现示例
Feb 01 Javascript
node使用promise替代回调函数
May 07 Javascript
详解基于Vue-cli搭建的项目如何和后台交互
Jun 29 Javascript
vue子路由跳转实现tab选项卡
Jul 24 Javascript
ES6中let、const的区别及变量的解构赋值操作方法实例分析
Oct 15 Javascript
js 数组当前行添加数据方法详解
Jul 28 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
PHP计算2点经纬度之间的距离代码
2013/08/12 PHP
PHP empty函数报错解决办法
2014/03/06 PHP
PHP实现的下载远程图片自定义函数分享
2015/01/28 PHP
php上传中文文件名乱码问题处理方案
2015/02/03 PHP
PHP入门教程之数学运算技巧总结
2016/09/11 PHP
Aster vs KG BO3 第二场2.18
2021/03/10 DOTA
模拟select的代码
2011/10/19 Javascript
js 关键词高亮(根据ID/tag高亮关键字)案例介绍
2013/01/21 Javascript
js中生成map对象的方法
2014/01/09 Javascript
jquery复选框多选赋值给文本框的方法
2015/01/27 Javascript
jQuery为DOM动态追加事件的方法
2017/02/16 Javascript
js实现显示手机号码效果
2017/03/09 Javascript
Node.js中看JavaScript的引用
2017/04/22 Javascript
Angular4绑定html内容出现警告的处理方法
2017/11/03 Javascript
vue项目中vue-i18n和element-ui国际化开发实现过程
2018/04/25 Javascript
浅谈使用mpvue开发小程序需要注意和了解的知识点
2018/05/23 Javascript
解决vue路由后界面没有变化,但是链接有的问题
2018/09/01 Javascript
详解如何用VUE写一个多用模态框组件模版
2018/09/27 Javascript
微信小程序实用代码段(收藏版)
2019/12/17 Javascript
vue中echarts的用法及与elementui-select的协同绑定操作
2020/11/17 Vue.js
[02:16]DOTA2英雄基础教程 干扰者
2014/01/15 DOTA
Python的加密模块md5、sha、crypt使用实例
2014/09/28 Python
Python2.7编程中SQLite3基本操作方法示例
2017/08/09 Python
Python 函数list&amp;read&amp;seek详解
2019/08/28 Python
Python3创建Django项目的几种方法(3种)
2020/06/03 Python
python如何查看网页代码
2020/06/07 Python
Django web自定义通用权限控制实现方法
2020/11/24 Python
CSS3中currentColor关键字的妙用
2016/02/27 HTML / CSS
学校安全教育制度
2014/01/31 职场文书
2014年驾驶员工作总结
2014/11/18 职场文书
慰问信范文
2015/02/14 职场文书
教师评职称工作总结2015
2015/04/20 职场文书
2019年二手房买卖合同范本
2019/10/14 职场文书
教你用python实现12306余票查询
2021/06/30 Python
如何通过简单的代码描述Angular父组件、子组件传值
2022/04/07 Javascript
java版 简单三子棋游戏
2022/05/04 Java/Android