How to properly display multiline text in SVG 1.1?

前端 未结 4 1724
春和景丽
春和景丽 2021-01-13 06:52

I would like to take a multiline block of text and display it in SVG. I would like to keep the lines as lines. Is there a proper way to do this?

I am using Inkscape

相关标签:
4条回答
  • 2021-01-13 07:27

    This is not acceptable since flow* elements are non-standard elements. It comes from an SVG1.2 draft that has never been accepted and it is designed to wrap text in custom shapes. Only Inkscape and some builds of Opera support it. So, don't use it, at least for the moment.

    If you don't need text wrapping (and you don't seem to, but I don't understand what you mean by "I would like to keep the lines as lines"), I suggest you use the basic <text/> element.

    0 讨论(0)
  • 2021-01-13 07:41

    Inkscape sets the SVG version of the document to 1.1 instead of 1.2, but still uses flowing text.

    The simple solution for you is to edit your svg document and change the SVG version attribute to 1.2. Inkscape will not change it back to 1.1 and it handles the 1.2 version specifier fine.

    Batik will then be happy to provide most functionality, however you'll also run into another Inkscape bug if you mess with pretty much any of the text attributes within the flow root that Inkscape creates. It sets the background color to the selected foreground color for the text, which means if you set the text color to red in Inkscape, when batik renders it, you'll see a red square ... the text is there, but its red too, so not really visible. This an Inkscape bug and is clearly visible in the code for the flowRegion -> rect element.

    The solution is to manually edit your flowRect attributes after tweaking them with inkscape.

    Batik also seems to do better if you use the standard svg output rather than inkscape svg output.

    0 讨论(0)
  • 2021-01-13 07:41

    I'd suggest <text> with <tspan> children. Inkscape can generate that for you quite easily, just don't click and drag an area but instead just click where you want the text and start writing, press return where you want a new line.

    0 讨论(0)
  • 2021-01-13 07:44

    Alternatively, foreignObject will allow you to include html:

    <svg:foreignObject><html:body><div>text here</html:div></html:body></svg:foreignObject>
    

    Doesn't seem to work in Opera or IE, though.

    0 讨论(0)
提交回复
热议问题