我正在尝试制作混合有行和简短文本片段(通常是两个或三个单词)的SVG XML文档。我遇到的主要问题是让文本与线段对齐。
对于水平对齐,我可以将text-anchor
与left
、middle
或right
一起使用。我找不到垂直对齐的等价物;alignment-baseline
似乎不能做到这一点,所以目前我正在使用dy="0.5ex"
作为中心对齐的拼凑工具。
是否有适当的方式与文本的垂直中心或顶部对齐?
发布于 2008-09-16 14:57:14
事实证明,您不需要显式的文本路径。Firefox3只部分支持垂直对齐标签(see this thread)。它似乎只在作为样式应用时才起作用,而文本锚点可以是样式或标签属性的一部分。
<path d="M10, 20 L17, 20"
style="fill:none; color:black; stroke:black; stroke-width:1.00"/>
<text fill="black" font-family="sans-serif" font-size="16"
x="27" y="20" style="dominant-baseline: central;">
Vertical
</text>
<path d="M60, 40 L60, 47"
style="fill:none; color:red; stroke:red; stroke-width:1.00"/>
<text fill="red" font-family="sans-serif" font-size="16"
x="60" y="70" style="text-anchor: middle;">
Horizontal
</text>
<path d="M60, 90 L60, 97"
style="fill:none; color:blue; stroke:blue; stroke-width:1.00"/>
<text fill="blue" font-family="sans-serif" font-size="16"
x="60" y="97" style="text-anchor: middle; dominant-baseline: hanging;">
Bit of Both
</text>
这在Firefox中是有效的。不幸的是,Inkscape似乎不能处理主导基线(或者至少不是以同样的方式)。
发布于 2014-05-15 22:25:49
此效果确实可以通过将alignment-baseline
设置为central
或middle
来实现。
https://stackoverflow.com/questions/56402
复制相似问题