有了前面的canvas基础之后,现在开始就精彩了,后面写的canvas教程都是属于综合应用,前面已经写了常用的canvas基础知识,参考链接如下:

[js高手之路] html5 canvas系列教程 - 认识canvas以及基本使用方法

[js高手之路] html5 canvas系列教程 - 掌握画直线图形的常用API

[js高手之路] html5 canvas系列教程 - 开始路径beginPath与关闭路径closePath详解

[js高手之路] html5 canvas系列教程 - arc绘制曲线图形(曲线,弧线,圆形)

[js高手之路] html5 canvas系列教程 - arcTo(弧度与二次,三次贝塞尔曲线以及在线工具)

[js高手之路] html5 canvas系列教程 - 线条样式(lineWidth,lineCap,lineJoin,setLineDash)

[js高手之路] html5 canvas系列教程 - 文本样式(strokeText,fillText,measureText,textAlign,textBaseline)

[js高手之路] html5 canvas系列教程 - 图片操作(drawImage,clip,createPattern)

[js高手之路] html5 canvas系列教程 - 状态详解(save与restore)

[js高手之路] html5 canvas系列教程 - 像素操作(反色,黑白,亮度,复古,蒙版,透明)

[js高手之路] html5 canvas系列教程 - 线形渐变,径向渐变与阴影设置

[js高手之路] html5新增的定时器requestAnimationFrame实战进度条

本文来做一个简单的实时获取鼠标坐标的功能,在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根线,便于观察.

 <head>
<meta charset='utf-8' />
<script>
;(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);
</script>
<style>
#canvas{
border:1px dashed #aaa;
}
</style>
<script>
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 );
}
</script>
</head>
<body>
<canvas id="canvas" width="500" height="400"></canvas>
<div id="info"></div>
</body>

四、点击'run code'可以预览效果额

<head>
<meta charset='utf-8' />
<script>
;(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);
</script>
<style>
#canvas{
border:1px dashed #aaa;
}
</style>
<script>
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 );
}
</script>
</head>
<body>
<canvas id="canvas" width="500" height="400"></canvas>
<div id="info"></div>
</body>
run code

[js高手之路] html5 canvas动画教程 - 实时获取鼠标的当前坐标的更多相关文章

  1. [js高手之路]html5 canvas动画教程 - 边界判断与小球粒子模拟喷泉,散弹效果

    备注:本文后面的代码,如果加载了ball.js,那么请使用这篇文章[js高手之路] html5 canvas动画教程 - 匀速运动的ball.js代码. 本文,我们要做点有意思的效果,首先,来一个简单 ...

  2. [js高手之路]html5 canvas动画教程 - 边界判断与反弹

    备注:本文后面的代码,如果加载了ball.js,那么请使用这篇文章[js高手之路] html5 canvas动画教程 - 匀速运动的ball.js代码. 边界反弹: 当小球碰到canvas的四个方向的 ...

  3. [js高手之路]html5 canvas动画教程 - 下雪效果

    利用canvas,实现一个下雪的效果,我们先预览下效果: 我们先分析下这个效果: 1,随机产生雪花 2,雪花的产生不是同时产生,而是有先后顺序的 3,雪花怎么表示 4,怎么源源不断的下雪 5,雪花有大 ...

  4. [js高手之路]html5 canvas动画教程 - 跟着鼠标移动消失的一堆炫彩小球

    综合利用前面所学,实现一个绚丽的小球动画,这个实例用到的知识点,在我的博客全部都有,可以去这里查看所有的canvas教程 <head> <meta charset='utf-8' / ...

  5. [js高手之路] html5 canvas动画教程 - 匀速运动

    匀速运动:指的是物体在一条直线上运动,并且物体在任何相等时间间隔内通过的位移都是相等的.其实就是匀速直线运动,它的特点是加速度为0,从定义可知,在任何相等的时间间隔内,速度大小和方向是相同的. < ...

  6. [js高手之路]html5 canvas动画教程 - 自己动手做一个类似windows的画图软件

    这个绘图工具,我还没有做完,不过已经实现了总架构,以及常见的简易图形绘制功能: 1,可以绘制直线,圆,矩形,正多边形[已完成] 2,填充颜色和描边颜色的选择[已完成] 3,描边和填充功能的选择[已完成 ...

  7. [js高手之路]html5 canvas动画教程 - 重力、摩擦力、加速、抛物线运动

    上节,我们讲了匀速运动,本节分享的运动就更有意思了: 加速运动 重力加速度 抛物线运动 摩擦力 加速运动: <head> <meta charset='utf-8' /> &l ...

  8. [js高手之路] html5 canvas系列教程 - 状态详解(save与restore)

    本文内容与路径([js高手之路] html5 canvas系列教程 - 开始路径beginPath与关闭路径closePath详解)是canvas中比较重要的概念.掌握理解他们是做出复杂canvas动 ...

  9. [js高手之路] html5 canvas系列教程 - 掌握画直线图形的常用API

    我们接着上文[js高手之路] html5 canvase系列教程 - 认识canvas以及基本使用方法继续. 一.直线的绘制 cxt.moveTo( x1, y1 ): 将画笔移动到x1, y1这个点 ...

随机推荐

  1. Js原生轮播-直接上代码

    <!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8&qu ...

  2. Day2 - Linux发展史

    第1章 Linux发展史 1.1 什么是操作系统 操作系统是人与计算机硬件的一个中介. 1.2 操作系统组成 操作系统类似与鸡蛋 蛋壳--------->系统中各种各样的软件 蛋清------- ...

  3. win10下移动硬盘位置不可用无法访问

    win10下移动硬盘位置不可用无法访问 网上搜索得到的答案是: 请参考以下步骤解决: 1.按Windows+R输入"CHKDSK H: /F /R"(H:是硬盘所在盘符./R 找到 ...

  4. hdu 6199 沈阳网络赛---gems gems gems(DP)

    题目链接 Problem Description Now there are n gems, each of which has its own value. Alice and Bob play a ...

  5. svn status详解

    svn 是在提交前查看本地文本和版本库里面的文件的区别.返回值有许多种具体含义如下: [url=]  L    abc.c               # svn已经在.svn目录锁定了abc.c M ...

  6. [转]Java7中的ForkJoin并发框架初探(中)——JDK中实现简要分析

    详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp85   根据前文描述的Doug Lea的理论基础,在JDK1.7中已经给 ...

  7. mha 复制检查报错“There is no alive server. We can't do failover”

    安装mha所参考的文章: http://linzhijian.blog.51cto.com/1047212/1906434 http://www.cnblogs.com/xiaoboluo768/p/ ...

  8. Wireshark抓包TCP三次握手数据

    抓包工具 - Wireshark(详细介绍与TCP三次握手数据分析) 功能使用的详细介绍 wireshark(官方下载网站: http://www.wireshark.org/),是用来获取网络数据封 ...

  9. 三种计算c#程序运行时间的方法

    三种计算c#程序运行时间的方法 第一种: 利用 System.DateTime.Now // example1: System.DateTime.Now method DateTime dt1 = S ...

  10. idea插件之——在markdown复制粘贴图片

    Markdown paste image 每次在idea的markdown中要粘贴图片的时候,要么复制链接,要么需要将软件手动上传到七牛云,本人根据了holgerbrandl/pasteimages这 ...