HTMLCanvasElement:toDataURL() 方法
Baseline
Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年7月.
HTMLCanvasElement.toDataURL()
方法會返回包含影像表示的數據 URL,格式由參數 type
指定。
可以指定所需的檔案格式和影像品質。如果未指定檔案格式,或者指定的格式不受支援,則數據會以 image/png
格式匯出。換句話說,如果對於任何其他類型(type)的請求地返回值是以 data:image/png
開頭,則表示該格式不受支援。
瀏覽器必須支援 image/png
格式;許多瀏覽器也會支援額外的格式,例如 image/jpeg
和 image/webp
。
對於支援編碼解析度中繼資料的檔案格式,創建的影像數據將有 96dpi 的解析度。
警告:
toDataURL()
會將整個影像編碼為一個內存字串。對於較大的影像,這可能會帶來效能問題,甚至在指定給 HTMLImageElement.src
時超過瀏覽器的 URL 長度限制。建議一般使用 toBlob()
,並搭配 URL.createObjectURL()
。
語法
toDataURL()
toDataURL(type)
toDataURL(type, quality)
參數
type
選擇性-
表示影像格式的字串。預設格式為
image/png
;如果指定的格式不支援,也會使用此格式。 quality
選擇性-
一個介於
0
和1
之間的Number
,表示創建有損壓縮格式(如image/jpeg
或image/webp
)影像時所用的影像品質。如果未指定此選項或數值超出允許範圍,則用戶代理將使用預設的品質值。
返回值
包含請求的數據 URL 的字串。
如果畫布的高度或寬度為 0
,或超過畫布的最大尺寸,將返回字串 "data:,"
。
例外
SecurityError
-
當畫布的點陣圖非來源乾淨,或其內容有部分可能來自與載入的文件本身不同的網站時。
範例
以下是此 <canvas>
元素:
<canvas id="canvas" width="5" height="5"></canvas>
可以使用以下程式碼取得該畫布的數據 URL:
const canvas = document.getElementById("canvas");
const dataURL = canvas.toDataURL();
console.log(dataURL);
// "
// blAAAADElEQVQImWNgoBMAAABpAAFEI8ARAAAAAElFTkSuQmCC"
設定 jpeg 格式的影像品質
const fullQuality = canvas.toDataURL("image/jpeg", 1.0);
// …9oADAMBAAIRAxEAPwD/AD/6AP/Z"
const mediumQuality = canvas.toDataURL("image/jpeg", 0.5);
const lowQuality = canvas.toDataURL("image/jpeg", 0.1);
範例:動態變更影像
可以搭配滑鼠事件,動態更改影像(例如切換為灰階或彩色影像)。
HTML
<img class="grayscale" src="myPicture.png" alt="我的圖片描述" />
JavaScript
window.addEventListener("load", removeColors);
function showColorImg() {
this.style.display = "none";
this.nextSibling.style.display = "inline";
}
function showGrayImg() {
this.previousSibling.style.display = "inline";
this.style.display = "none";
}
function removeColors() {
const images = document.getElementsByClassName("grayscale");
const canvas = document.createElement("canvas");
const ctx = canvas.getContext("2d");
for (const colorImg of images) {
const width = colorImg.offsetWidth;
const height = colorImg.offsetHeight;
canvas.width = width;
canvas.height = height;
ctx.drawImage(colorImg, 0, 0);
const imgData = ctx.getImageData(0, 0, width, height);
const pix = imgData.data;
const pixLen = pix.length;
for (let pixel = 0; pixel < pixLen; pixel += 4) {
pix[pixel + 2] =
pix[pixel + 1] =
pix[pixel] =
(pix[pixel] + pix[pixel + 1] + pix[pixel + 2]) / 3;
}
ctx.putImageData(imgData, 0, 0);
const grayImg = new Image();
grayImg.src = canvas.toDataURL();
grayImg.onmouseover = showColorImg;
colorImg.onmouseout = showGrayImg;
ctx.clearRect(0, 0, width, height);
colorImg.style.display = "none";
colorImg.parentNode.insertBefore(grayImg, colorImg);
}
}
規範
Specification |
---|
HTML> # dom-canvas-todataurl-dev> |
瀏覽器相容性
Loading…