偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

HTML5 進(jìn)階系列:canvas 動(dòng)態(tài)圖表

開(kāi)發(fā) 開(kāi)發(fā)工具
canvas 強(qiáng)大的功能讓它成為了 HTML5 中非常重要的部分,至于它是什么,這里就不需要我多作介紹了。而可視化圖表,則是 canvas 強(qiáng)大功能的表現(xiàn)之一。

[[195863]]

canvas 強(qiáng)大的功能讓它成為了 HTML5 中非常重要的部分,至于它是什么,這里就不需要我多作介紹了。而可視化圖表,則是 canvas 強(qiáng)大功能的表現(xiàn)之一。

現(xiàn)在已經(jīng)有了很多成熟的圖表插件都是用 canvas 實(shí)現(xiàn)的,Chart.js、ECharts等可以制作出好看炫酷的圖表,而且?guī)缀醺采w了所有圖表的實(shí)現(xiàn)。

有時(shí)候自己只想畫(huà)個(gè)柱狀圖,自己寫(xiě)又覺(jué)得麻煩,用別人插件又感覺(jué)累贅,***打開(kāi)百度,拷段代碼,粘貼上來(lái)修修改改。還不如自己擼一個(gè)呢。

效果

動(dòng)畫(huà)效果圖片顯示不出來(lái),可以到最下面找demo地址

分析

可以這個(gè)圖表由 xy軸、數(shù)據(jù)條形和標(biāo)題組成。

  • 軸線:可以使用 moveTo() & lineTo() 實(shí)現(xiàn)
  • 文字:可以使用 fillText() 實(shí)現(xiàn)
  • 長(zhǎng)方形:可以使用 fillRect() 實(shí)現(xiàn)

這樣看來(lái),似乎并沒(méi)有多難。

實(shí)現(xiàn)

定義畫(huà)布

  1. <canvas id="canvas" width="600" height="500"></canvas> 

canvas 標(biāo)簽只是個(gè)容器,真正實(shí)現(xiàn)畫(huà)圖的還是 JavaScript。

畫(huà)坐標(biāo)軸

坐標(biāo)軸就是兩條橫線,也就是canvas里最基礎(chǔ)的知識(shí)。

  • 由 ctx.beginPath() 開(kāi)始一條新的路徑
  • ctx.lineWidth=1 設(shè)置線條寬度
  • ctx.strokeStyle=’#000000’ 設(shè)置線條顏色
  • ctx.moveTo(x,y) 定義線條的起點(diǎn)
  • ctx.lineTo(x1,y1) 定義線條的終點(diǎn)
  • *** ctx.stroke() 把起點(diǎn)和終點(diǎn)連成一條線
  1. var canvas = document.getElementById('canvas'); 
  2. var ctx = canvas.getContext('2d'); 
  3. var width = canvas.width; 
  4. var height = canvas.height; 
  5. var padding = 50;       // 坐標(biāo)軸到canvas邊框的邊距,留邊距寫(xiě)文字 
  6. ctx.beginPath(); 
  7. ctx.lineWidth = 1; 
  8. // y軸線 
  9. ctx.moveTo(padding + 0.5, height - padding + 0.5); 
  10. ctx.lineTo(padding + 0.5, padding + 0.5); 
  11. ctx.stroke(); 
  12. // x軸線 
  13. ctx.moveTo(padding + 0.5, height - padding + 0.5); 
  14. ctx.lineTo(width - padding + 0.5, height - padding + 0.5); 
  15. ctx.stroke(); 

畫(huà)坐標(biāo)點(diǎn)

