0

使用 svgwrite python 库时,我遇到了文本垂直对齐的问题。

例如,下面是一个简单的代码,它生成一个红色填充的圆圈,圆圈顶部有一个黑色文本,上面写着“Text”:

import svgwrite                                             

d = svgwrite.Drawing(filename='alignment_test.svg',                          
                     size=(60,60))                                             
circle = d.circle((30,30), 30, fill='red')                                     
text = d.text('Test', (30,30),                                                 
              style='text-anchor:middle',                                      
              font_size='17px')                                                                                                               
d.add(circle)                                                                  
d.add(text)
d.save()

结果是这个预期的图像:

在此处输入图像描述

但是,我希望文本也垂直对齐。

我尝试使用alignment-baselineSVG的属性,即

style='text-anchor:middle;\
       alignment-baseline:middle'

但是,它不起作用 - 在 FireFox 中(垂直对齐不起作用),在 Inkscape 中都不起作用,它抱怨Unimplemented style property 363.

我将不胜感激有关如何解决此问题的任何建议。

4

1 回答 1

0

...所以在写这个问题时,我搜索了更多,实际上在这里阅读了第二个答案(通过 toutankh): SVG 中文本元素的垂直对齐,这建议使用属性dominant-baseline而不是alignment-baseline文本对象。而且效果很好。

经验教训:永远不要只阅读 SO 问题的第一个答案。

于 2021-02-21T22:08:22.223 回答