14-canvas绘制柱状图

  1 <!DOCTYPE html>
  2 <html lang="en">
  3 <head>
  4     <meta charset="UTF-8">
  5     <title>14-Canvas绘制柱状图</title>
  6     <style>
  7         *{
  8             margin: 0;
  9             padding: 0;
 10         }
 11         canvas{
 12             display: block;
 13             margin: 0 auto;
 14             background: red;
 15         }
 16     </style>
 17 </head>
 18 <body>
 19 <canvas width="500" height="400"></canvas>
 20 <script>
 21     // 1.拿到canvas
 22     let oCanvas = document.querySelector("canvas");
 23     // 2.从canvas中拿到绘图工具
 24     let oCtx = oCanvas.getContext("2d");
 25     // 3.定义变量保存小方格的尺寸
 26     let gridSize = 50;
 27     // 4.拿到canvas的宽高
 28     let canvasWidth = oCtx.canvas.width;
 29     let canvasHeight = oCtx.canvas.height;
 30     // 5.计算在垂直方向和水平方向可以绘制多少条横线
 31     let row = Math.floor(canvasHeight / gridSize);
 32     let col = Math.floor(canvasWidth / gridSize);
 33     // 6.绘制垂直方向的横线
 34     for(let i = 0; i < row; i++){
 35         oCtx.beginPath();
 36         oCtx.moveTo(0, i * gridSize - 0.5);
 37         oCtx.lineTo(canvasWidth, i * gridSize - 0.5);
 38         oCtx.strokeStyle = "#ccc";
 39         oCtx.stroke();
 40     }
 41     // 7.绘制水平方向的横线
 42     for(let i = 0; i < col; i++){
 43         oCtx.beginPath();
 44         oCtx.moveTo(i * gridSize - 0.5, 0);
 45         oCtx.lineTo(i * gridSize - 0.5, canvasHeight);
 46         oCtx.strokeStyle = "#ccc";
 47         oCtx.stroke();
 48     }
 49
 50     // 1.计算坐标系原点的位置
 51     let originX = gridSize;
 52     let originY = canvasHeight - gridSize;
 53     // 2.计算X轴终点的位置
 54     let endX = canvasWidth - gridSize;
 55     // 3.绘制X轴
 56     oCtx.beginPath();
 57     oCtx.moveTo(originX, originY);
 58     oCtx.lineTo(endX, originY);
 59     oCtx.strokeStyle = "#000";
 60     oCtx.stroke();
 61     // 4.绘制X轴的箭头
 62     oCtx.lineTo(endX - 10, originY + 5);
 63     oCtx.lineTo(endX - 10, originY - 5);
 64     oCtx.lineTo(endX, originY);
 65     oCtx.fill();
 66
 67     // 5.计算Y轴终点的位置
 68     let endY = gridSize;
 69     // 3.绘制Y轴
 70     oCtx.beginPath();
 71     oCtx.moveTo(originX, originY);
 72     oCtx.lineTo(originX, endY);
 73     oCtx.strokeStyle = "#000";
 74     oCtx.stroke();
 75     // 4.绘制X轴的箭头
 76     oCtx.lineTo(originX - 5, endY + 10);
 77     oCtx.lineTo(originX + 5, endY + 10);
 78     oCtx.lineTo(originX, endY);
 79     oCtx.fill();
 80
 81     // 1.拿到服务器返回数据
 82     let list = [
 83         {
 84             x: 100,
 85             y: 300
 86         },
 87         {
 88             x: 200,
 89             y: 200
 90         },
 91         {
 92             x: 300,
 93             y: 250
 94         },
 95     ];
 96     let data = {
 97         x: 100,
 98         y: 300
 99     }
100     // 2.绘制矩形
101     for(let i = 0; i < list.length; i++){
102         let barHeight = originY - list[i].y;
103         oCtx.fillRect(list[i].x, list[i].y, gridSize, barHeight);
104     }
105
106 </script>
107 </body>
108 </html>

原文地址:https://www.cnblogs.com/gsq1998/p/12166113.html

时间: 2024-08-29 18:06:43

14-canvas绘制柱状图的相关文章

167天:canvas绘制柱状图

canvas绘制柱状图 1.HTML 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no"> 6 &l

canvas绘制柱状图和、绘制形状中心旋转

<!DOCTYPE html> <html ng-app=""> <head lang="en"> <meta charset="UTF-8"> <title></title> </head> <body> <canvas id="cvs" width="400" height="300"

用canvas绘制折线图

1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>用canvas绘制折线图</title> 6 </head> 7 <body> 8 <canvas id="cv"></canvas> 9 </body> 1

封装 用canvas绘制直线的函数--面向对象

1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>用面向对象的思想 封装 在canvas绘制直线的函数</title> 6 </head> 7 <body> 8 <canvas id="cv"></canvas> 9 &

html5 Canvas绘制图形入门详解

html5,这个应该就不需要多作介绍了,只要是开发人员应该都不会陌生.html5是「新兴」的网页技术标准,目前,除IE8及其以下版本的IE浏览器之外,几乎所有主流浏览器(FireFox.Chrome.Opera.Safari.IE9+)都已经开始支持html5了.除此之外,在移动浏览器市场上,众多的移动浏览器也纷纷展开关于「html5的支持能力以及性能表现」的军备竞赛.html作为革命性的网页技术标准,再加上众多浏览器厂商或组织的鼎力支持,可以想见,html5将会成为未来网页技术的领头羊. ht

用h5中的canvas 绘制八卦图

1 <!doctype html> 2 <html> 3 <head> 4 <meta charset="UTF-8"> 5 <title>canvas绘制八卦图</title> 6 </head> 7 8 <body> 9 <canvas id="canvas" width="600" height="500"><

canvas绘制清晰的方法

很早就开始使用canvas,包括自己绘制各种图形,以及作为画布提供给诸如echarts,当canvas绘制细线条,特别是关于文字绘制会出现很模糊或者锯齿的感觉. 1 <canvas ref="canvas" width="200" height="200"/> 正常情况下一般都是这么写的,但是实际上对于canvas来说,这个canvas.width canvas.height 与canvas.style.width canvas.st

html5 canvas绘制圆形印章,以及与页面交互

1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="UTF-8"> 5 <title>HTML5 Canvas画印章</title> 6 <script type="text/javascript" src="../JQmain/jquery-2.2.0.min.js"></script> 7 &l

使用html5 canvas绘制圆形或弧线

注意:本文属于<html5 Canvas绘制图形入门详解>系列文章中的一部分.如果你是html5初学者,仅仅阅读本文,可能无法较深入的理解canvas,甚至无法顺畅地通读本文.请点击上述链接以了解使用html5 canvas绘制图形的完整内容. 在html5中,CanvasRenderingContext2D对象也提供了专门用于绘制圆形或弧线的方法,请参考以下属性和方法介绍: arc(x, y, radius, startRad, endRad, anticlockwise) 在canvas画