HTMLCanvasElement: toDataURL() Methode
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Die HTMLCanvasElement.toDataURL()
Methode gibt eine Data-URL zurück, die eine Darstellung des Bildes im durch den type
Parameter angegebenen Format enthält.
Das gewünschte Dateiformat und die Bildqualität können angegeben werden.
Wenn das Dateiformat nicht angegeben ist oder das angegebene Format nicht unterstützt wird, wird die Datei als image/png
exportiert.
Mit anderen Worten, wenn der zurückgegebene Wert mit data:image/png
beginnt, obwohl ein anderes type
angefordert wurde, wird dieses Format nicht unterstützt.
Browser sind verpflichtet, image/png
zu unterstützen; viele werden zusätzliche Formate wie image/jpeg
und image/webp
unterstützen.
Die erstellten Bilddaten haben eine Auflösung von 96 dpi für Dateiformate, die das Kodieren von Auflösungsmetadaten unterstützen.
Warning:
toDataURL()
kodiert das gesamte Bild in einem In-Memory-String. Bei größeren Bildern kann dies Auswirkungen auf die Leistung haben und sogar das URL-Längenlimit von Browsern überschreiten, wenn es einemHTMLImageElement.src
zugewiesen wird. Sie sollten generelltoBlob()
in Kombination mitURL.createObjectURL()
bevorzugen.
Syntax
toDataURL()
toDataURL(type)
toDataURL(type, quality)
Parameter
type
Optional-
Ein String, der das Bildformat angibt. Der Standardtyp ist
image/png
; dieses Bildformat wird auch verwendet, wenn der angegebene Typ nicht unterstützt wird. quality
Optional-
Eine
Number
zwischen0
und1
, die die Bildqualität angibt, die beim Erstellen von Bildern mit Dateiformaten, die verlustbehaftete Kompression unterstützen (wieimage/jpeg
oderimage/webp
), verwendet werden soll. Ein User-Agent verwendet seinen Standardqualitätswert, wenn diese Option nicht angegeben ist oder wenn die Zahl außerhalb des zulässigen Bereichs liegt.
Rückgabewert
Ein String, der die angeforderte Data-URL enthält.
Wenn die Höhe oder Breite der Leinwand 0
oder größer als die maximale Leinwandgröße ist, wird der String "data:,"
zurückgegeben.
Ausnahmen
SecurityError
-
Das Bitmap der Leinwand ist nicht origin-sauber; mindestens einige seiner Inhalte wurden von einer anderen Website geladen oder könnten von einer anderen Website geladen worden sein als der, von der das Dokument selbst geladen wurde.
Beispiele
Angenommen, dieses <canvas>
Element:
<canvas id="canvas" width="5" height="5"></canvas>
Sie können eine Data-URL der Leinwand mit den folgenden Zeilen erhalten:
const canvas = document.getElementById("canvas");
const dataURL = canvas.toDataURL();
console.log(dataURL);
// "
// blAAAADElEQVQImWNgoBMAAABpAAFEI8ARAAAAAElFTkSuQmCC"
Festlegen der Bildqualität mit JPEGs
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);
Beispiel: Bilder dynamisch ändern
Sie können diese Technik in Kombination mit Mausereignissen verwenden, um Bilder dynamisch zu ändern (Graustufen vs. Farbe in diesem Beispiel):
HTML
<img class="grayscale" src="myPicture.png" alt="Description of my picture" />
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);
}
}
Spezifikationen
Specification |
---|
HTML # dom-canvas-todataurl-dev |