简体   繁体   中英

How to fill canvas and add text

I want to fill my canvas with a image (base64-string) and than add a text into the canvas.

Initial idea (javascript browser application): I want to set the base64-string txtb64 (Image) as background image of the canvas and than add the text over it.

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

The problem is I always get a black rectangle as output. What is wrong with my code, because i can see no error.

It looks like you should put the code needed to download the new image inside the "load" event handler of the image you create. This is needed because the load event could trigger after the code beneath it runs, resulting in an empty image being put onto the canvas.

Also you declare var image = new Image(); twice, which could also be causing issues. Calling one image1 and the other image2 will prevent that.

WARNING Running this snippet triggers a download request.

 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>

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

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