當前位置:
首頁 > 知識 > HTML5 進階系列:canvas 動態圖表

HTML5 進階系列:canvas 動態圖表

前言

canvas 強大的功能讓它成為了 HTML5 中非常重要的部分,至於它是什麼,這裡就不需要我多作介紹了。而可視化圖表,則是 canvas 強大功能的表現之一。

現在已經有了很多成熟的圖表插件都是用 canvas 實現的,Chart.js、ECharts等可以製作出好看炫酷的圖表,而且幾乎覆蓋了所有圖表的實現。

有時候自己只想畫個柱狀圖,自己寫又覺得麻煩,用別人插件又感覺累贅,最後打開百度,拷段代碼,粘貼上來修修改改。還不如自己擼一個呢。

效果

動畫效果圖片顯示不出來,可以到最下面找demo地址

分析

可以這個圖表由 xy軸、數據條形和標題組成。

軸線:可以使用 moveTo() & lineTo() 實現

文字:可以使用 fillText() 實現

長方形:可以使用 fillRect() 實現

這樣看來,似乎並沒有多難。

實現

定義畫布

canvas 標籤只是個容器,真正實現畫圖的還是 JavaScript。

畫坐標軸

坐標軸就是兩條橫線,也就是canvas里最基礎的知識。

由 ctx.beginPath() 開始一條新的路徑

ctx.lineWidth=1 設置線條寬度

ctx.strokeStyle="#000000" 設置線條顏色

ctx.moveTo(x,y) 定義線條的起點

ctx.lineTo(x1,y1) 定義線條的終點

最後 ctx.stroke() 把起點和終點連成一條線

var canvas = document.getElementById("canvas");var ctx = canvas.getContext("2d");var width = canvas.width;var height = canvas.height;var padding = 50; // 坐標軸到canvas邊框的邊距,留邊距寫文字ctx.beginPath();ctx.lineWidth = 1;// y軸線ctx.moveTo(padding + 0.5, height - padding + 0.5);ctx.lineTo(padding + 0.5, padding + 0.5);ctx.stroke();// x軸線ctx.moveTo(padding + 0.5, height - padding + 0.5);ctx.lineTo(width - padding + 0.5, height - padding + 0.5);ctx.stroke();

畫坐標點

y軸上多少坐標點由自己來定義,需要獲取到數據的最大值來計算y軸上的坐標值。x軸的點則由傳入的數據長度決定,坐標值由傳入數據的 xAxis 屬性決定。

坐標值就是文字,由 ctx.fillText(value, x, y) 填充文字,value 為文字值,x y 為值的坐標

ctx.textAlign="center" 設置文字居中對齊

ctx.fillStyle="#000000" 設置文字填充顏色

var yNumber = 5; // y軸的段數var yLength = Math.floor((height - padding * 2) / yNumber); // y軸每段的真實長度var xLength = Math.floor((width - padding * 2) / data.length); // x軸每段的真實長度ctx.beginPath();ctx.textAlign = "center";ctx.fillStyle = "#000000";ctx.strokeStyle = "#000000";// x軸刻度和值for (var i = 0; i

柱狀動畫

接下來要把數據通過柱狀的高低顯示出來,這裡有個動畫效果,柱狀會從0升到對應的值。在 canvas 上實現動畫我們可以使用 setInterval、setTimeout 和 requestAnimationFrame。

requestAnimationFrame 不需要自己設置定時時間,而是跟著瀏覽器的繪製走。這樣就不會掉幀,自然就流暢。requestAnimationFrame 原本只支持IE10以上,不過可以通過兼容的寫法實現兼容到IE6都行。

