计算鼠标移动的精确速度

站长手记 作者: 2024-08-28 01:55:01
要达到无论在什么机器上,算出来的速度是一样的。计算两次mousemove之间的位移和时间,就可以算出精确的速度,不要将onMousemove的调用时间间隔看成是均等的,事实上也不是均等的
var preX = 0;
    var preTime  = undefined;
    document.addEventListener("mousedown",onMouseDown);


    function onMouseDown(event){
        preTime = undefined;
        document.addEventListener("mousemove",getVolecity);
        document.addEventListener("mouseup",onMouseUp);
    }

    function onMouseUp(event){
        document.removeEventListener("mousemove",getVolecity);
    }


    /**
     * 计算速度
     * @param event
     */
    function getVolecity(event){
        var currTime = Date.now();
        if(typeof preTime != "undefined"){    //跳过第一次
            var dist = event.clientX - preX;
            var time = currTime - preTime;
            var volecity = dist/time;   
            console.log("volecity:"+volecity);
        }
        preX = event.clientX;
        preTime = currTime;
 }
原创声明
本站部分文章基于互联网的整理,我们会把真正“有用/优质”的文章整理提供给各位开发者。本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
本文链接:http://www.jiecseo.com/news/show_69867.html
鼠标移动 js