misskey/packages/frontend/src/workers/draw-blurhash.ts

25 lines
778 B
TypeScript
Raw Normal View History

2023-05-06 15:52:51 +00:00
import { decode } from 'blurhash';
let canvas: OffscreenCanvas | null = null;
onmessage = (event) => {
if ('canvas' in event.data) {
canvas = event.data.canvas;
}
2023-05-06 17:50:43 +00:00
if (!canvas) {
console.error('Cannot draw blurhash without canvas', canvas, event.data);
throw new Error('Cannot draw blurhash without canvas');
}
if (!('hash' in event.data && typeof event.data.hash === 'string')) {
return;
2023-05-06 15:52:51 +00:00
}
const width = event.data.width ?? 64;
const height = event.data.height ?? 64;
const ctx = canvas.getContext!('2d');
if (!ctx) return;
const imageData = ctx.createImageData(width, height);
const pixels = decode(event.data.hash, width, height);
imageData.data.set(pixels);
ctx!.putImageData(imageData, 0, 0);
};