前段时间看了某个平台的后台,发现订单显示使用的canvas进行绘画(插件echarts),直观,明了的表达出了订单的走势如下

所以自己心痒痒的,就自己模仿了一个-->贴上代码

 <style>
#canvasmain{position: relative;width: 1000px;height: 500px;}
#canvas{position: absolute;top: 0;left: 0;}
#canvassub{position: absolute}
#tip{position: absolute;min-width: 50px;max-width: 70px;background-color: rgba(0, 0, 0, 0.77);color: #fff;text-align: center;border-radius: 6px;-webkit-border-radius: 6px;-moz-border-radius: 6px;pointer-events: none;}
#a,#b{cursor:pointer;}
</style>
<div id="canvasmain">
<canvas id="canvas">
你的浏览器居然不支持Canvas?!赶快换一个吧!!
</canvas>
<canvas id="canvassub"></canvas>
<div id="tip"></div>
</div> <div>
<p id="line">折线图</p>
<p id="bar">条形图</p>
</div>
<script>
function createCanvas() {
var canvas = document.getElementById("canvas");
canvas.width = 1000;
canvas.height = 500;
var context = canvas.getContext("2d");
if (!canvas.getContext)
return; this.json = [
{ key: 1, "number": 0 },
{ key: 2, "number": 14 },
{ key: 3, "number": 25 },
{ key: 4, "number": 1 },
{ key: 5, "number": 98 },
{ key: 6, "number": 11 },
{ key: 7, "number": 21 },
{ key: 8, "number": 32 },
{ key: 9, "number": 23 },
{ key: 10, "number": 36 },
{ key: 11, "number": 1 },
{ key: 12, "number": 52 },
{ key: 13, "number": 65 },
{ key: 14, "number": 45 },
{ key: 15, "number": 86 },
{ key: 16, "number": 10 },
{ key: 17, "number": 45 },
{ key: 18, "number": 54 },
{ key: 19, "number": 35 },
{ key: 20, "number": 10 },
{ key: 21, "number": 64 },
{ key: 22, "number": 45 },
{ key: 23, "number": 35 },
{ key: 24, "number": 23 },
{ key: 25, "number": 24 },
{ key: 26, "number": 10 },
{ key: 27, "number": 43 },
{ key: 28, "number": 66 },
{ key: 29, "number": 25 },
{ key: 30, "number": 44 },
{ key: 31, "number": 100 }
]; this.arrnumber = [];
this.maxnumber = 0;
this.wframe = 100;
this.hframe = 50;
this.wlocation = canvas.width - 100;
this.hlocation = canvas.height - 100;
this.wlocationAverage = this.wlocation / this.json.length; this.moduleArrNumber = function (type) {
for (var i = 0, j = this.json.length; i < j; i++) {
this.arrnumber.push(this.json[i].number);
}
if (type === 'max')
return Math.max.apply(null, this.arrnumber);
else
return Math.min.apply(null, this.arrnumber);
}
this.type = 'line'; var canvassub = document.getElementById("canvassub");
canvassub.width = this.wlocation;
canvassub.height = this.hlocation;
var contextsub = canvassub.getContext("2d");
canvassub.style.top = this.hframe + "px";
canvassub.style.left = this.wframe + "px"; if (typeof this.moduleCanvas != 'function') {
createCanvas.prototype.moduleCanvas = function () {
context.fillStyle = "black";
context.font = "30px Arial";
context.textAlign = "left";
context.textBaseline = "alphabetic";
context.fillText("9月份订单", 10, 30);
context.strokeStyle = '#9D9D9D';
context.lineWidth = 1;
context.font = "italic small-caps bold 14px Arial";
for (var i = 0; (k = i * (this.hlocation / 10)) <= this.hlocation; i++) {
this.moduleArrNumber('max') > 10 ? (this.moduleArrNumber('max') > 100 ? (this.moduleArrNumber('max') > 1000 ? (this.moduleArrNumber('max') > 1000 ? this.maxnumber = 10000 : this.maxnumber = 1000) : this.maxnumber = 100) : this.maxnumber = 10) : this.maxnumber = 1;
context.beginPath();
context.moveTo(this.wframe, k + this.hframe);
context.lineTo(this.wlocation + this.wframe, k + this.hframe);
context.stroke();
context.textBaseline = "middle";
context.fillText((10 - i) * this.maxnumber, this.wframe - 50, k + this.hframe);
}
for (var j = 0; (k = j * ((this.wlocation - 1) / this.json.length)) <= this.wlocation; j++) {
context.beginPath();
context.moveTo(k + this.wframe, this.hframe);
context.lineTo(k + this.wframe, this.hlocation + this.hframe);
context.stroke();
if (this.json.length > j)
context.textAlign = "center",context.fillText(this.json[j].key, k + (this.wlocationAverage / 2 + this.wframe), this.hlocation + this.hframe + 40);
}
}
} if (typeof this.lineChart != 'function') {
createCanvas.prototype.lineChart = function () {
this.type = 'line';
context.strokeStyle = 'red';
context.lineWidth = 2;
var tenmaxnumber = this.maxnumber * 10;
for (var i = 0; i < this.json.length; i++) {
context.beginPath();
context.moveTo(i * this.wlocationAverage + (this.wlocationAverage / 2 + this.wframe), (1 - (this.json[i].number / tenmaxnumber)) * this.hlocation + this.hframe);
if (this.json.length > i + 1)
context.lineTo((i + 1) * this.wlocationAverage + (this.wlocationAverage / 2 + this.wframe), (1 - (this.json[i + 1].number / tenmaxnumber)) * this.hlocation + this.hframe);
context.stroke(); context.fillStyle = 'black';
context.textAlign = "center";
context.fillText(this.json[i].number, i * this.wlocationAverage + (this.wlocationAverage / 2 + this.wframe), (1 - (this.json[i].number / tenmaxnumber)) * this.hlocation + this.hframe - 5); context.beginPath();
context.fillStyle = "green";
context.arc(i * this.wlocationAverage + (this.wlocationAverage / 2 + this.wframe), (1 - (this.json[i].number / tenmaxnumber)) * this.hlocation + this.hframe, 3, 0, 360, false);
context.fill();
context.closePath();
}
}
} if (typeof this.barChart != 'function') {
createCanvas.prototype.barChart = function () {
this.type = 'bar';
var tenmaxnumber = this.maxnumber * 10;
for (var i = 0; i < this.json.length; i++) {
context.beginPath();
context.fillStyle = "#F00";
context.fillRect(i * this.wlocationAverage + (this.wlocationAverage / 4 + this.wframe), this.hlocation + this.hframe, this.wlocationAverage / 2, -(this.json[i].number / tenmaxnumber) * this.hlocation);
context.closePath();
context.fillStyle = 'black';
context.textAlign = "center";
context.fillText(this.json[i].number, i * this.wlocationAverage + (this.wlocationAverage / 2 + this.wframe), (1 - (this.json[i].number / tenmaxnumber)) * this.hlocation + this.hframe - 5);
}
}
} if (typeof this.clearRect != 'function') {
createCanvas.prototype.clearRect = function () {
context.clearRect(0, 0, canvas.width, canvas.height);
contextsub.clearRect(0,0,canvassub.width,canvassub.height);
}
}
} var cc = new createCanvas();
cc.moduleCanvas();
cc.lineChart(); var position = 0, positionchange = 0;
var canvassub = document.getElementById("canvassub");
var contextsub = canvassub.getContext("2d");
var tip = document.getElementById("tip"); document.getElementById("canvassub").onmousemove = function (e) {
var e = e || window.event;
if (e.offsetX > cc.wframe || e.offsetY > cc.hframe) {
positionchange = Math.floor(e.offsetX / cc.wlocationAverage);
tip.style.display = "block";
tip.innerText = '今天共有' + cc.json[Math.floor(e.offsetX / cc.wlocationAverage)].number + '张订单';
tip.setAttribute("style", "top:" + (cc.hlocation - (cc.json[Math.floor(e.offsetX / cc.wlocationAverage)].number / (cc.maxnumber * 10)) * cc.hlocation) + "px;left:" + (parseFloat(Math.floor(e.offsetX / cc.wlocationAverage) + 0.5) * cc.wlocationAverage + cc.wframe) + "px;padding: 3px;");
if (cc.type === 'line' && position !== positionchange) {
contextsub.clearRect(0,0,cc.wlocation,cc.hlocation);
contextsub.beginPath();
contextsub.fillStyle = "blue";
contextsub.arc((parseFloat(Math.floor(e.offsetX / cc.wlocationAverage) + 0.5) * cc.wlocationAverage), (cc.hlocation - (cc.json[Math.floor(e.offsetX / cc.wlocationAverage)].number / (cc.maxnumber * 10)) * cc.hlocation), 4, 0, 360, false);
contextsub.fill();
contextsub.closePath();
position = Math.floor(e.offsetX / cc.wlocationAverage);
}
else if (cc.type === 'bar' && position !== positionchange) {
contextsub.clearRect(0, 0, cc.wlocation, cc.hlocation);
contextsub.beginPath();
contextsub.fillStyle = "blue";
contextsub.fillRect((parseFloat(Math.floor(e.offsetX / cc.wlocationAverage) + 0.25) * cc.wlocationAverage), canvassub.height, cc.wlocationAverage * 0.5, -(cc.json[Math.floor(e.offsetX / cc.wlocationAverage)].number / cc.maxnumber / 10) * cc.hlocation);
contextsub.closePath();
position = Math.floor(e.offsetX / cc.wlocationAverage);
}
}
}
document.getElementById("canvassub").onmouseout = function () {
tip.style.display = "none";
} document.getElementById("line").onclick = function () {
cc.clearRect();
cc.moduleCanvas();
setTimeout('cc.lineChart()',300);
}
document.getElementById("bar").onclick = function () {
cc.clearRect();
cc.moduleCanvas();
setTimeout('cc.barChart()', 300);
}
</script>

效果如下

参考教材:http://blog.csdn.net/clh604/article/details/8536059 http://www.w3school.com.cn/tags/html_ref_canvas.asp

注:Internet Explorer 9+, Firefox, Opera, Chrome, 和 Safari 支持 <canvas> 元素. (注意: Internet Explorer 8 及更早 IE 版本的浏览器不支持 <canvas> 元素.

如需转发请附上本文地址


javascript canvas画订单的更多相关文章

  1. 使用javascript和canvas画月半弯

    使用javascript和canvas画月半弯,月半弯好浪漫!浏览器须支持html5 查看效果:http://keleyi.com/a/bjad/8xqdm0r2.htm 以下是代码: <!do ...

  2. HTML5之Canvas画圆形

    HTML5之Canvas画圆形 1.设计源码 <!DOCTYPE html> <head> <meta charset="utf-8" /> & ...

  3. HTML5之Canvas画正方形

    HTML5之Canvas画正方形 1.设计源码 <!DOCTYPE html> <head> <meta charset="utf-8" /> ...

  4. [JavaScript] canvas 合成图片和文字

    Canvas Canvas 是 HTML5 新增的组件,就像一个画板,用 js 这杆笔,在上面乱涂乱画 创建一个 canvas <canvas id="stockGraph" ...

  5. canvas画流程图

    用canvas画流程图: 需求:最后一个圆圈无直线 遇到问题:需要画多个圆圈时,画布超出显示屏加滚动条,解决方法是<canvas>外层<div>的width=100%,且ove ...

  6. Javascript Canvas验证码

    用Canvas画的验证码,效果图如下 1.验证码的JS代码,保存到一个名称是validatedCode.js的文件内,代码如下: (function(window,document){ functio ...

  7. HTML5 Canvas 画虚线组件

    前段时间由于项目需要,用到了HTML5 Canvas画图,但是没有画虚线的方法,自己写了一个HTML5 画虚线的组件. dashedLine.js if (window.CanvasRendering ...

  8. canvas 画椭圆

    圆的标准方程(x-x0)²+(y-y0)²=r²中,有三个参数x0.y0.r,即圆心坐标为(x0, y0), 半径为 r圆的参数方程 x = x0 + r * cosθ, y = y0 + r * s ...

  9. 兼容IE浏览器的canvas画线和圆圈

    1.新建test.html文件,代码如下: <!DOCTYPE html><html><head>    <meta charset="utf-8& ...

随机推荐

  1. Sql Server 2008R2 数据库发布与订阅

    背景描述: 发布服务器A: (远程端) , 数据库服务名: GUANWANG1 订阅服务器B: (本机)   ,  数据库服务名: PC-LLRDBA 需要从服务器A中数据库发布,然后在B中订阅A发布 ...

  2. 380. Insert Delete GetRandom O(1) 设计数据结构:在1的时间内插入、删除、产生随机数

    [抄题]: Design a data structure that supports all following operations in average O(1) time. insert(va ...

  3. opennebula 添加kvm主机日志

    Sun Sep :: [ReM][D]: Req: UID: HostDelete invoked, Sun Sep :: [ReM][D]: Req: UID: HostDelete result ...

  4. 8-全排列next_permutation

    C++中全排列函数next_permutation 用法 转载 2017年03月29日 14:38:25 1560 全排列参考了两位的博客 感谢! http://blog.sina.com.cn/s/ ...

  5. photoshop最全快捷键列表

    一.工具箱(多种工具共用一个快捷键的可同时按[Shift]加此快捷键选取) 矩形.椭圆选框工具 [M] 移动工具 [V] 套索.多边形套索.磁性套索 [L] 魔棒工具 [W] 裁剪工具 [C] 切片工 ...

  6. Openssl s_server命令

    一.简介 s_server是openssl提供的一个SSL服务程序.使用此程序前,需要生成各种证书.本命令可以用来测试ssl客户端,比如各种浏览器的https协议支持 二.语法 openssl s_s ...

  7. Windows多线程编程入门

    标签(空格分隔): Windows multithread programming 多线程 并发 编程 背景知识 在开始学习多线程编程之前,先来学习下进程和线程 进程 进程是指具有一定独立功能的程序在 ...

  8. Python爬虫实战八之利用Selenium抓取淘宝匿名旺旺

    更新 其实本文的初衷是为了获取淘宝的非匿名旺旺,在淘宝详情页的最下方有相关评论,含有非匿名旺旺号,快一年了淘宝都没有修复这个. 可就在今天,淘宝把所有的账号设置成了匿名显示,SO,获取非匿名旺旺号已经 ...

  9. Spring.net 表达式解析ExpressionEvaluator

    1.类定义 public class Company { private string name; private Employee managingDirector; public string N ...

  10. R语言笔记完整版

    [R笔记]R语言函数总结   R语言与数据挖掘:公式:数据:方法 R语言特征 对大小写敏感 通常,数字,字母,. 和 _都是允许的(在一些国家还包括重音字母).不过,一个命名必须以 . 或者字母开头, ...