XSLT を使用して XML を SVG に変換しています。左に 1 つの値、右に棒グラフの値を持つ横棒グラフを作成したいと考えています。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
私は本当に立ち往生しているので、どんな助けも大歓迎です!