仿3D

效果图
示例代码:

html文件:

        <div id="box">
            <a href="javascript:;">
                ![]((img/1.jpg))
            </a>
            <a href="javascript:;">
                ![]((img/3.jpg))
            </a>
            <a href="javascript:;">
                ![]((img/5.jpg))
            </a>
            <a href="javascript:;">
                ![]((img/6.jpg))
            </a>
            <a href="javascript:;">
                ![]((img/7.jpg))
            </a>
            <a href="javascript:;">
                ![]((img/8.jpg))
            </a>
            <a href="javascript:;">
                ![]((img/9.jpg))
            </a>
        </div>

css代码:

          *{
                margin:0;
                padding:0;
            }
            #box{
                width:800px;
                height:400px;
                margin:50px auto;
                position: relative;
            }
            #box img{
                position: absolute;
            }
            #box .aa{
                width:320px;
                height:160px;
                top:-160px;
                left:0;
                z-index:1;
                opacity: 0;
            }
          #box .aa1{
              width:320px;
              height:160px;
              top:120px;
              left:0;
              z-index:1;
              opacity: 0.2;
          }
          #box .aa2{
            width:360px;
            height:180px;
            top:110px;
            left:100px;
            z-index:2;
            opacity:0.6;
          }
          #box .aa3{
            width:400px;
            height:200px;
            top:100px;
            z-index:3;
            left:200px;
            opacity: 1;
          }
          #box .aa4{
            width:360px;
            height:180px;
            top:110px;
            left:340px;
            z-index:2;
            opacity:0.6;
          }
          #box .aa5{
            width:320px;
            height:160px;
            top:120px;
            left:480px;
            z-index:1;
            opacity: 0.2;
          }
          #box .aa6{
            width:320px;
            height:160px;
            top:-160px;
            left:480px;
            z-index:1;
            opacity: 0;
          }

js代码:

        var aImg=document.getElementsByTagName("img");
        var arr=["zIndex","width","height","opacity","left","top"];
        var arrVal=[];
        for(var i=0;i<aImg.length;i++){
             var oarr={};
            for(var j=0;j<arr.length;j++){
                if(arr[j]=="opacity"){
                    var icur=Math.round(getStyle(aImg[i],'opacity')*100)
                }else{
                    var icur=parseInt(getStyle(aImg[i],arr[j]))
                }
              oarr[arr[j]]=icur;    
            }
            arrVal.push(oarr)
        }

        setInterval(function(){
            arrVal.push(arrVal.shift());
//          console.log(arrVal[0]);
            for(var i=0;i<aImg.length;i++){
                startMove(aImg[i], arrVal[i])
            }
        },3000)

        function getStyle(obj,attr){
            if(obj.currentStyle){
                return obj.currentStyle[attr]
            }else{
                return getComputedStyle(obj)[attr]
            }
        }

        function startMove(obj,json,fnEnd){
            //每次调用的时候,就需要只有一个定时器在工作,(开始运动时候关闭所有定时器)
            //并且关闭或开启都是当前物体的定时器,防止与页面上其他定时器冲突,使每个定时器互不干扰。
            clearInterval(obj.timer);
            obj.timer=setInterval(function(){
                var bStop=true; //假设所有的都已经到达目标了。
                for(var name in json){
                    var iTarget=json[name] //所有的目标点
                    if(name=="opacity"){
                        var cur=parseInt(parseFloat(getStyle(obj,name))*100)
                    }else{
                        var cur=parseInt(getStyle(obj,name))   //cur是当前移动的数值
                    }
                    var speed=(iTarget-cur)/10;
                    //物体运动的速度,数字越小运动的越慢。
                    speed=speed>0?Math.ceil(speed):Math.floor(speed);
                    if(name=="opacity"){
                        obj.style.opacity=(cur+speed)/100
                    }else if(name=='zIndex'){
                        obj.style[name]=cur+speed
                    }else{
                        obj.style[name]=cur+speed+"px";
                    }
                    //某个值不等于目标点
                    if(cur!=iTarget){
                        bStop=false;
                    }
                }

                if(bStop){
                    clearInterval(obj.timer);
                    if(fnEnd){
                        fnEnd();
                    }
                }
            },20)
        }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,296评论 25 708
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,241评论 4 61
  • 其实,我总觉得我应该漂亮、温柔、多才多艺,而不该是这样普通、粗糙、啥都不会。 我学习普通,能力普通,交际普通...
    Y黑姑娘阅读 364评论 8 0
  • 01. 上周五与两个同事一起吃饭,吃饭间隙大家聊到了“耳机”,仿佛男生天生就比女生对这些产品或硬件等特性懂行一些,...
    妍兮阅读 875评论 0 5
  • 本故事纯属虚构,如有雷同,请勿对号入座。 “那晚,隔着学校的弹簧伸缩门见到他的瞬间,我就迷醉在他的眼神中了。我从他...
    雪球球阅读 166评论 0 0