我有相同的图像和相同大小的画布,但是输出是不同的。我想要同样的输出,该怎么做呢?
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;
由于您使用该画布所做的只是绘制图像,因此您应该使用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相同的结果? 这是一个摆弄模型布局的摆弄,展示了这
我习惯于用旧标记编码,并尝试用内联CSS来完成。 我有一张内联样式的桌子。我试图得到一个彩色的1px边框。在FFox和Opera(边框颜色#FFBF97)下看起来像是需要的,但IE11显示了不同的边框颜色(黑色) 我做错了什么? 下面是我的代码: 我尝试更改style=“border-collable:collable;table border:1px;border-color:#FFBF97;”