当前位置: 首页 > 知识库问答 >
问题:

在不同的浏览器上不同的输出

苍轶
2023-03-14

我有相同的图像和相同大小的画布,但是输出是不同的。我想要同样的输出,该怎么做呢?

var canvas = document.createElement('canvas'),
    ctx = canvas.getContext('2d'),
    img = new Image;

img.crossOrigin = 'Anonymous';

img.onload = function(){
    canvas.height = img.height;
    canvas.width = img.width;
    ctx.drawImage(img, 0, 0);
    var dataURL = canvas.toDataURL();
    setBreakpoint(dataURL);
    callback.call(this, dataURL);
    canvas = null;
};

img.src = url;

共有1个答案

诸龙野
2023-03-14

由于您使用该画布所做的只是绘制图像,因此您应该使用FileReader及其方法readAsDataURL()。

对于外部文件,您仍然可以使用它,这要感谢XMLHttpRequest对象及其xhr。responseType=“blob”属性,但受跨源请求的限制。

这将直接在文件的二进制数据上工作,直接将每个字节转换为其Base64表示。

另一方面,绘制到画布上的图像在绘制之前进行解码,然后在调用toDataURL时重新编码。这个过程依赖于每个浏览器,甚至每台机器(看看画布指纹和@Oriol的这篇文章)。

显然,此过程将修改原始文件的内容(实际上与此无关)

如果你不相信,这里有一个片段,它将测试你的浏览器和我的浏览器的转换。

var xhr = new XMLHttpRequest();
xhr.responseType = 'blob';
xhr.onload = function() {
  var f = new FileReader();
  f.onload = function() {
    if (this.result === imageDataURL) {
      console.log('same conversion');
    }
    else {
      console.log('please post a comment to let me know that it\'s also browser/machine dependant');
      }
  };
  f.readAsDataURL(this.response);
};

xhr.open('GET', 'https://dl.dropboxusercontent.com/s/4e90e48s5vtmfbd/aaa.png');
xhr.send();

var imageDataURL = '';

然而,对于那些使用画布进行真实绘制的人来说,在不同的UAs之间不可能有相同的结果。从绘图到导出的每个方法都可能产生不同的结果,您必须完全重写所有这些方法才能获得完全相同的结果。

对于那些真正需要这样做的人,像NodeCanvas这样的项目可能会有所帮助,尽管它显然比本机实现的性能要差得多。

 类似资料:
  • 问题内容: 在IE7,IE8和Firefox上设置属性并返回不同的值: IE 8: IE 7: 火狐: 为什么存在这种差异? 在不使用jQuery的情况下,是否存在跨不同浏览器(IE8,IE7,Firefox)一致的等效属性? 问题答案: 这与浏览器的盒子模型有关。使用jQuery或其他JavaScript抽象库之类的东西来规范DOM模型。

  • 问题内容: 我正在写一个基于AJAX / COMET的在线聊天室。我的设计是: 请求 -----------------等待------------------------->发送转储数据 -----------------等待------------------------->发送转储数据 -----------------等待------------------------->发送转储数据 -

  • 问题内容: 有没有办法为特定的浏览器加载不同的CSS文件? 像(伪代码差): 问题答案: 您想要的理想解决方案不存在: 不幸的是,如果您尝试在HTML本身上进行操作,则不存在跨浏览器解决方案。但是,它将适用于大多数版本的IE。像这样: 所以最好的解决方案是: 这样的Javascript解决方案怎么样:浏览器检测。阅读有关此类的内容以更好地弄清该文件的基本作用,就是这样的概念: 显然,它不仅可以检测

  • 当我跑的时候。使用CPLEX的NET 4应用程序,我在不同的机器上得到不同的输出。在我的开发机器上,CPLEX输出一个结果(异常并卡在某个大值上),在所有其他机器上,结果都可以。 首先,我认为它与操作系统有关,因为我的开发机器上同时有视窗7 x64和视窗8 x64,所以我尝试在两个系统上运行应用程序。结果是一样的——有缺陷。 然后我试着在两台不同的台式机上运行,效果很好。我甚至在虚拟机内部进行了尝

  • 我需要一张图片来填充分区。根据这个答案,工作几乎完成了。当图像略大于其所包含的div时,就会出现问题。图像以100%的比例显示,这在我的情况下并不理想。 在Firefox中,这个问题可以通过使用以下CSS来解决: 在其他浏览器(使用Chrome和Edge测试)中,此解决方案不起作用,最终结果与以前相同。 有没有办法在其他浏览器上实现与Firefox相同的结果? 这是一个摆弄模型布局的摆弄,展示了这

  • 但是,当我使用不带参数的url(时,它工作正常。