【发布时间】:2014-01-29 17:07:01
【问题描述】:
我正在尝试为网站创建一些动态创建页面的缩略图,我找到了一个解决方案,方法是在 svg 中添加 html,然后在画布内绘制图像,在绘制图像后调整其大小.
此解决方案适用于 firefox 和 chrome,但不适用于 safari,似乎没有绘制 svg 我只是得到一个空白页。即使我尝试了一些尝试,但我在网上找不到解决方案,我也没有收到任何错误。
我的html只是一个带有画布的基本测试页面,我尝试在头部添加一个元标记
<meta http-equiv="content-type" content="application/xhtml+xml; charset=utf-8" />
但它也没有工作。
这是我写的代码:
var canvas = document.getElementById('canvasTest'),
context = canvas.getContext('2d');
var data = "<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'>" +
"<foreignObject width='100%' height='100%'>" +
"<div xmlns='http://www.w3.org/1999/xhtml' style='font-size:40px'>" +
"<div>TEST<span>TEST</span></div>" +
"</div>" +
"</foreignObject>" +
"</svg>"
;
var DOMURL = self.URL || self.webkitURL || self;
var img = new Image();
try {
var svg = new Blob([data], {type: "image/svg+xml;charset=utf-8"});
} catch(e) {
window.BlobBuilder = window.BlobBuilder || window.WebKitBlobBuilder || window.MozBlobBuilder || window.MSBlobBuilder;
console.log(window.BlobBuilder);
if(e.name == 'TypeError' && window.BlobBuilder){
var bb = new BlobBuilder();
bb.append(data);
var svg = bb.getBlob("image/svg+xml;charset=utf-8");
} else if(e.name == "InvalidStateError") {
var svg = new Blob(data, {type : "image/svg+xml;charset=utf-8"});
} else {
}
}
var url = DOMURL.createObjectURL(svg);
img.onload = function() {
context.drawImage(img, 100, 100);
};
img.src = url;
DOMURL.revokeObjectURL(url);
context.translate(canvas.width / 2, canvas.height / 2);
context.scale(0.4, 0.4);
Safari 可以使用 Blob 构造函数,因此它不会陷入困境。问题似乎是当我通过 svg 参考 (img.src = url) 但我不知道该怎么做,如果有人有一些想法或解决方案,那就太好了。
编辑:Safari 的控制台输出
Blob:Blob {size=232, type="image/svg+xml;charset=utf-8", webkitSlice}
网址:blob:http://myPage.com/96fb502f-46bb-492b-af35-5313bb39bd31
【问题讨论】:
-
之后可以使用
.toDataURL(),还是在 Safari 上出现安全错误?
标签: javascript canvas svg safari