canvas 绘点图

项目中需要一个记录点实时变动的信息,在此记录一下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<script src="http://cdn.bootcss.com/jquery/3.0.0-beta1/jquery.min.js"></script>
</head> <body>
<canvas id="myCanvas2" class="pointCanvas" width="950" height="650"></canvas>
<canvas id="myCanvas" class="pointCanvas" width="950" height="650"></canvas>
<script type="text/javascript">
var data1 = {
"code": 0,
"msg": "Get complete!",
"data": {
"d3:35:c5:e7:62:27": [369.92, 425.31],
"20:29:73:d7:09:37": [575.07, 192.57],
}
}
jQuery(function() {
$.fn.extend({ // 将可选择的变量传递给方法
runingPoint: function(options) {
return this.each(function() {
var __this = this;
// console.log($(this));
var runingPoint = {
// 参数配置
options: {
// c: $(__this),
radius: 10,
url: null,
imgUrl: null,
points: [],
selectedCircle: null,
hoveredCircle: null
}, // 初始化方法
init: function(config) {
var _this = this,
o = this.options;
$.extend(true, _this.options, config);
console.log(_this.options);
// 第一次执行
_this.getData();
_this.eventsFn(); // 每5秒执行一次
setInterval(function() {
o.hoveredCircle = undefined;
_this.getData();
}, 5000); // 测试数据 start
// setInterval(function(){ // var arrData = [];
// var D = data1.data;
// o.hoveredCircle = undefined;
// for(var i in D){
// arrData.push({x:D[i][0],y:D[i][1],name:i})
// }
// // console.log('init',arrData); // _this.drawFn(arrData);
// }, 5000);//测试数据 end }, // 获取数据
getData: function() {
var _this = this,
o = this.options;
var arrData = [];
$.getJSON(o.url, function(data) {
// console.log('getData',data);
if (data.code == 0) {
var D = data.data;
for (var i in D) {
arrData.push({
x: D[i][0],
y: D[i][1],
name: i
})
}
// 调用绘图方法
_this.drawFn(arrData); }
});
}, //清除canvas
clear: function() {
var _this = this,
o = this.options;
var ctx = __this.getContext("2d");
ctx.clearRect(0, 0, ctx.canvas.width, ctx.canvas.height);
}, // 获取点的信息
getPointInfoFn: function(p) {
var _this = this,
o = this.options; console.log('getPointInfoFn', JSON.stringify(p)); // $.getJSON('/path/to/file', {param1: 'value1'}, function(json, textStatus) { // });
}, // 事件绑定
eventsFn: function() {
var _this = this,
o = this.options;
// 红点click事件
$(__this).on('click', function(e) {
var e = window.event || e
var rect = this.getBoundingClientRect();
var mouseX = e.clientX - rect.left; //获取鼠标在canvsa中的坐标
var mouseY = e.clientY - rect.top; o.hoveredCircle = undefined;
for (var i = 0; i < o.points.length; i++) { // 检查每一个圆,看鼠标是否滑过
var circleX = o.points[i].x;
var circleY = o.points[i].y;
var radius = o.radius;
if (Math.pow(mouseX - circleX, 2) + Math.pow(mouseY - circleY, 2) < Math.pow(radius, 2)) {
o.hoveredCircle = i;
// console.log('click',o.points[i]);
// 获取点信息
_this.getPointInfoFn(o.points[i]);
//点击放大
_this.drawFn(o.points);
break;
}
}
}); }, // 绘图方法
drawFn: function(data) {
var _this = this,
o = this.options;
var D = data;
var ctx = __this.getContext("2d");
var img = document.createElement('img');
img.src = o.imgUrl;
o.points = [];
_this.clear();
if(!o.imgUrl){
drawPointFn();
return;
}
img.onload = function() {
drawPointFn();
}
function drawPointFn(){
ctx.drawImage(img, 0, 0);
ctx.fillStyle = "#FF0000";
// console.log(D);
for (var i in D) {
// 记录点的数据
o.points.push({
x: D[i].x,
y: D[i].y,
name: D[i].name
}); ctx.beginPath();
ctx.arc(D[i].x, D[i].y, i == o.hoveredCircle ? o.radius * 1.5 : o.radius, 0, Math.PI * 2, true); //Math.PI*2是JS计算方法,是圆
ctx.closePath();
ctx.fill();
}
}
} }; // runingPoint End
console.log(options)
runingPoint.init(options); });
}
}); //extend end // 初始化
$(".pointCanvas").runingPoint({
radius: 10,
imgUrl: './img/img.jpg',
url: 'data.json'
}); })
</script>
</body> </html>

下载demo:http://pan.baidu.com/s/1jHjeHRw

canvas 绘点图的更多相关文章

  1. 第166天:canvas绘制饼状图动画

    canvas绘制饼状图动画 1.HTML <!DOCTYPE html> <html lang="en"> <head> <meta ch ...

  2. canvas绘制饼型图

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

  3. [canvas]用canvas绘制饼状图

    折线图之后又来饼状图啦~\(≧▽≦)/~啦啦啦 <!DOCTYPE html> <html lang="en"> <head> <meta ...

  4. HTML5 Canvas绘文本动画(使用CSS自定义字体)

    一.HTML代码: <!DOCTYPE html> <html> <head> <title>Matrix Text - HTML5 Canvas De ...

  5. canvas 绘圆加边框

    HTML5中canvas元素,绘制圆形需要使用路径,开始时要取得图形上下文,首先使用路径来勾勒图形的轮廓,然后设置颜色,进行绘制. arc(cx,cy,radius,start_angle,end_a ...

  6. 使用canvas绘制饼状图

    <!doctype html><html lang="en"><head> <meta charset="UTF-8" ...

  7. canvas绘制中的API

    canvas绘制Z 先贴代码吧: /** * Created by Administrator on 2016/1/26. */ var i; function draw (id){ var canv ...

  8. HTML5 Canvas JavaScript库 Fabric.js 使用经验

    首先,表明我的态度:采用 Flash 才是最优方案,不建议使用 HTML 5 的 Canvas 做一些生产/工业级的网页应用. Flash的优势一是浏览器支持好,二是代码成熟稳定.而HTML5 的 C ...

  9. canvas二三事之签名板与视频绘制

    今天,不知道怎么的就点开了语雀,然后就看到了<HTML5 Canvas 教程>,开始了canvas的研究(学习)之旅. 首先,想到的第一个东西就是签名板,上代码: <canvas i ...

随机推荐

  1. 1.6.1 什么是 Indexing

    这部分描述了建立索引的过程:添加内容到solr索引中,如果有需要,修改内容或者删除它.通过添加内容到索引里边,我们使其内容可以搜索. solr索引能够接收不同来源的数据,xml文件,逗号分隔值的(CV ...

  2. Handle类的用法

    android中Handle类的用法 当我们在处理下载或是其他需要长时间执行的任务时,如果直接把处理函数放Activity的OnCreate或是OnStart中,会导致执行过程中整个Activity无 ...

  3. nodejs的mysql模块学习(九)连接池集群

    连接池集群 连接池集群可以提供多个主机连接 创建连接池集群 //创建连接池集群 var poolCluster = mysql.createPoolCluster(); //添加配置 config是一 ...

  4. 用英文加优先级来解读C的声明

    比如:int ( * func_p ) ( double ); 首先着眼于标识符. func_p is 因为存在括号,(* func_p) 先被处理,这里着眼于* func_p is a pointe ...

  5. extjs 简单入门

    中文网站:http://extjs.org.cn/ 英文网站:http://www.sencha.com/products/extjs/ 1.简介 extJS是一种主要用于创建前端用户界面,是一个基本 ...

  6. flexpaper 在线观看 PPT,PDF,DOC等文档

    0.安装环境.可以参考http://www.cnblogs.com/star-studio/archive/2011/12/09/2281807.html     百度关键字 仿百度文库方案 1.借用 ...

  7. 最初步的正则表达式引擎:生成nfa

    这个版本修改了前面版本的两个个bug. 第一个:识别到字符集的时候,只是将name_number加1,却并不对reg_pattern_table[name_number]进行初始化. 第二个:识别到假 ...

  8. UIActionSheet警告,提示调用showFromTabBar方法

    UIActionSheet *actionSheet = [[UIActionSheet alloc]initWithTitle:@"选择图片" delegate:(self) c ...

  9. 使用Boost asio实现同步的TCP/IP通信

    可以先了解一下Boost asio基本概念,以下是Boost asio实现的同步TCP/IP通信: 服务器程序部分,如果想保留套接字之后继续通信,可以动态申请socket_type,保存指针,因为so ...

  10. 文件上传利器SWFUpload入门简易教程

    凡做过网站开发的都应该知道表单file的确鸡肋. Ajax解决了不刷新页面提交表单,但是却没有解决文件上传不刷新页面,当然也有其它技术让不刷新页面而提交文件,该技术主要是利用隐藏的iFrame, 较A ...