多物體運動JavaScript函數封裝

來源:互聯網
上載者:User

標籤:turn   最好   interval   art   有一個   attr   效果   etc   getc   

function startMove(obj, json, func){
  clearInterval(obj.timer);
  obj.timer = setInterval(function(){

    var bStop = true;

    //取出該屬性的初值
    for(var attr in json){
      var iCur = 0;
      if(attr == "opacity"){
        iCur = parseFloat(getStyle(obj, attr)) * 100;
      }else{
        iCur = parseInt(getStyle(obj, attr))
      }
      var speed = (json[attr] - iCur) / 8;  //8 縮放係數,緩衝運動效果最好的縮放係數
      speed = speed > 0 ? Math.ceil(speed) : Math.floor(speed);

      //只要有一個值未達到指定值程式就不能繼續執行
      if(iCur != json[attr]){
        bStop = false;
      }
      if(attr == "opacity"){
        obj.style.filter = "alpha(opacity: " + (iCur + speed) + ")";
        obj.style.opacity = (iCur + speed) / 100;
      }else{
        obj.style[attr] = iCur + speed + "px";
      }
    }
    if(bStop){
      clearInterval(obj.timer);
      if(func){
        func();
      }
    }
  }, 30);
}

//擷取非行間樣式
function getStyle(obj, attr){
  if(obj.currentStyle){
    return obj.currentStyle[attr];  //IE9 以下
  }else{
    return getComputedStyle(obj)[attr];  //IE9 及標準瀏覽器
  }
}

多物體運動JavaScript函數封裝

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.