y軸上多少坐標(biāo)點(diǎn)由自己來(lái)定義,需要獲取到數(shù)據(jù)的***值來(lái)計(jì)算y軸上的坐標(biāo)值。x軸的點(diǎn)則由傳入的數(shù)據(jù)長(zhǎng)度決定,坐標(biāo)值由傳入數(shù)據(jù)的 xAxis 屬性決定。

  • 坐標(biāo)值就是文字,由 ctx.fillText(value, x, y) 填充文字,value 為文字值,x y 為值的坐標(biāo)
  • ctx.textAlign=’center’ 設(shè)置文字居中對(duì)齊
  • ctx.fillStyle=’#000000’ 設(shè)置文字填充顏色
  1. var yNumber = 5;                                                // y軸的段數(shù) 
  2. var yLength = Math.floor((height - padding * 2) / yNumber);     // y軸每段的真實(shí)長(zhǎng)度 
  3. var xLength = Math.floor((width - padding * 2) / data.length);  // x軸每段的真實(shí)長(zhǎng)度 
  4. ctx.beginPath(); 
  5. ctx.textAlign = 'center'
  6. ctx.fillStyle = '#000000'
  7. ctx.strokeStyle = '#000000'
  8. // x軸刻度和值 
  9. for (var i = 0; i < data.length; i++) { 
  10.     var xAxis = data[i].xAxis; 
  11.     var xlen = xLength * (i + 1); 
  12.     ctx.moveTo(padding + xlen, height - padding); 
  13.     ctx.lineTo(padding + xlen, height - padding + 5); 
  14.     ctx.stroke();                                       // 畫(huà)軸線上的刻度 
  15.     ctx.fillText(xAxis, padding + xlen - xLength / 2, height - padding + 15);   // 填充文字 
  16. // y軸刻度和值 
  17. for (var i = 0; i < yNumber; i++) { 
  18.     var y = yFictitious * (i + 1); 
  19.     var ylen = yLength * (i + 1); 
  20.     ctx.moveTo(padding, height - padding - ylen); 
  21.     ctx.lineTo(padding - 5, height - padding - ylen); 
  22.     ctx.stroke(); 
  23.     ctx.fillText(y, padding - 10, height - padding - ylen + 5); 

柱狀動(dòng)畫(huà)

接下來(lái)要把數(shù)據(jù)通過(guò)柱狀的高低顯示出來(lái),這里有個(gè)動(dòng)畫(huà)效果,柱狀會(huì)從0升到對(duì)應(yīng)的值。在 canvas 上實(shí)現(xiàn)動(dòng)畫(huà)我們可以使用 setInterval、setTimeout 和 requestAnimationFrame。

requestAnimationFrame 不需要自己設(shè)置定時(shí)時(shí)間,而是跟著瀏覽器的繪制走。這樣就不會(huì)掉幀,自然就流暢。

requestAnimationFrame 原本只支持IE10以上,不過(guò)可以通過(guò)兼容的寫(xiě)法實(shí)現(xiàn)兼容到IE6都行。

  1. function looping() { 
  2.     looped = requestAnimationFrame(looping); 
  3.     if(current < 100){       
  4.     // current 用來(lái)計(jì)算當(dāng)前柱狀的高度占最終高度的百分之幾,通過(guò)不斷循環(huán)實(shí)現(xiàn)柱狀上升的動(dòng)畫(huà) 
  5.         current = (current + 3) > 100 ? 100 : (current + 3); 
  6.         drawAnimation(); 
  7.     }else
  8.         window.cancelAnimationFrame(looped); 
  9.         looped = null
  10.     } 
  11. function drawAnimation() { 
  12.     for(var i = 0; i < data.length; i++) { 
  13.         var x = Math.ceil(data[i].value * current / 100 * yRatio); 
  14.         var y = height - padding - x; 
  15.         ctx.fillRect(padding + xLength * (i + 0.25), y, xLength/2, x); 
  16.         // 保存每個(gè)柱狀的信息 
  17.         data[i].left = padding + xLength / 4 + xLength * i; 
  18.         data[i].top = y; 
  19.         data[i].right = padding + 3 * xLength / 4 + xLength * i; 
  20.         data[i].bottom = height - padding; 
  21.     } 
  22. looping(); 
  • 柱狀即是畫(huà)矩形,由 ctx.fillRect(x, y, width, height) 實(shí)現(xiàn),x y 為矩形左上角的坐標(biāo),width height 為矩形的寬高,單位為像素
  • ctx.fillStyle=’#1E9FFF’ 設(shè)置填充顏色

到這里,一個(gè)最基本的柱狀圖就完成了。接下來(lái),我們可以為他添加標(biāo)題。

標(biāo)題

要放置標(biāo)題,就會(huì)發(fā)現(xiàn)我們一大早定義的 padding 內(nèi)邊距確實(shí)有用,總不能把標(biāo)題給覆蓋到柱狀圖上吧。但是標(biāo)題有的是在頂部,有的在底部,那么就不能寫(xiě)死了。定一個(gè)變量 position 來(lái)判斷位置去畫(huà)出來(lái)。這個(gè)簡(jiǎn)單。

  1. // 標(biāo)題 
  2. if(title){                      // 也不一定有標(biāo)題 
  3.     ctx.textAlign = 'center'
  4.     ctx.fillStyle = '#000000';  // 顏色,也可以不用寫(xiě)死,個(gè)性化嘛 
  5.     ctx.font = '16px Microsoft YaHei' 
  6.     if(titlePosition === 'bottom' && padding >= 40){ 
  7.         ctx.fillText(title,width/2,height-5) 
  8.     }else
  9.         ctx.fillText(title,width/2,padding/2) 
  10.     } 

監(jiān)聽(tīng)鼠標(biāo)移動(dòng)事件

我們看到,有些圖表,把鼠標(biāo)移上去,當(dāng)前的柱狀就變色了,移開(kāi)之后又變回原來(lái)的顏色。這里就需要監(jiān)聽(tīng) mouseover 事件,當(dāng)鼠標(biāo)的位置位于柱狀的面積內(nèi),觸發(fā)事件。

那我怎么知道在柱狀里啊,發(fā)現(xiàn)在 drawAnimation() 里會(huì)有每個(gè)柱狀的坐標(biāo),那我干脆把坐標(biāo)給保存到 data 里。那么鼠標(biāo)在柱狀里的條件應(yīng)該是:

  • ev.offsetX > data[i].left
  • ev.offsetX < data[i].right
  • ev.offsetY > data[i].top
  • ev.offsetY < data[i].bottom
  1. canvas.addEventListener('mousemove',function(ev){ 
  2.     var ev = ev||window.event; 
  3.     for (var i=0;i<data.length;i++){ 
  4.     for (var i=0;i<data.length;i++){ 
  5.         if(ev.offsetX > data[i].left && 
  6.         ev.offsetX < data[i].right && 
  7.         ev.offsetY > data[i].top && 
  8.         ev.offsetY < data[i].bottom){ 
  9.             console.log('我在第'+i+'個(gè)柱狀里。'); 
  10.         } 
  11.     } 
  12. }) 

總結(jié)

為了更方便的使用,封裝成構(gòu)造函數(shù)。通過(guò)

  1. var chart = new sBarChart('canvas',data,{ 
  2.     title: 'xxx公司年度盈利',   // 標(biāo)題 
  3.     titleColor: '#000000',      // 標(biāo)題顏色 
  4.     titlePosition: 'top',       // 標(biāo)題位置 
  5.     bgColor: '#ffffff',         // 背景色 
  6.     fillColor: '#1E9FFF',       // 柱狀填充色 
  7.     axisColor: '#666666',       // 坐標(biāo)軸顏色 
  8.     contentColor: '#a5f0f6'     // 內(nèi)容橫線顏色 
  9. }); 

參數(shù)可配置,很簡(jiǎn)單就生成一個(gè)個(gè)性化的柱狀圖。代碼地址:canvas-demo

***加上折線圖、餅圖、環(huán)形圖,完整封裝成sChart.js插件,插件地址:sChart.js

【本文為51CTO專(zhuān)欄作者“林鑫”的原創(chuàng)稿件,轉(zhuǎn)載請(qǐng)通過(guò)微信公眾號(hào)聯(lián)系作者獲取授權(quán)】

戳這里,看該作者更多好文

責(zé)任編輯:武曉燕 來(lái)源: 51CTO專(zhuān)欄
相關(guān)推薦

2021-04-18 20:49:03

Pyecharts圖表 組件

2012-02-24 15:28:36

ibmdw

2011-09-02 17:04:13

Sencha ToucHTML5圖表庫(kù)

2011-07-21 15:34:36

iPhone HTML5 Canvas

2012-08-30 10:18:09

HTML5CanvasHTML5實(shí)例

2015-10-08 08:48:44

HTML5canvas動(dòng)畫(huà)

2012-05-09 12:18:14

HTML5Canvas

2016-01-20 10:11:56

華麗CanvasHTML5

2012-06-04 10:16:18

HTML5

2020-03-05 09:59:45

Excel辦公數(shù)據(jù)

2012-04-18 15:36:33

HTML5Canvas交互式

2012-06-12 09:53:14

HTML5

2012-09-24 13:49:13

HTML5CanvasJS

2013-01-24 10:26:04

HTML5HTML 5HTML5的未來(lái)

2013-03-06 16:14:16

UCHTML5游戲引擎

2015-07-14 09:50:28

PHPHTML5

2024-07-12 09:07:29

HTML5圖表應(yīng)用

2013-10-21 15:24:49

html5游戲

2011-05-13 17:36:05

HTML

2011-11-09 10:05:26

HTML 5
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)