Revert "WIP"

This reverts commit 05b729ef91.
This commit is contained in:
tamaina 2023-05-17 07:55:09 +00:00
parent 6bed74109b
commit 15f56b231d
1 changed files with 15 additions and 18 deletions

View File

@ -114,6 +114,20 @@ watch([() => props.width, () => props.height, root], () => {
immediate: true, immediate: true,
}); });
workerPromise.then(worker => {
if (!worker) return;
worker.postMessage({
id: viewId,
hash: props.hash,
});
worker.addEventListener('message', event => {
if (event.data.id !== viewId) return;
drawImage(event.data.bitmap as ImageBitmap);
});
});
function drawImage(bitmap: CanvasImageSource) { function drawImage(bitmap: CanvasImageSource) {
// canvasmountedTmp // canvasmountedTmp
if (!canvas.value) { if (!canvas.value) {
@ -151,19 +165,6 @@ async function draw() {
} }
} }
function workerOnMessage(event: MessageEvent) {
if (event.data.id !== viewId) return;
drawImage(event.data.bitmap as ImageBitmap);
}
workerPromise.then(worker => {
if (worker) {
worker.addEventListener('message', workerOnMessage);
}
draw();
});
watch(() => props.src, () => { watch(() => props.src, () => {
waitForDecode(); waitForDecode();
}); });
@ -180,11 +181,7 @@ onMounted(() => {
}); });
onUnmounted(() => { onUnmounted(() => {
workerPromise.then(worker => { workerPromise.then(worker => worker?.postMessage!({ id: viewId, delete: true }));
if (worker) {
worker.removeEventListener('message', workerOnMessage);
}
});
}); });
</script> </script>