SVG textPath не привязан к связанному пути после импорта FabricJS?

У меня есть следующий SVG, который отлично работает сам по себе: http://jsfiddle.net/bL3k48jn/1/

Однако при импорте с помощью fabric.loadSVGFromString текст больше не привязывается к пути, и стили шрифта теряются.

SVG

<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="500px" height="500px">

  <path id="textPath" fill="none" stroke-width="5" stroke="yellow"
    d="
    M 250 -250
    m 0, 250
    a -250,250 0 1,0 0,500
    a 250,-250 0 1,0  0,-500
    "
  />

  <text fill="black" font-family = "arial" text-anchor="middle">
    <textPath startOffset="50%" fill="white" stroke="black" stroke-width="2" font-size="36px" font-weight="bold" xlink:href="#textPath">Happy Birthday Dad!</textPath>
  </text>      

</svg>

Вы должны увидеть круг с текстом, следующий за нижним краем кривой.

Код, который я использую для импорта SVG, находится здесь: http://jsfiddle.net/hnzgy940/2/< /а>

JavaScript

var canvas = new fabric.Canvas('c');

// This is the SVG as a single line
var str = '<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="500px" height="500px"><path id="text_path" d="M 250 -250 m 0,250 a -250,250 0 1,0 0,500 a 250,-250 0 1,0 0,-500"  fill="none" stroke-width="5" stroke="yellow"/><text font-family="arial" text-anchor="middle"><textPath startOffset="50%" fill="white" stroke="black" stroke-width="2" font-size="36px" font-weight="bold" xlink:href="#text_path">Happy Birthday Dad!</textPath></text></svg>';

fabric.loadSVGFromString(str, function(objects, options) {
    svg_text = fabric.util.groupSVGElements(objects, options)

    svg_text.set({
    originX: 'center',
    originY: 'center',
    left: canvas.width / 2,
    top: canvas.height / 2
    });

    svg_text.setCoords();
    canvas.add(svg_text);
    canvas.renderAll();
});

Похоже, что он игнорирует атрибут xlink:href в элементе <textPath> вместе со стилями шрифта, что, я думаю, означает, что он может просто игнорировать весь элемент <textPath>, но я не понимаю, почему.

Раньше у меня была проблема, когда текст вообще не отображался, но я думаю, что это могло быть из-за того, что у меня не было правильного атрибута xmlns.


person Barry    schedule 08.12.2014    source источник


Ответы (1)


Текстовые пути еще не поддерживаются в Fabric, но есть ветка:

https://github.com/lirmont/fabric.js/tree/Curve-Text

Также смотрите диалог:

https://github.com/kangax/fabric.js/issues/729

person Josh Pearce    schedule 17.12.2014