繁体   English   中英

如何将图像同步绘制到画布上

[英]How to synchronously draw an image to a canvas

我有一个用 base64 编码的图像,我需要以同步方式在画布上绘制它。 看看我的这段代码:

//convert base64 to actual Image()
var input = new Image();
input.src = dataurl;

//draw on canvas
var w = input.width, h = input.height;
canvas.width = w; canvas.height = h;
ctx.drawImage(input, 0, 0)

这曾经适用于 Chrome。 我知道假设浏览器能够在下一条指令之前完成加载不是一个好习惯,但它确实有效。 后来经过几次更新,终于失败了。

我无法侦听load事件,因为这会使其异步,这不好,因为这是一个生成器函数,我需要同步返回画布。 该程序是围绕它构建的,使其异步意味着完全重写。 这不好。


试图

input.src = dataurl;

while(!input.width){ /* busy wait */ }

var w = input.width, h = input.height;

不起作用,因为浏览器不会在我的代码完成执行之前更新它。


现在我真的想不出任何方法来解决这个困境,所以任何输入都值得赞赏。 (请注意,datauri 是从另一个画布生成的,我确实可以访问。)

在加载之前无法将图像绘制到画布上,这意味着等待load事件。 这意味着您无法将数据 URI 同步加载到 DOM 图像中,因此您需要将 API 转换为异步 API。

唯一的另一种方法是使用基于 JavaScript 的图像解码器将数据 URI 转换为ImageData对象,这不是一件容易的事,并且需要用户加载更多代码。

曾经有一种不同的 hack 涉及innerHTML可以工作,但它也不再有效。

现已损坏的示例:

 var base64 = ''; var el = document.createElement('p'); el.innerHTML = '<img src="'+base64+'" />'; var input = el.firstChild; //draw on canvas var canvas = document.getElementById('canvas'); var w = input.width, h = input.height; canvas.width = w; canvas.height = h; var ctx = canvas.getContext('2d'); ctx.drawImage(input, 0, 0);
 <canvas id="canvas"></canvas>

只需使用 Promise 使其异步即可。

 return new Promise(resolve => {

          image.onload = function () {
                ctx.drawImage(input, 0, 0)
                resolve('resolved');
             }

    });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM