Raphael js текстовое расположение: центрирование текста в кругу

Я использую Raphael js для рисования окруженных чисел. Проблема состоит в том, что каждое число имеет различную ширину/высоту, настолько использующую один набор координат для центрирования, текст не работает. Текст отображается по-другому между IE, FF и сафари. Существует ли динамический способ найти высоту/ширину числа и центрировать его соответственно?

Вот моя тестовая страница:

http://jesserosenfield.com/fluid/test.html

и мой код:

function drawcircle(div, text) { 
    var paper = Raphael(div, 26, 26); //<<
    var circle = paper.circle(13, 13, 10.5);
    circle.attr("stroke", "#f1f1f1");
    circle.attr("stroke-width", 2);
    var text = paper.text(12, 13, text); //<<
    text.attr({'font-size': 15, 'font-family': 'FranklinGothicFSCondensed-1, FranklinGothicFSCondensed-2'});
    text.attr("fill", "#f1f1f1");
}

window.onload = function () {
    drawcircle("c1", "1");
    drawcircle("c2", "2");
    drawcircle("c3", "3");
};

Большое спасибо!

21
задан HandiworkNYC.com 30 March 2010 в 19:06
поделиться

1 ответ

Может быть, это:

var paper = Raphael(div, 26, 26); //<<
var circle = paper.circle(13, 13, 10.5);
circle.attr("stroke", "#f1f1f1");
circle.attr("stroke-width", 2);
var text = paper.text(0, 0, text); //<<
text.attr({'font-size': 15, 'font-family': 'FranklinGothicFSCondensed-1, FranklinGothicFSCondensed-2'});
text.attr("fill", "#f1f1f1");
text.translate((35 - text.getBBox().width)/2, (45 - text.getBBox().height)/2);
9
ответ дан 29 November 2019 в 20:28
поделиться