zoukankan      html  css  js  c++  java
  • 关于360度全景照片的问题总结

    今天做了一个360度的全景照片,其中要注意以下几个问题:

    1:如何在拖图片时,使其加载变快?---注意让图片隐藏的性能比让图片切换的性能高,且在IE9下运行,会出现图片加载的问题
    1:如何使图片带有一定的速度转
    1:考虑如果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>

  • 相关阅读:
    DHTML【11】--DOM
    sql 查询强制使用HASH连接性能测试比较
    Winform开发框架之读卡器和条码扫描枪的数据接收处理
    DevExpress的XtraReport和微软RDLC报表的使用和对比
    sql server日期时间转字符串
    C#在线更新程序[下载程序、解压缩程序、控制台程序]
    C# 定时器事件(设置时间间隔,间歇性执行某一函数,控制台程序)
    用C#用C#实现窗体在规定时间弹出,例如:10:00.弹出后关闭。并在5分钟后再次弹出。5次后停止。最好有具体代码实现窗体在规定时间弹出,例如:10:00.弹出后关闭。并在5分钟后再次弹出。5次后停止。最好有具体代码
    C#多线程学习之(五)使用定时器进行多线程的自动管理
    C# 文件与目录的基本操作(System.IO)
  • 原文地址:https://www.cnblogs.com/jtjds/p/5263645.html
Copyright © 2011-2022 走看看