欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

javascript的惯性运动实现代码实例

程序员文章站 2023-11-03 14:21:22
移动端的惯性运动,最早来自 ios 的专利。用于手指滑动,离开屏幕之后,屏幕内容继续滚动。更有动态感。 这里,以 pc 端,鼠标横向(沿x轴) 拖拽的,惯性计算。移动端同...

移动端的惯性运动,最早来自 ios 的专利。用于手指滑动,离开屏幕之后,屏幕内容继续滚动。更有动态感。

这里,以 pc 端,鼠标横向(沿x轴) 拖拽的,惯性计算。移动端同理

效果

javascript的惯性运动实现代码实例

代码如下

<!doctype html>
<html lang="zh">
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="x-ua-compatible" content="ie=edge">
  <title>惯性运动</title>
  <style type="text/css">
    #box{
      background: pink;
      width: 100px;
      height: 100px;
      position: absolute;
      top: 100px;
      left: 100px;
    }
  </style>
</head>
<body>
  <div id="box"></div>
</body>
<script type="text/javascript">
  var $box = document.getelementbyid("box");
   
  var isdown = false; //是否按下鼠标
  var inertance = 1.2; //惯性系数,越大,惯性越不明显,不能小于0
  var fv = 0; //滑动的力度
  var timer = null;
  $box.onmousedown = function(e){
    cleartimeout(timer);//清除定时器
    fv = 0;
    this._start = e.clientx; //鼠标按下的位置
    isdown = true;//鼠标是否有按下,主要防止用户是从容器外开始滑动的
  }
   
  $box.onmousemove = function(e){
    if(isdown){
      var miss = e.clientx - this._start;
      movemiss(miss)
      this._start = e.clientx;
      fv = miss;
    }
  }
   
  function movemiss(miss){
    $box.style.left = miss + $box.offsetleft + "px";
  }
   
  window.onmouseup = function(e){
    if(isdown){
      isdown = false;
      var me = this;
      var friction = ((fv >> 31) * 2 + 1) * inertance;//根据力度套用公式计算出惯性大小,公式要记住
      var num = math.abs(friction);
      timer = setinterval(function(){
         fv -= friction;//力度按 惯性的大小递减
         movemiss(fv);
         if(math.abs(fv) < num){ //如果力度减小到小于1了,结束,或者边界弹回
           clearinterval(timer);
           return ;
         }
      },20);
    }
  }
   
</script>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。