Выравнивание текста в SVG

Я пытаюсь сделать документы SVG XML со смесью строк и кратких фрагментов текста (обычно два или три слова). Основная проблема, с которой я сталкиваюсь, - это выравнивание текста с сегментами строк.

Для горизонтального выравнивания я могу использовать text-anchor с left, middle или right. Я не могу найти эквивалент для вертикального выравнивания; alignment-baseline, похоже, не делает этого, поэтому в настоящее время я использую dy="0.5ex" как kludge для выравнивания по центру.

Есть ли подходящий способ для выравнивания с вертикальным центром или верхней частью текста?

Ответ 1

Оказывается, вам не нужны явные текстовые пути. Firefox 3 имеет только частичную поддержку тегов вертикального выравнивания (см. Этот поток). Также кажется, что доминирующая-базовая линия работает только тогда, когда применяется как стиль, тогда как текстовый якорь может быть частью атрибута стиля или тега.

<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, похоже, не справляется с доминирующей базой (или, по крайней мере, не таким же образом).

Ответ 2

Этот эффект действительно может быть достигнут установкой alignment-baseline в central или middle.