如何实时获取鼠标的当前坐标

本文来做一个简单的实时获取鼠标坐标的功能,在canvas动画开发中,获取鼠标的坐标,键盘的按键等等,都是常用的操作,我们就慢慢得把他们封装成一个公共库。

一、事件的兼容:

function bindEvent(obj, event, fn) {        if (obj.attachEvent) { //ie            obj.attachEvent('on' + event, function () {                fn.call(obj);            });        } else {            //chrome&ff            obj.addEventListener(event, fn, false);        }    }

登录后复制

上面兼容ie8以及修正this关键字在ie低版本的指向,下面兼容chrome和ff。其他更常用的封装可以参考我的javascript开源框架gdom

二、用立即表达式搭建一个基本的库

添加获取鼠标坐标的方法

;(function (window) {    window.G = {};    function bindEvent(obj, event, fn) {        if (obj.attachEvent) { //ie            obj.attachEvent('on' + event, function () {                fn.call(obj);            });        } else {            //chrome&ff            obj.addEventListener(event, fn, false);        }    }    G.getPos = function( dom ){        var oPos = { x : 0, y : 0 };        bindEvent( dom, 'mousemove', function( ev ){            var oEvent = ev || event, x, y;            if ( oEvent.pageX || oEvent.pageY ){                x = oEvent.pageX;                y = oEvent.pageY;            }else {                x = oEvent.clientX + document.body.scrollLeft || document.documentElement.scrollLeft;                y = oEvent.clientX + document.body.scrollTop || document.documentElement.scrollTop;            }            x -= dom.offsetLeft;            y -= dom.offsetTop;            oPos.x = x;            oPos.y = y;        } );        return oPos;    };})(window);

登录后复制

三、引入封装的js库,绑定canvas为监听对象,打印当前鼠标的坐标

鼠标的坐标,我这里画了2根线,便于观察.

;(function (window) {    window.G = {};    function bindEvent(obj, event, fn) {        if (obj.attachEvent) { //ie            obj.attachEvent('on' + event, function () {                fn.call(obj);            });        } else {            //chrome&ff            obj.addEventListener(event, fn, false);        }    }    G.getPos = function( dom ){        var oPos = { x : 0, y : 0 };        bindEvent( dom, 'mousemove', function( ev ){            var oEvent = ev || event, x, y;            if ( oEvent.pageX || oEvent.pageY ){                x = oEvent.pageX;                y = oEvent.pageY;            }else {                x = oEvent.clientX + document.body.scrollLeft || document.documentElement.scrollLeft;                y = oEvent.clientX + document.body.scrollTop || document.documentElement.scrollTop;            }            x -= dom.offsetLeft;            y -= dom.offsetTop;            oPos.x = x;            oPos.y = y;        } );        return oPos;    };})(window);#canvas{    border:1px dashed #aaa;}window.onload = function(){    var oCanvas = document.querySelector( "#canvas" ),        oGc = oCanvas.getContext( '2d' ),        width = oCanvas.width, height = oCanvas.height,        oInfo = document.querySelector( "#info" ),        oPos = G.getPos( oCanvas );        oCanvas.addEventListener( "mousemove", function(){                        oGc.clearRect( 0, 0, width, height );            oGc.beginPath();            oGc.moveTo( oPos.x, 0 );            oGc.lineTo( oPos.x, height );            oGc.moveTo( 0, oPos.y );            oGc.lineTo( width, oPos.y );            oGc.closePath();            oGc.strokeStyle = '#09f';            oGc.stroke();            oInfo.innerHTML = '鼠标的当前坐标是:(' + oPos.x + ',' + oPos.y + ')';        }, false );}

登录后复制

以上就是如何实时获取鼠标的当前坐标 的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2909548.html

(0)
上一篇 2025年3月11日 04:22:57
下一篇 2025年3月11日 04:23:07

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论