首頁 > web前端 > H5教程 > HTML5畫布Canvas圖片擷取、像素資訊取得、命中偵測

HTML5畫布Canvas圖片擷取、像素資訊取得、命中偵測

黄舟
發布: 2017-02-27 15:41:09
原創
4084 人瀏覽過

今天主要介紹canvas中比較強大的功能 

例如將畫布內容抽取為圖片
獲取、修改畫布的像素資訊
以及畫布的命中檢測
首先我仍然需要建立畫布

<canvas id="myCanvas" width=500 height=500></canvas>
登入後複製

圖片抽取

首先要明確的一點是
toDataURL()是canvas物件本身的方法而不是環境物件的
這個方法會將canvas的內容抽取為一張圖片(base64編碼)
我們來看一下它的使用方法

canvas轉化為圖像

我閒著沒事用canvas做了一個太極圖
js程式碼如下

let canvas = document.getElementById(&#39;myCanvas&#39;);
let cxt = canvas.getContext(&#39;2d&#39;);
let l = canvas.width/2;
const PI = Math.PI;
cxt.translate(l, l);let createTaiChi = () => {
    cxt.clearRect(-l, -l, l, l);
    cxt.arc(0, 0, l, 0, 2*PI, 0);
    cxt.stroke();
    cxt.beginPath();
    cxt.arc(0, -l/2, l/2, -PI/2, PI/2, 0);
    cxt.arc(0, l/2, l/2, 3/2*PI, PI/2, 1);
    cxt.arc(0, 0, l, PI/2, PI*3/2, 0);
    cxt.fill();
    cxt.beginPath();
    cxt.fillStyle = &#39;#fff&#39;;
    cxt.arc(0, -l/2, l/7, 0, PI*2, 0);
    cxt.fill();
    cxt.beginPath();
    cxt.fillStyle = &#39;#000&#39;;
    cxt.arc(0, l/2, l/7, 0, PI*2, 0);
    cxt.fill();
};

createTaiChi();
登入後複製

再配合css做成一個持續旋轉的樣子

#myCanvas {    
width: 250px;    
height: 250px;    
margin: 100px;    
animation: rotate 3s linear infinite;
}@keyframes rotate{
    0% {        
    transform: rotateZ(0);    
    }
    100% {        
    transform: rotateZ(360deg);    }}
登入後複製

注意這裡我設定的css寬高要比canvas本來的寬高小一倍
(這樣可以讓canvas更清晰一些)


#下面我就要將我在canvas畫的太極圖轉化為一張圖片
首先要取得canvas的base64編碼

let data = canvas.toDataURL();console.log(data);
登入後複製

這裡我們在控制台列印一下看看它的樣子

我們要將它變成圖片,
只需要建立一個img標籤,然後將src設定為data即可

let img = document.createElement(&#39;img&#39;);
img.src = data;document.body.appendChild(img);
登入後複製

這時我們就會發現頁面中多了一個靜態的太極圖
大小與canvas的width/ height屬性相同500×500

同源策略限制

注意這個方法是受同源策略限制的
比如說我在頁面中新增一個本地圖片
然後將這張圖片畫到canvas中

let img = document.getElementsByTagName(&#39;img&#39;)[0];
cxt.drawImage(img, 0, 0);let data = canvas.toDataURL();
登入後複製

瀏覽器會報錯

HTML5畫布Canvas圖片擷取、像素資訊取得、命中偵測

#我們使用本地伺服器的話就可以用這個方法
證明這個方法受同源策略限制

像素資訊

使用getImageData(x, y, dx, dy)可以取得canvas的像素資訊
方法由環境物件呼叫(我們這裡是cxt)
(同樣受同源策略限制)
前兩個參數是要取得影像資訊的起始座標,後兩個參數就是要取得影像資訊的寬高
(類似矩形繪製函數)
這個方法回傳一個ImageData物件(包括像素資訊數組data還有寬高width/height)
我們主要用這個物件的data屬性

我們畫布的大小是500×500
所以取得canvas上所有像素資訊就是這樣

console.log(cxt.getImageData(0, 0, 500, 500).data);
登入後複製

我們發現這個陣列的長度為100w


假如我們的canvas有四個像素點
每個像素點資訊有分為RGBA四個方面的值
那麼數組長度就應該是4×4 = 16
它們分別是 
1R 1G 1B 1A  
2R 2G 2B 2A  
3R 3G 3B 3A  
4R 4G 4B 4A


我們這裡的canvas一(500×500 #所以像素資訊數組大小為25w×4 = 100w

我們也可以使用createImageData(width,height)方法

建立一個空白imageData物件

let blankImg = cxt.createImageData(250, 250);
console.log(blankImg);
登入後複製


#使用putImageData(imgData, x, y)可以將你的圖像像素覆蓋原canvas

imgData就是imgData對象,x,y是覆蓋的起始座標
比如說我將我們上面建立的250×250的空白影像覆蓋原canvas

cxt.putImageData(blankImg, 0, 0);
登入後複製

# 命中偵測

isPointInPath()可以偵測像素點是否在路徑區域內

使用方法很簡單

cxt.rect(100, 100, 300, 300);if(cxt.isPointInPath(200, 200)){
    cxt.stroke();}
登入後複製

isPointInStroke()用來偵測像素點是否在路徑上,用法也類似

不過它的相容性不是很好

 以上就是HTML5畫布Canvas圖片擷取、像素資訊取得、命中偵測的內容,更多相關內容請追蹤PHP中文網(www.php.cn)!



#

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板