有了前面的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. [2014-11-11]使用Owin中间件搭建OAuth2.0认证授权服务器

    前言 这里主要总结下本人最近半个月关于搭建OAuth2.0服务器工作的经验.至于为何需要OAuth2.0.为何是Owin.什么是Owin等问题,不再赘述.我假定读者是使用Asp.Net,并需要搭建OA ...

  2. jsp页面附件上传暂存的处理

    有没有遇到页面是新建一个新对象,对象里面需要上传附件,但是只有当对象保存时才将附件一同上传到数据库的情况? 这种情况的处理可以参考狐狸的思路: @jsp页面创建一个botton bn,该button的 ...

  3. Java Integer封装类的IntegerCache内部类

    个人理解,不喜勿喷,欢迎指正. 首先看下面这段代码,猜一下输出结果是什么 Integer a = 10; Integer b = 10; System.out.println(a == b); a = ...

  4. JS中的事件以及DOM 操作

    [DOM树节点] DOM节点分为三大节点:元素节点,文本节点,属性节点. 文本节点,属性节点为元素节点的两个子节点通过getElment系列方法,可以去到元素节点 [查看节点] 1 document. ...

  5. chrome开发工具指南(三)

    Security 面板 使用 Security Overview 可以立即查看当前页面是否安全. 检查各个源以查看连接和证书详情(安全源)或找出具体哪些请求未受保护(非安全源). Security O ...

  6. Mac上安装openCV(Java版本)

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt410 Install and use OpenCV 3.0 on Mac O ...

  7. js函数防抖、节流实现

    防抖 Debounce 函数防抖就是,延迟一段时间再执行函数,如果这段时间内又触发了该函数,则延迟重新计算: // 简单实现 function debounce(fn, wait) { let t r ...

  8. 编程零基础应当如何开始学习 Python?

    提前说一下,这篇福利多多,别的不说,直接让你玩回最有手感的怀旧游戏,参数贴图很方便自己可以根据喜好修改哦. 本篇通过以下四块展开,提供大量资源对应. 选一个好版本 有没有看过<在下坂本,有何贵干 ...

  9. SwaggerUI笔记

    关于 Swagger Swagger能成为最受欢迎的REST APIs文档生成工具之一,有以下几个原因: Swagger 可以生成一个具有互动性的API控制台,开发者可以用来快速学习和尝试API. S ...

  10. 1001.A+B Format (20)的解题

    关于A+B的正确打开方式! 解题思路 gitub 也是研究了很久才学会了本地上传,中间还遇到一些问题,多亏学长的教程跟搜索引擎的帮忙解决啦! 我想还是了解题目的意思是解题的最关键,通过了查词软件跟自身 ...