如何填充画布和添加文本

时间:2019-05-02 15:03:28

标签: javascript canvas

我想用图像(base64字符串)填充画布,然后在画布中添加文本。

最初的想法(JavaScript浏览器应用程序):我想将base64字符串txtb64(图像)设置为画布的背景图像,然后在其上添加文本。

downloadtext: function() {
  var sign = this.getView().byId("SigId");
  var txtb64 = signpad.getSignAsJpeg();

  var canvas = document.createElement("canvas");
  var ctx = canvas.getContext('2d');
  var image = new Image();
  image.src = txtb64;
  image.addEventListener("load", function(event) {
    console.log("Ready!");
  });

  ctx.drawImage(image, 0, 0);

  ctx.fillText('My random text', 0, 0);

  var dataURL = canvas.toDataURL("image/jpeg");

  var image = new Image();
  var element = document.createElement('a');

  image.src = dataURL;

  element.setAttribute('href', image.src);
  element.setAttribute('download', 'image');
  element.style.display = 'none';

  element.click();
},

问题是我总是得到一个黑色矩形作为输出。 我的代码有什么问题,因为我看不到错误。

1 个答案:

答案 0 :(得分:2)

您似乎应该将下载新图像所需的代码放在创建的图像的“加载”事件处理程序中。之所以需要这样做是因为load事件可能在其下面的代码运行之后触发,从而导致在画布上放置一个空图像。

您还要两次声明var image = new Image();,这也可能引起问题。呼叫一个image1和另一个image2可以防止这种情况。

警告:运行此代码段将触发下载请求。

var data = "";

var can = document.getElementById('can');
var ctx = can.getContext('2d');
var img = new Image();

img.src = data;

img.addEventListener('load', e =>
{
  ctx.drawImage(img, 0, 0);
  
  ctx.fillText('My random text', 100, 100);
  
  var dataURL = can.toDataURL("image/jpeg");

  var image = new Image();
  var element = document.createElement('a');

  image.src = dataURL;
  
  element.setAttribute('href', image.src);
  element.setAttribute('download', 'image');
  
  document.body.appendChild(element);
  
  element.click();
});
<canvas width="300" height="300" id="can"></canvas>