JavaScript+Canvas實現(xiàn)簡單的柱狀圖
筆者之所以想要深入了解 Canvas
,是因為最近幾次的實習部門都屬于 Data
這個門類下面,所以用echarts
之類的圖標庫會很多很多,那么當然要好好學一下其間的底層原理了。
那么讓我們好好聊聊,如何實現(xiàn)一個柱狀圖
如何實現(xiàn)一個柱狀圖
Step1
首先創(chuàng)建一個叫做barchart.html
的新文件,并且在其中寫入如下代碼:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> </head> <body> <canvas width="500" height="500" id="canvas"></canvas> </body> <script> var data = [16, 68, 20, 30, 54]; </script> </html>
Tips 我們知道canvas
可以使用fillRect
來實現(xiàn)一個矩形。
fillRect(x, y, xWidth, yHeight)
fillRect有四個參數,分別是x的坐標,y的坐標,寬度與高度。
Step2
我們創(chuàng)建文件包含了 canvas
和 script
元素,對canvas
來說,我們標注了他的寬高,它類似于DOM
中的DIV
元素,我們可以為其添加樣式和移動位置。
data
變量呢則是一系列的數據集,我們將用這些變量來畫柱狀圖。
接下來我們將獲取canvas
元素,并且繪制一個底層色(灰色)
//get a reference to the canvas var canvas = document.getElementById('canvas'); //get a reference to the drawing context var c = canvas.getContext('2d'); //draw c.fillStyle = "gray"; c.fillRect(0,0,500,500);
Step3
在我們的基本條件都具備了之后,我們可以添加數據了,這里采用一個循環(huán)來添加。
//draw data c.fillStyle = "blue"; for(var i=0; i<data.length; i++) { var dp = data[i]; c.fillRect(25 + i*100, 30, 50, dp*5); }
效果如下:
但是這里有一個問題,我們的柱狀圖,反了!怎么讓他正起來呢?
Step4
我們知道,fillRect
的前兩個參數是我們的起點x和y的坐標,那么為了實現(xiàn)“正”的效果,我們可以移動起點的位置。
//draw data c.fillStyle = "blue"; for(var i=0; i<data.length; i++) { var dp = data[i]; c.fillRect(25 + i*100, 500-dp*5 - 30 , 50, dp*5); }
效果如下:
是不是看起來很舒服啦?
但是現(xiàn)在還有一個問題,我們的坐標軸去哪了???
Step5
現(xiàn)在,讓我們一起來畫一個坐標軸
首先需要畫x
軸和y
軸
//draw axis lines c.fillStyle = "black"; c.lineWidth = 2.0; c.beginPath(); c.moveTo(30,10); c.lineTo(30,460); c.lineTo(490,460); c.stroke();
然后我們要新增y
軸標記點和文本
//draw text and vertical lines c.fillStyle = "black"; for(var i=0; i<6; i++) { c.fillText((5-i)*20 + "",4, i*80+60); c.beginPath(); c.moveTo(25,i*80+60); c.lineTo(30,i*80+60); c.stroke(); }
最后新增x
軸文本
var labels = ["JAN","FEB","MAR","APR","MAY"]; //draw horiz text for(var i=0; i<5; i++) { c.fillText(labels[i], 50+ i*100, 475); }
效果如下:
看起來有部分問題,讓我們再來做一些調整!
Step6
將背景色改成白色 & 把起點做一下變更。
//draw background c.fillStyle = "white"; c.fillRect(0,0,500,500); //draw data c.fillStyle = "blue"; for(var i=0; i<data.length; i++) { var dp = data[i]; c.fillRect(40 + i*100, 460-dp*5 , 50, dp*5); }
噔噔噔噔,我們的柱狀圖就這樣寫好啦~
到此這篇關于JavaScript+Canvas實現(xiàn)簡單的柱狀圖的文章就介紹到這了,更多相關JavaScript Canvas柱狀圖內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
js for循環(huán),為什么一定要加var定義i變量
我知道,有些人(譬如之前的我)寫js的for循環(huán)時,都不習慣加上var,這當然是語法允許的。2010-06-06uniapp實現(xiàn)滾動觸底加載項目實戰(zhàn)
這篇文章主要為大家介紹了uniapp實現(xiàn)滾動觸底加載項目實戰(zhàn)方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-09-09HTML+CSS+JavaScript實現(xiàn)放大鏡效果
這篇文章主要為大家詳細介紹了HTML+CSS+JavaScript實現(xiàn)放大鏡效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07Clipboard.js 無需Flash的JavaScript復制粘貼庫
這篇文章主要介紹了JavaScript 內容復制(無需flash) Clipboard.js使用方法,需要的朋友可以參考下2015-10-10