function looping() { looped = requestAnimationFrame(looping); if(current 100 ? 100 : (current + 3); drawAnimation(); }else{ window.cancelAnimationFrame(looped); looped = null; }}function drawAnimation() { for(var i = 0; i

柱狀即是畫矩形,由 ctx.fillRect(x, y, width, height) 實現,x y 為矩形左上角的坐標,width height 為矩形的寬高,單位為像素

ctx.fillStyle="#1E9FFF" 設置填充顏色

到這裡,一個最基本的柱狀圖就完成了。接下來,我們可以為他添加標題。

標題

要放置標題,就會發現我們一大早定義的 padding 內邊距確實有用,總不能把標題給覆蓋到柱狀圖上吧。但是標題有的是在頂部,有的在底部,那麼就不能寫死了。定一個變數 position 來判斷位置去畫出來。這個簡單。

// 標題if(title){ // 也不一定有標題 ctx.textAlign = "center"; ctx.fillStyle = "#000000"; // 顏色,也可以不用寫死,個性化嘛 ctx.font = "16px Microsoft YaHei" if(titlePosition === "bottom" && padding >= 40){ ctx.fillText(title,width/2,height-5) }else{ ctx.fillText(title,width/2,padding/2) }}

監聽滑鼠移動事件

我們看到,有些圖表,把滑鼠移上去,當前的柱狀就變色了,移開之後又變回原來的顏色。這裡就需要監聽 mouseover 事件,當滑鼠的位置位於柱狀的面積內,觸發事件。

那我怎麼知道在柱狀里啊,發現在 drawAnimation() 里會有每個柱狀的坐標,那我乾脆把坐標給保存到 data 里。那麼滑鼠在柱狀里的條件應該是:

ev.offsetX > data[i].left

ev.offsetX

ev.offsetY > data[i].top

ev.offsetY

canvas.addEventListener("mousemove",function(ev){ var ev = ev||window.event; for (var i=0;i data[i].left && ev.offsetX data[i].top && ev.offsetY

總結

為了更方便的使用,封裝成構造函數。通過

var chart = new sBarChart("canvas",data,{ title: "xxx公司年度盈利", // 標題 titleColor: "#000000", // 標題顏色 titlePosition: "top", // 標題位置 bgColor: "#ffffff", // 背景色 fillColor: "#1E9FFF", // 柱狀填充色 axisColor: "#666666", // 坐標軸顏色 contentColor: "#a5f0f6" // 內容橫線顏色});


喜歡這篇文章嗎?立刻分享出去讓更多人知道吧!

本站內容充實豐富,博大精深,小編精選每日熱門資訊,隨時更新,點擊「搶先收到最新資訊」瀏覽吧!


請您繼續閱讀更多來自 1KE互聯網教育 的精彩文章:

Google 的軟體工程經驗
淺談程序員的英語學習
一個三年工作經驗的Web工程師的經驗之談
每個年輕設計師都需要知道的幾件事
最佳的 Node.js 教程和實例

TAG:1KE互聯網教育 |

您可能感興趣

SAE International發布駕駛自動化等級標準圖表
ReportLab: 使用Python將圖表添加到PDF中
World Emoji Day 這一天,Tinder 開始支持 Bitmoji 貼圖表情
PowerBI自定義圖表:Bullet Chart子彈圖
Bitcoin.com推出BCH新圖表,加大對BCH的支持
蘋果iPhone 9/9 Plus尺寸與iPhone X對比圖表
抖音i need your love表情包GIF動圖表情包分享
Photoshop結合AI製作卡式播放器圖表
Python操作Excel學習筆記:圖表坐標軸
可視化圖表——ECharts
Matplotlib 可視化最有價值的 50 個圖表
Matplotlib可視化最有價值的50個圖表
實現SpreadJS的切片器與圖表聯動
自定義可視化圖表:PowerKPI
用PowerBI圖表進行時間序列預測分析
用Google Colab,怎樣讓機器學習圖表動起來?
開源一個Android自定義圖表庫
AAAI2019《圖表示學習》Tutorial,180頁PPT 帶你從入門到精通
PowerBI自定義圖表:蝴蝶結圖
愛上Excel圖表