Skip to content

Instantly share code, notes, and snippets.

Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save guest271314/03cbf85fa50b5ce8a328a1a6b2611eb1 to your computer and use it in GitHub Desktop.
Save guest271314/03cbf85fa50b5ce8a328a1a6b2611eb1 to your computer and use it in GitHub Desktop.
<!DOCTYPE html>
<html>
<head>
</head>
<body>
<canvas></canvas>
<script>
(async() => {
const canvas = document.querySelector("canvas");
const data = "";
// https://stackoverflow.com/q/56801191
// https://github.com/web-platform-tests/wpt/commit/36bfff9e3bafa41e22da654525c3c3f42b6362eb
const IMAGE = atob(data.split(",").pop());
console.log(IMAGE);
const bytes = new Array(IMAGE.length);
for (let i = 0; i < IMAGE.length; i++) {
bytes[i] = IMAGE.charCodeAt(i);
}
const blob = new Blob([new Uint8Array(bytes)]);
let imageBitmap;
try {
imageBitmap = await window.createImageBitmap(blob);
} catch (e) {
console.error(e);
}
console.log(imageBitmap);
canvas.width = imageBitmap.width;
canvas.height = imageBitmap.height;
const ctx = canvas.getContext("2d");
ctx.drawImage(imageBitmap, 0, 0);
})();
</script>
</body>
</html>
@guest271314
Copy link
Author

guest271314 commented Jun 29, 2019

@ouroborus The data URL renders at Firefox 69, throws a DOMException at Chromium 77 https://plnkr.co/edit/FgLpwYmvEY8xHSzQdtn5?p=preview

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment