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 相关文章推荐
CSS+JS构建的图片查看器
Jul 22 Javascript
js中 javascript:void(0) 用法详解
Aug 11 Javascript
JS代码防止SQL注入的方法(超简单)
Apr 12 Javascript
简单实现node.js图片上传
Dec 18 Javascript
js判断手机系统是android还是ios
Mar 07 Javascript
微信小程序url与token设置详解
Sep 26 Javascript
javascript少儿编程关于返回值的函数内容
May 27 Javascript
详解VUE Element-UI多级菜单动态渲染的组件
Apr 25 Javascript
layui复选框的全选与取消实现方法
Sep 02 Javascript
微信小程序自定义tabbar custom-tab-bar 6s出不来解决方案(cover-view不兼容)
Nov 01 Javascript
vue 实现用户登录方式的切换功能
Apr 14 Javascript
简单聊聊Vue中的计算属性和属性侦听
Oct 05 Vue.js
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
jQuery 源码分析笔记
2011/05/25 PHP
php 判断字符串中是否包含html标签
2014/02/17 PHP
php给图片添加文字水印方法汇总
2015/08/27 PHP
PHP设计模式之模板模式定义与用法详解
2018/12/20 PHP
laravel-admin select框默认选中的方法
2019/10/03 PHP
js移除事件 js绑定事件实例应用
2012/11/28 Javascript
体验js中splice()的强大(插入、删除或替换数组的元素)
2013/01/16 Javascript
nodejs读取memcache示例分享
2014/01/02 NodeJs
使用js判断控件是否获得焦点
2014/01/03 Javascript
innerHTML在IE中报错解决方案
2014/12/15 Javascript
JavaScript实现防止网页被嵌入Frame框架的代码分享
2014/12/29 Javascript
浅析JavaScript动画
2015/06/10 Javascript
javascript实现显示和隐藏div方法汇总
2015/08/14 Javascript
JavaScript如何动态创建table表格
2020/08/02 Javascript
jquery淡入淡出效果简单实例
2016/01/14 Javascript
JS中的phototype详解
2017/02/04 Javascript
基于Vue 撸一个指令实现拖拽功能
2019/10/09 Javascript
Node在Controller层进行数据校验的过程详解
2020/08/28 Javascript
Openlayers显示地理位置坐标的方法
2020/09/28 Javascript
vue实现登录功能
2020/12/31 Vue.js
Python中__init__和__new__的区别详解
2014/07/09 Python
Python lxml模块安装教程
2015/06/02 Python
python 生成器生成杨辉三角的方法(必看)
2017/04/10 Python
在VS Code上搭建Python开发环境的方法
2018/04/06 Python
django中使用POST方法获取POST数据
2019/08/20 Python
Python钉钉报警及Zabbix集成钉钉报警的示例代码
2020/08/17 Python
详解scrapy内置中间件的顺序
2020/09/28 Python
css3实现3D色子翻转特效
2014/12/23 HTML / CSS
HTML 5 input placeholder 属性如何完美兼任ie
2014/05/12 HTML / CSS
DELPHI面试题研发笔试试卷
2015/11/08 面试题
Laravel中Kafka的使用详解
2021/03/24 PHP
艺术设计专业毕业生推荐信
2014/07/08 职场文书
党的群众路线对照检查材料范文
2014/09/24 职场文书
人民调解协议书范本
2014/10/11 职场文书
2014年财务部工作总结
2014/11/11 职场文书
python 遍历磁盘目录的三种方法
2021/04/02 Python