html5 canvas 画图表
(function () {
var canvas = document.createElement("canvas");
canvas.width = 800;
canvas.height = 400;
canvas.innerText = "抱歉,你的浏览器不支持canvas T_T";
document.getElementById('leoncanvas').appendChild(canvas);
var data = { "aaa": 1000, "bbb": 600, "ccc": 200, "ddd": 400, "eee": 550, "fff": 50, "ggg": 10, "hhh": 280 };
var yAxisValueStep = 100;
var width = canvas.width;
var height = canvas.height;
// data length calc & value analysis
var length = 0, min = 0, max = 0;
for (var i in data) {
length++;
if (data[i] < min)
min = data[i];
if (data[i] > max)
max = data[i];
}
var xLength = width * 0.9;
var yLength = height * 0.7;
var left = width * 0.12;
var bottom = height * 0.08;
// origin point
var x0 = left;
var y0 = height - bottom;
var p0 = { x: x0, y: y0 };
var px = { x: left + xLength, y: p0.y };
var py = { x: p0.x, y: p0.y - yLength };
var xScaleMarkWidth = xLength / (length + 3);
var yScaleMarkWidth = yLength / (length + 3);
// begin to draw axis
var context = canvas.getContext('2d');
context.beginPath();
// offset 0.5 to draw 1 pixel line
//http://kilianvalkhof.com/2010/design/the-problem-with-svg-and-canvas/
// xAxis
context.moveTo(p0.x + 0.5, p0.y + 0.5);
context.lineTo(px.x + 0.5, px.y + 0.5);
// yAxis
context.moveTo(p0.x + 0.5, p0.y + 0.5);
context.lineTo(py.x + 0.5, py.y + 0.5);
context.font = "normal lighter 12px sans-serif";
// scale marker
for (var i = 0; i < length + 2; i++) {
// xaxis
context.moveTo(p0.x + (i + 1) * xScaleMarkWidth + 0.5, p0.y + 0.5);
context.lineTo(p0.x + (i + 1) * xScaleMarkWidth + 0.5, p0.y + 2 + 0.5);
// yaxis
context.moveTo(p0.x + 0.5, p0.y - (i + 1) * yScaleMarkWidth + 0.5);
context.lineTo(p0.x + 0.5 - 2, p0.y - (i + 1) * yScaleMarkWidth + 0.5);
}
// y axis marker value
for (var i = 0; i <= length + 2; i++) {
// yaxis value
context.fillText(yAxisValueStep * i, p0.x + 0.5 - 30, p0.y - i * yScaleMarkWidth + 3);
}
// draw column chart
var lengthPerValue = (yScaleMarkWidth * (length + 2)) / max;
var rectX, rectY;
var i = 0;
for (var p in data) {
rectX = p0.x + (i + 1) * xScaleMarkWidth + 0.5 - xScaleMarkWidth * 0.25;
rectY = p0.y - lengthPerValue * data[p];
// draw column
context.fillStyle = "rgba(255,0,0,0.6)";
context.fillRect(rectX, rectY, xScaleMarkWidth / 2, lengthPerValue * data[p]);
// add text
context.fillStyle = 'rgb(0,0,0)';
// column value
context.fillText(data[p], rectX, rectY - 15);
// x value
context.fillText(p, rectX + xScaleMarkWidth * 0.1, rectY + lengthPerValue * data[p] + 20);
i++;
}
context.lineWidth = 1;
context.stroke();
context.closePath();
})();
柱状图效果如下:
(function () {
var canvas = document.createElement("canvas");
canvas.width = 800;
canvas.height = 400;
canvas.innerText = "抱歉,你的浏览器不支持canvas T_T";
document.getElementById('leoncanvas1').appendChild(canvas);
var data = { "aaa": 1000, "bbb": 600, "ccc": 200, "ddd": 400, "eee": 550, "fff": 50, "ggg": 10, "hhh": 280 };
var yAxisValueStep = 100;
var width = canvas.width;
var height = canvas.height;
// data length calc & value analysis
var length = 0, min = 0, max = 0;
for (var i in data) {
length++;
if (data[i] < min)
min = data[i];
if (data[i] > max)
max = data[i];
}
var xLength = width * 0.9;
var yLength = height * 0.7;
var left = width * 0.12;
var bottom = height * 0.08;
// origin point
var x0 = left;
var y0 = height - bottom;
var p0 = { x: x0, y: y0 };
var px = { x: left + xLength, y: p0.y };
var py = { x: p0.x, y: p0.y - yLength };
var xScaleMarkWidth = xLength / (length + 3);
var yScaleMarkWidth = yLength / (length + 3);
// begin to draw axis
var context = canvas.getContext('2d');
context.beginPath();
// offset 0.5 to draw 1 pixel line
//http://kilianvalkhof.com/2010/design/the-problem-with-svg-and-canvas/
// xAxis
context.moveTo(p0.x + 0.5, p0.y + 0.5);
context.lineTo(px.x + 0.5, px.y + 0.5);
// yAxis
context.moveTo(p0.x + 0.5, p0.y + 0.5);
context.lineTo(py.x + 0.5, py.y + 0.5);
// scale marker
for (var i = 0; i < length + 2; i++) {
// xaxis
context.moveTo(p0.x + (i + 1) * xScaleMarkWidth + 0.5, p0.y + 0.5);
context.lineTo(p0.x + (i + 1) * xScaleMarkWidth + 0.5, p0.y + 2 + 0.5);
// yaxis
context.moveTo(p0.x + 0.5, p0.y - (i + 1) * yScaleMarkWidth + 0.5);
context.lineTo(p0.x + 0.5 - 2, p0.y - (i + 1) * yScaleMarkWidth + 0.5);
}
// y axis marker value
for (var i = 0; i <= length + 2; i++) {
// yaxis value
context.fillText(yAxisValueStep * i, p0.x + 0.5 - 30, p0.y - i * yScaleMarkWidth + 3);
}
// draw column chart
var lengthPerValue = (yScaleMarkWidth * (length + 2)) / max;
//var rectX, rectY;
var x, y;
var i = 0;
context.font = "normal lighter 12px sans-serif";
// set axis text & marker
for (var p in data) {
x = p0.x + (i + 1) * xScaleMarkWidth + 0.5;
y = p0.y - lengthPerValue * data[p];
// add text
context.fillStyle = 'rgb(0,0,0)';
// point value
context.fillText(data[p], x, y - 15);
// x value
context.fillText(p, x + xScaleMarkWidth * 0.1, y + lengthPerValue * data[p] + 20);
i++;
}
context.stroke();
context.closePath();
context.beginPath();
context.strokeStyle = "rgba(255,0,0,0.8)";
context.lineCap = "square";
context.lineJoin = "miter";
context.lineWidth = 2;
i = 0;
for (var p in data) {
x = p0.x + (i + 1) * xScaleMarkWidth + 0.5;
y = p0.y - lengthPerValue * data[p];
if (i == 0) {
context.moveTo(x, y);
}
else {
context.lineTo(x, y);
}
i++;
}
context.stroke();
context.closePath();
})();
折线图效果如下:
html5 canvas 画图表的更多相关文章
- 怎样用JavaScript和HTML5 Canvas绘制图表
原文:https://code.tutsplus.com/zh-...原作:John Negoita翻译:Stypstive 在这篇教程中,我将展示用JavaScript和canvas作为手段,在饼状 ...
- HTML5 Canvas 画虚线组件
前段时间由于项目需要,用到了HTML5 Canvas画图,但是没有画虚线的方法,自己写了一个HTML5 画虚线的组件. dashedLine.js if (window.CanvasRendering ...
- HTML5 Canvas 画钟表
画钟表是2D画图的老生常谈,我也不能免俗弄了一个.代码如下: <!DOCTYPE html> <html lang="utf-8"> <meta ht ...
- CSS3进度条 和 HTML5 Canvas画圆环
看到一些高大上的进度条插件,然后想自己用CSS写.经过搜索资料之后,终于成功了.为了以后方便拿来用,或者复习.将代码贴出. HTML代码: 只需要两个div,外面的为一个有border的div id为 ...
- html5 canvas画饼
1. [图片] lxdpie.jpg 2. [文件] lqdpie.html ~ 801B 下载(7) <!DOCTYPE HTML PUBLIC "-//W3C//DTD ...
- html5 canvas画不出图像的原因
很久没写博客了,今年过年的时候,家里出了意外,现在心里依然很难受.6月份之前一直忙着写毕业论文,答辩完6月初回公司继续上班,今天刚好周末有空,就写下之前碰到一个问题. 做一个图像查看器(基于Chrom ...
- html5 canvas画流程图
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- HTML5 Canvas画数字时钟
先不说废话,没代码算个蛋. 一些地方注释都写得比较清楚,不过这只是部分,因为只有秒针,但是时针,分针的逻辑都是一致的. 代码中有些坐标不知道为什么较不准,看看就好
- html5 canvas画进度条
这个ie8的兼容是个问题,ie8 的innerHTML有问题啊,添加两个附件吧 <!DOCTYPE html> <html> <head> <meta cha ...
随机推荐
- XPath注入跟SQL注入差不多,只不过这里的数据库走的xml格式
SQL注入这块不想细聊了,相信很多朋友都听到耳朵长茧,不外乎是提交含有SQL操作语句的信息给后端,后端如果没有做好过滤就执行该语句,攻击者自然可以随意操纵该站点的数据库. 比如有一个图书馆站点book ...
- Git生成ssh ksy后进行项目管理
1.首先你要有一个git账号,然后在网站上Create a New Repository,填好名称后就建立了一个仓库,之后即会出现一些仓库的配置信息... 2.然后你要下载一个git客户端,也可以是m ...
- 一步步学习javascript基础篇(5):面向对象设计之对象继承(原型链继承)
上一篇介绍了对象创建的几种基本方式,今天我们看分析下对象的继承. 一.原型链继承 1.通过设置prototype指向“父类”的实例来实现继承. function Obj1() { this.name1 ...
- Curator Framework的基本使用方法
Curator Framework提供了简化使用zookeeper更高级的API接口.它包涵很多优秀的特性,主要包括以下三点: 自动连接管理:自动处理zookeeper的连接和重试存在一些潜在的问题: ...
- 剑指Offer面试题:8.斐波那契数列
一.题目:斐波那契数列 题目:写一个函数,输入n,求斐波那契(Fibonacci)数列的第n项.斐波那契数列的定义如下: 二.效率很低的解法 很多C/C++/C#/Java语言教科书在讲述递归函数的时 ...
- 细说ES7 JavaScript Decorators
开篇概述 在上篇的ES7之Decorators实现AOP示例中,我们预先体验了ES7的Decorators,虽然它只是一个简单的日志AOP拦截Demo.但它也足以让我们体会到ES7 Decorator ...
- 【Java并发编程实战】-----“J.U.C”:Condition
在看Condition之前,我们先来看下面这个例子: 工厂类,用来存放.取出商品: public class Depot { private int depotSize; //仓库大小 private ...
- 使用border做三角形
网站上经常会使用一些三角形,除了图片的方式,实际上利用border我们可以做出纯CSS的三角形.我们知道border是个边抖可以单独设置,当四个边相交的时候他们是什么时候改变的? .t0{ margi ...
- 《Entity Framework 6 Recipes》中文翻译系列 (22) -----第五章 加载实体和导航属性之延迟加载
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 第五章 加载实体和导航属性 实体框架提供了非常棒的建模环境,它允许开发人员可视化地使 ...
- Thrift架构~目录
回到占占推荐博客索引 概念相关 thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ru ...