Question

I am checking the use of fonts in SVG and the Canvas (html5). I have translated a svg file in urldata. I got this result:



When I copy and paste on the address brosser all that ( Firefox, Chrome par example) I can display the word "hello" using the Desyrel font (If you tried that, you won't display the Desyrel font). On the other hand, I have tried to use the same urldata dans le canvas (html5) using this code:

.............
                        var imageObj = new Image();

                imageObj.onload = function() {

                    context.drawImage(imageObj, 0, 0);

                 };
...........
         imageObj.src=urldata; 

In the Canvas (html5) I can display also "hello" but the font Desyrel is missing. I tried other fonts and the result is the same.

Does anyone know how to display in a html5 canvas the font required? I tried also imageObj.src=myfile.svg; And again the font is not taken in account. I think the html5 canvas can display svg images but is there a problem about the fonts? Thansk for your answer, any solution?

Was it helpful?

Solution

An image must be self contained to prevent privacy leaks. Your base64 encoded image contains this:

<style type="text/css">@import url(http://127.0.0.1:8000/VegaEditor/static/ModelePol/Desyrel.css)</style>

This won't work as it tries to access data outside the image file. You'd have to url or base64 encode the css file and embed it into the image as a data url just as you did with the image itself.

Once all of the data for the image is in the one file it should work.

OTHER TIPS

I had this problem too and I wanted to better understand Robert's answer so I put together this jsfiddle demonstrating how one can base64 encode the font face "Geogrotesque" and embed it within the svg so that when the svg is serialized into a string and set as the source as the img, it will maintain the font face in the img so that it then can be drawn in the canvas.

<defs>
<style>
@font-face {
font-family: 'geogrotesque_mediummedium';
src: url(data:application/font-woff2;charset=utf-8;base64,d09GMg...[place encoded data here];
}
</style>
</defs>
Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top