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 相关文章推荐
用JavaScript对JSON进行模式匹配(Part 1-设计)
Jul 17 Javascript
JavaScript中的Array对象使用说明
Jan 17 Javascript
jquery教程限制文本框只能输入数字和小数点示例分享
Jan 13 Javascript
JS+CSS实现的漂亮渐变背景特效代码(6个渐变效果)
Mar 25 Javascript
js编写一个简单的产品放大效果代码
Jun 27 Javascript
js完整倒计时代码分享
Sep 18 Javascript
Vue.js 和 MVVM 的注意事项
Nov 07 Javascript
vue2.0 keep-alive最佳实践
Jul 06 Javascript
浅谈Node.js 沙箱环境
May 15 Javascript
vue通过点击事件读取音频文件的方法
May 30 Javascript
发布Angular应用至生产环境的方法
Dec 10 Javascript
JavaScript实现文件下载并重命名代码实例
Dec 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
屏蔽浏览器缓存另类方法
2006/10/09 PHP
Laravel学习教程之request validation的编写
2017/10/25 PHP
js removeChild 障眼法 可能出现的错误
2009/10/06 Javascript
JQUERY操作JSON实例代码
2010/02/09 Javascript
解析prototype,JQuery中跳出each循环的方法
2013/12/12 Javascript
jquery获取当前日期的方法
2015/01/14 Javascript
js制作简易年历完整实例
2015/01/28 Javascript
jquery简单倒计时实现方法
2015/12/18 Javascript
实例讲解jquery与json的结合
2016/01/07 Javascript
学习JavaScript事件流和事件处理程序
2016/01/25 Javascript
jQuery实现百叶窗焦点图动画效果代码分享(附源码下载)
2016/03/14 Javascript
dedecms页面如何获取会员状态的实例代码
2016/03/15 Javascript
Javascript动画效果(4)
2016/10/11 Javascript
JS常用算法实现代码
2016/11/14 Javascript
微信小程序 实现拖拽事件监听实例详解
2016/11/16 Javascript
JS滚动到指定位置导航栏固定顶部
2017/07/03 Javascript
layui 对table中的数据进行转义的实例
2019/09/12 Javascript
Vue路由权限控制解析
2020/11/09 Javascript
Python的math模块中的常用数学函数整理
2016/02/04 Python
python在每个字符后添加空格的实例
2018/05/07 Python
详解Django-restframework 之频率源码分析
2019/02/27 Python
使用OpenCV去除面积较小的连通域
2020/07/05 Python
基于Python的接口自动化读写excel文件的方法
2021/01/15 Python
多重CSS背景动画实现方法示例
2014/04/04 HTML / CSS
TripAdvisor西班牙官方网站:全球领先的旅游网站
2018/01/10 全球购物
下列程序在32位linux或unix中的结果是什么
2015/01/26 面试题
单位在职证明范本
2014/01/09 职场文书
大学生创业感言
2014/01/25 职场文书
八项规定自查自纠报告及整改措施
2014/10/26 职场文书
后进生评语大全
2015/01/04 职场文书
长城的导游词
2015/01/30 职场文书
活动新闻稿范文
2015/07/17 职场文书
人事部:年度述职报告范文
2019/07/12 职场文书
Vue详细的入门笔记
2021/05/10 Vue.js
Javascript 解构赋值详情
2021/11/17 Javascript
vue 给数组添加新对象并赋值
2022/04/20 Vue.js