09-canvas绘制坐标系

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>09-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 </script>
81 </body>
82 </html>

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

时间: 2024-10-13 15:58:33

09-canvas绘制坐标系的相关文章

HTML5—canvas绘制图形(1)

1.canvas基础知识 canvas元素是HTML5中新增的一个重要的元素,专门用来绘制图形,不过canvas本身不具备画图的能力,在页面中放置了canvas元素,就相当于在页面中放置了一块矩形的“画布”,我们可以利用js脚本在“画布”上绘制图形. 1.1canvas元素 在利用canvas绘制图形之前,我们首先需要在页面中放置一个canvas元素,如下代码: <canvas id="mycanvas" width="400" height="40

使用html5 Canvas绘制线条(直线、折线等)

使用html5 Canvas绘制直线所需的CanvasRenderingContext2D对象的主要属性和方法(有"()"者为方法)如下: 属性或方法 基本描述 strokeStyle 用于设置画笔绘制路径的颜色.渐变和模式.该属性的值可以是一个表示css颜色值的字符串.如果你的绘制需求比较复杂,该属性的值还可以是一个CanvasGradient对象或者CanvasPattern对象 globalAlpha 定义绘制内容的透明度,取值在0.0(完全透明)和1.0(完全不透明)之间,默认

用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 &

canvas绘制时钟

<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>canvas绘制钟表</title> <style type="text/css"> #canvas{ /*border: 2px solid red;*/ display: block; margin: 0 auto; } </style> </

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绘制图形的基本教程

原文地址:http://www.cnblogs.com/picaso/archive/2012/11/26/2789077.html HTML5火的正热,最近有个想法也是要用到HTML的相关功能,所以也要好好学习一把. 好好看了一下Canvas的功能,感觉HTML5在客户端交互的功能性越来越强了,今天看了一下Canvas绘图,下边是几个实例,记下以备后用. 1.使用Canvas绘制直线: <!doctype html> <html> <head> <meta ch

Canvas绘制线条模糊的解决方案

前段时间,做一个跨平台app项目,需要绘制分时图和K线图.找了很多开源的js的图表库,包括echarts.highcharts等等,都不是很满意,原因有2: 1.太臃肿,我实际上只要一个分时和一个K线图表,最多搭配几个线形图 2.不满足需求.主要就是分时图,国内玩的js图表库,几乎都没有分时图.都是用1分钟线的收盘价线来做的,和中国股民的使用习惯完全不搭界. 多年前有人开源了一个js绘制股票图形的库,叫做html54stock,图像表现上很符合中国人的使用习惯,但是也有问题: 1.封装不好,很多