所以我正在使用谷歌地图,我得到的照片看起来像这样
<img id="staticMap"
src="http://maps.googleapis.com/maps/api/staticmap?center=Brooklyn+Bridge,New+York,NY&zoom=13&size=600x300&maptype=roadmap
&markers=color:blue%7Clabel:S%7C40.702147,-74.015794&markers=color:green%7Clabel:G%7C40.711614,-74.012318
&markers=color:red%7Ccolor:red%7Clabel:C%7C40.718217,-73.998284&sensor=false">
我需要保存它。我发现了这一点:
function getBase64FromImageUrl(URL) {
var img = new Image();
img.src = URL;
img.onload = function() {
var canvas = document.createElement("canvas");
canvas.width = this.width;
canvas.height = this.height;
var ctx = canvas.getContext("2d");
ctx.drawImage(this, 0, 0);
var dataURL = canvas.toDataURL("image/png");
alert(dataURL.replace(/^data:image\/(png|jpg);base64,/, ""));
};
}
但是我遇到了这个问题:
未捕获到的SecurityError:无法在“ HTMLCanvasElement”上执行“ toDataURL”:受污染的画布可能无法导出。
我搜索了修复程序。我在这里找到了如何使用CORS的示例,但仍然无法将这两段代码捆绑在一起以使其正常工作。也许我做错了方法,并且有一种更简单的方法?我正在尝试保存此图片,以便可以将数据传输到我的服务器。因此,也许有人做了这样的事情,并且知道如何根据.toDataURL()
需要进行工作?
403
),您才可以回退使用canvas.toDataURL(img)
,以希望它的来源与页面相同。此默认行为也会导致产生原始文件(EXIF等)