SVG 到 Canvas 和 HTML 符号

SVG to Canvas with HTML Symbol

<svg id="s1" xmlns="http://www.w3.org/2000/svg" width="400" height="400">
<rect width="100%" height="100%" fill="none" stroke="black" />
<foreignObject x="0" y="0" width="100%" height="100%">
<p style="font-size:200px;text-align:center;">&#128512;</p>
</foreignObject>
</svg>
<canvas id="c1" width="400" height="400"></canvas>
<script>
let img = new Image();
let b64 = "data:image/svg+xml;base64,";
let xml = new XMLSerializer().serializeToString(s1);
b64 += btoa(xml);//InvalidCharacterError: String contains an invalid character
let ctx = c1.getContext("2d");
img.onload = function(){
   ctx.drawImage(img, 0, 0);
};
img.src = b64;
</script>

您好,您知道如何将带有“”等符号的 svg 转换为 canvas 吗?

控制台:InvalidCharacterError:字符串包含无效字符

它适用于像“你好”这样的普通文本。

谢谢。

添加一个不可见的 img 元素到您的 DOM,在 canvas 中渲染它:

const image = document.getElementById('my-image');
const canvas = document.getElementById('my-canvas');
const ctx = canvas.getContext("2d");
ctx.drawImage(image, 10, 10);
img {
  visibility: hidden;
}
canvas {
  border: 1px solid gray;
}
<canvas id="my-canvas" width="240" height="240" ></canvas>
<img id="my-image" src=""/>

btoa 和 atob only support acscii strings 但我们可以通过对字符串进行编码和解码来解决这个问题

let img = new Image();
let b64 = "data:image/svg+xml;base64,";
let s1 = document.getElementById("s1");
let xml = new XMLSerializer().serializeToString(s1);
b64 += btoa(unescape(encodeURIComponent(xml)));
let ctx = c1.getContext("2d");
img.onload = function(){
   ctx.drawImage(img, 0, 0);
};
img.src = b64;
<svg id="s1" xmlns="http://www.w3.org/2000/svg" width="400" height="400">
<rect width="100%" height="100%" fill="none" stroke="black" />
<foreignObject x="0" y="0" width="100%" height="100%">
<p style="font-size:200px;text-align:center;">&#128512;</p>
</foreignObject>
</svg>
<canvas id="c1" width="400" height="400"></canvas>