有没有办法在画布中绘制损坏的图像?

时间:2016-08-25 07:30:34

标签: javascript html5 html5-canvas

我正在尝试在画布上绘制图像。我使用的图像是从服务器获取的base64字符串。出于测试目的,我在调试时将映像保存在客户端和服务器的磁盘上。图像保存得很好。在画布中绘图时,图像不会在Chrome和Firefox中呈现。但它在IE 11中工作正常。有没有办法让图像在所有浏览器中绘制。

var base64String = ".." //only few of the string is shared
function drwImage(base64String) {
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');
var img = new Image();
img.onload=function(){
    context.drawImage(img, 0, 0, 1, 1);
}
img.src = base64String;
}

提前感谢您的帮助。

1 个答案:

答案 0 :(得分:2)

看似与序列化图片相关的内容,正如您在下面的代码段中看到的,它适用于Chrome,我使用了online encoder。 正如您可以阅读here,数据库几乎得到支持。



  var base64String = "" //only few of the string is shared

   drwImage(base64String);


function drwImage(b) {
    var canvas = document.createElement('canvas');
    var context = canvas.getContext('2d');
    var img = new Image();
    img.onload = function() {
      console.log('load')
      context.drawImage(img, 0, 0, 1, 1);
      document.body.appendChild(img);
    }
    img.onerror = function() {
      console.log('error')
    }
    img.src = b;
  }