编辑:
考虑到dennmat的建议,我使用Image()
将我的图像获取脚本简化为几行:
window.onload = function(){
var img;
capture_canvas = document.createElement('canvas');
capture_canvas.width = 1000;
capture_canvas.height = 1000;
document.documentElement.appendChild(capture_canvas);
img = new Image();
img.crossOrigin = "Anonymous";
img.src = "http://www.shangalulu.com/get_resource_no_64.php?url=http://www.shangalulu.com/users/1196739508/post/41-1330377498/41-1330377498_thumb.jpg";
img.onload = function() {
var context, canvas_img;
context = capture_canvas.getContext('2d');
context.drawImage(img, 0, 0, 255, 255);
canvas_img = context.getImageData(0, 0, capture_canvas.width, capture_canvas.height);
}
}
虽然这适用于Chrome和Firefox,但不适用于IE9。以下链接中提到的解决方案似乎不适用于此情况。 尝试设置cookie时出现Uncaught Error: SECURITY_ERR: DOM Exception 18
Image()
中的cors功能是否受IE9支持?
我遇到了一个小小的问题。 上面的图片实际上是一个文件,包含标准png头部,接着是255个字节,从255递减到0(两次)。这个想法是看看Internet Explorer 9如何处理通过AJAX请求接收二进制数据。
所以,我的问题是:我注意到当我在客户端接收一个大于127的字节时,该值默认为253。有没有办法让IE读取正确值的扩展字节?
需要注意以下几点:
1)我们不使用任何JavaScript框架。要求仅使用裸露的JavaScript。
2)这个实验的目的是找到一种清晰的方法来获取图像,以便将其放置在画布上而不会污染它。有时这些图像来自我们外部托管的图像服务器,其他时候它将来自我们无法控制的另一个主机。
下面附上我的测试脚本:
var request;
window.onload = function(){
request = new XMLHttpRequest();
if (window.XDomainRequest) {
request = new XDomainRequest();
}
request.open('GET',
"http://www.shangalulu.com/get_resource_no_64.php?url=
http://www.shangalulu.com/resources/images/sample/sample.png", true);
request.onload = function()
{
var binary, i, response;
response = this.responseText;
binary = "";
if (this.contentType)
{
document.documentElement.appendChild(
document.createTextNode(this.contentType));
document.documentElement.appendChild(document.createElement('br'));
}
for( i=0; i < response.length; i++) {
binary = "Line " + (i) + " --> " + ((response.charCodeAt(i)) & 0xff);
document.documentElement.appendChild(document.createTextNode(binary));
document.documentElement.appendChild(document.createElement('br'));
}
};
request.send();
}
Image()
函数有什么问题吗?请参考以下示例:https://developer.mozilla.org/zh-CN/docs/Web/API/Canvas_API/Tutorial/Using_images - dennmat