如何填充画布并添加文字



我想用图像(base64-string(填充我的画布,而不是在画布中添加文本。

初始想法(JavaScript浏览器应用程序(:我想将Base64-string txtb64(Image(设置为画布的背景图像,而不是在其上添加文本。

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();
},

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

看来,您应该将下载新图像的代码放入您创建的图像的"加载"事件处理程序中。这是需要的,因为加载事件可以在其下方的代码运行后触发,从而导致将空图像放在画布上。

您还两次声明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>

最新更新