计算鼠标移动的精确速度

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

思路:
计算两次mousemove之间的位移和时间,就可以算出精确的速度

不要将onMousemove的调用时间间隔看成是均等的,事实上也不是均等的,而是根据机器的运行状况实时调整的,所以两次调用之间的时间间隔不能看成是单位时间。关于mousemove的讨论

示例

复制代码
    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://blog.csdn.net/ruangong1203/article/details/52474746 

posted @   笠航  阅读(378)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
点击右上角即可分享
微信分享提示