• 运动框架


    运动框架演变过程
    startMove(iTarget) 运动框架
    startMove(obj, iTarget) 多物体
    startMove(obj, attr, iTarget) 任意值
    startMove(obj, attr, iTarget, fn) 链式运动
    startMove(obj, json) 多值运动
    startMove(obj, json, fn) 完美运动框架

    完美运动框架:(下面是讲解)

    
    
    function startMove(obj, json, fnEnd)//json顶替了之前iTarget的位置
    {
        clearInterval(obj.timer);
        obj.timer=setInterval(function (){

            var bStop=true; //新引进的变量 假设:所有值(width/height/opacity)都已经到达目标了 因 300, height: 101而生 即倘若两个变化差很大肉眼可见无法同时到达
            
            for(var attr in json)
            {
    //
                var cur=0;
                if(attr=='opacity')
                {
                    cur=Math.round(parseFloat(getStyle(obj, attr))*100);
                }
                else
                {
                    cur=parseInt(getStyle(obj, attr));
                }
                
                var speed=(json[attr]-cur)/6;/////这里
                speed=speed>0?Math.ceil(speed):Math.floor(speed);

                if(cur!=json[attr]) /////这里
                bStop=false;//一旦有一个json元素未达到目标 就改变变量的值
                
             if(attr=='opacity')
                {
                    obj.style.filter='alpha(opacity:'+(cur+speed)+')';
                    obj.style.opacity=(cur+speed)/100;
                }
                else
                {
                    obj.style[attr]=cur+speed+'px';
                }
    //是之前的内容(有iTarget的时候) 现在用上了json+for-in循环
            }
            
            if(bStop) //bstop为真 就是没有执行上面那个if语句 没有东西没到目标
            {
                clearInterval(obj.timer);//关掉定时器
                            
                if(fnEnd)fnEnd();//如果有函数就执行函数
            }
        }, 30);
    }
     

     完美运动框架:可以多个值同时变化

    Json+for-in+新变量(var bStop=true

     

  • 相关阅读:
    51nod 1621 花钱买车牌 优先队列
    最大字段和 51nod 1049 水水水水水水水水水水水水
    大数相乘 51nod 1027 水题
    逆序数 51nod 1019 归并 分治
    最长公共子序列 LCS 递归 dp 51Nod 1006
    vc6 字体设置
    自行车维护大全(zz)
    DirectX 9.0 3D游戏开发编程基础 [书评](zz)
    二维线段树
    latex 引用文献 bib
  • 原文地址:https://www.cnblogs.com/yundong333/p/10403456.html
Copyright © 2020-2023  润新知