使用XSLT从XML创建SVG条形图

时间:2012-12-13 14:36:26

标签: xml xslt svg

我正在使用XSLT将XML转换为SVG。我想创建水平条形图,左边有一个值,右边有条形图值。 XML看起来像这样:

<value1 name="something">
  <value2>13</value2>
</value1>
<value1 name="something else">
  <value2>45</value2>
</value1>

这就是我到目前为止所做的,从value2创建水平条形图。

<xsl:template match="/" mode="svg">
    <svg width="500px" height="500px" xmlns="http://www.w3.org/2000/svg">
      <g id="bar" transform="translate(50,50) rotate(90 90 90)">
        <xsl:for-each select=".../value1">
        <xsl:variable name="val" select="value2"/>
      <rect x="{position()*25}" y="-{$val*1.5}" height="{$val*1.5}" width="15" style="fill:{@fill};"/>
      <text x="{position()*25 + 7.5}" y="0" style="font-family:arial;text-anchor:middle;baseline-shift:-15;">
      </text>
    </xsl:for-each>
  </g>
</svg>

我遇到的问题是将文本和图表放在一起。我错了吗?我希望输出看起来像这样:

value1     bar chart  value2
value1     longer bar chart  value2

我真的被困住了,所以感谢任何帮助!

1 个答案:

答案 0 :(得分:0)