zoukankan      html  css  js  c++  java
  • JS小问题之——缓冲运动

    今天写一个实现动画缓冲的效果,源代码用到了一个小技巧,之前觉得并没有什么用,后来觉得还是很有必要的,贴上来记录一下。

    代码如下:

    //图片切换,淡入淡出效果
        function show(a){
            index=a
            for(i=0;i<onum.length;i++)onum[i].className="";
            onum[index].className="current";
            clearInterval(timer);
            console.log(oimg[0].offsetHeight)
            var oimgtop=-(index*oimg[0].offsetHeight)
            timer=setInterval(function(){
                var iSpeed=(oimgtop-oul[0].offsetTop)/10;
                iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);
                oul[0].offsetTop==oimgtop?clearInterval(timer):oul[0].style.top=oul[0].offsetTop+iSpeed+"px"
            },30)
        }

    timer指向了一个周期函数是这段代码实现缓冲效果的关键,通过每30ms计算一次oimgtop,并将其与目标值的差除以10就是我们每次需要增加/减少的量,可见每次的增加/减少量是在逐渐减少的,也就实现了缓冲效果。

    但是之前我一直以为这样不是永远加不到目标值么。

    iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);

    通过Math.ceil处理我们每次的增加量,来使我们快接近目标值的时候,每次增加的量都是1或者-1,这样一步步靠近我们的目标值。

    目标值=当前值 的时候,清除timer周期函数。这里需要注意的是,目标值应该是一个整数!

  • 相关阅读:
    fzu 2122
    hdu 4707 bellman
    sicily 10330. Cutting Sausages
    湖南省2016省赛题。1809: Parenthesis 线段树
    Panoramic Photography
    B. No Time for Dragons 贪心
    The Weakest Sith
    E. The Best among Equals
    Gym 101149I I
    AtCoder D
  • 原文地址:https://www.cnblogs.com/coderzzp/p/6412935.html
Copyright © 2011-2022 走看看