Baseline Widely available
HTMLCanvasElement.toDataURL()
â меÑод, коÑоÑÑй возвÑаÑÐ°ÐµÑ data URI изобÑÐ°Ð¶ÐµÐ½Ð¸Ñ Ð² ÑоÑмаÑе, заданном паÑамеÑÑом type
(по ÑмолÑÐ°Ð½Ð¸Ñ PNG). ÐозвÑаÑаемое изобÑажение Ð¸Ð¼ÐµÐµÑ ÑазÑеÑение 96 dpi.
0
или болÑÑе макÑималÑного ÑазмеÑа Ñ
олÑÑа, возвÑаÑаеÑÑÑ ÑÑÑока "data:,"
.image/png
, но возвÑаÑаемое знаÑение наÑинаеÑÑÑ Ñ data:image/png
, Ñо запÑоÑеннÑй Ñип не поддеÑживаеÑÑÑ.image/webp
.canvas.toDataURL(type, encoderOptions);
ÐаÑамеÑÑÑ
type
ÐеобÑзаÑелÑнÑй
СÑÑока (DOMString
), ÑказÑваÑÑÐ°Ñ ÑоÑÐ¼Ð°Ñ Ð¸Ð·Ð¾Ð±ÑажениÑ. Ðо ÑмолÑÐ°Ð½Ð¸Ñ â image/png
.
encoderOptions
ÐеобÑзаÑелÑнÑй
ЧиÑло (Ñипа Number
) Ð¼ÐµÐ¶Ð´Ñ 0
и 1
, ÑказÑваÑÑее каÑеÑÑво изобÑÐ°Ð¶ÐµÐ½Ð¸Ñ Ð´Ð»Ñ ÑоÑмаÑов, иÑполÑзÑÑÑиÑ
ÑжаÑие Ñ Ð¿Ð¾ÑеÑÑми, ÑакиÑ
как image/jpeg
и image/webp
. ÐÑли пеÑедан невалиднÑй аÑгÑменÑ, Ñо иÑполÑзÑеÑÑÑ Ð·Ð½Ð°Ñение по ÑмолÑÐ°Ð½Ð¸Ñ 0.92
. ÐÑÑалÑнÑе аÑгÑменÑÑ Ð¸Ð³Ð½Ð¾ÑиÑÑÑÑÑÑ.
СÑÑока (DOMString
), ÑодеÑжаÑÐ°Ñ Ð·Ð°Ð¿ÑоÑеннÑй data URI.
SecurityError
РаÑÑÑовое изобÑажение Ñ Ð¾Ð»ÑÑа не ÑооÑвеÑÑÑвÑÐµÑ Ð¸ÑÑоÑникÑ; по кÑайней меÑе ÑаÑÑÑ ÐµÐ³Ð¾ ÑодеÑжимого могла бÑÑÑ Ð·Ð°Ð³ÑÑжена Ñ ÑайÑа, оÑлиÑного Ð¾Ñ Ñого, Ñ ÐºÐ¾ÑоÑого бÑл загÑÑжен Ñам докÑменÑ.
ÐозÑмÑм ÑледÑÑÑий <canvas>
ÑлеменÑ:
<canvas id="canvas" width="5" height="5"></canvas>
ÐÑ Ð¼Ð¾Ð¶ÐµÑе полÑÑиÑÑ ÐµÐ³Ð¾ data-URL ÑледÑÑÑим обÑазом:
var canvas = document.getElementById("canvas");
var dataURL = canvas.toDataURL();
console.log(dataURL);
// "
// blAAAADElEQVQImWNgoBMAAABpAAFEI8ARAAAAAElFTkSuQmCC"
ÐаÑÑÑойка каÑеÑÑва изобÑÐ°Ð¶ÐµÐ½Ð¸Ñ Ñ Ð¿Ð¾Ð¼Ð¾ÑÑÑ jpegs
var fullQuality = canvas.toDataURL("image/jpeg", 1.0);
// ...9oADAMBAAIRAxEAPwD/AD/6AP/Z"
var mediumQuality = canvas.toDataURL("image/jpeg", 0.5);
var 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() {
var aImages = document.getElementsByClassName("grayscale"),
nImgsLen = aImages.length,
oCanvas = document.createElement("canvas"),
oCtx = oCanvas.getContext("2d");
for (
var nWidth, nHeight, oImgData, oGrayImg, nPixel, aPix, nPixLen, nImgId = 0;
nImgId < nImgsLen;
nImgId++
) {
oColorImg = aImages[nImgId];
nWidth = oColorImg.offsetWidth;
nHeight = oColorImg.offsetHeight;
oCanvas.width = nWidth;
oCanvas.height = nHeight;
oCtx.drawImage(oColorImg, 0, 0);
oImgData = oCtx.getImageData(0, 0, nWidth, nHeight);
aPix = oImgData.data;
nPixLen = aPix.length;
for (nPixel = 0; nPixel < nPixLen; nPixel += 4) {
aPix[nPixel + 2] =
aPix[nPixel + 1] =
aPix[nPixel] =
(aPix[nPixel] + aPix[nPixel + 1] + aPix[nPixel + 2]) / 3;
}
oCtx.putImageData(oImgData, 0, 0);
oGrayImg = new Image();
oGrayImg.src = oCanvas.toDataURL();
oGrayImg.onmouseover = showColorImg;
oColorImg.onmouseout = showGrayImg;
oCtx.clearRect(0, 0, nWidth, nHeight);
oColorImg.style.display = "none";
oColorImg.parentNode.insertBefore(oGrayImg, oColorImg);
}
}
СпеÑиÑикаÑии СовмеÑÑимоÑÑÑ Ñ Ð±ÑаÑзеÑами СмоÑÑиÑе Ñакже
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4