计算鼠标移动的精确速度

摘要:要达到无论在什么机器上,算出来的速度是一样的。计算两次mousemove之间的位移和时间,就可以算出精确的速度,不要将onMousemove的调用时间间隔看成是均等的,事实上也不是均等的

效果
要达到无论在什么机器上,算出来的速度是一样的。


思路
计算两次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;
 }


本文内容仅供个人学习、研究或参考使用,不构成任何形式的决策建议、专业指导或法律依据。未经授权,禁止任何单位或个人以商业售卖、虚假宣传、侵权传播等非学习研究目的使用本文内容。如需分享或转载,请保留原文来源信息,不得篡改、删减内容或侵犯相关权益。感谢您的理解与支持!

链接: https://shenqiku.cn/article/FLY_2030