Nvd3を使用して縦積み重ね棒グラフを作成しようとしています。 website の例としてランダムに生成された値ではなく、離散データ値を使用します。
Group/Stacked Bar Chartのライブコード例をいじってみて、自分の値を含むJSONデータを入れました。私がやろうとしたことは、横棒グラフからJSONデータを取り出し、縦棒グラフのデータとして挿入することでした。
これは、Group/Stacked Bar Chartのデータの代わりにライブコード例で使用したデータです。
[
{
"key": "Series1",
"color": "#d62728",
"values": [
{
"label" : "Group A" ,
"value" : -1.8746444827653
} ,
{
"label" : "Group B" ,
"value" : -8.0961543492239
} ,
{
"label" : "Group C" ,
"value" : -0.57072943117674
} ,
{
"label" : "Group D" ,
"value" : -2.4174010336624
} ,
{
"label" : "Group E" ,
"value" : -0.72009071426284
} ,
{
"label" : "Group F" ,
"value" : -0.77154485523777
} ,
{
"label" : "Group G" ,
"value" : -0.90152097798131
} ,
{
"label" : "Group H" ,
"value" : -0.91445417330854
} ,
{
"label" : "Group I" ,
"value" : -0.055746319141851
}
]
},
{
"key": "Series2",
"color": "#1f77b4",
"values": [
{
"label" : "Group A" ,
"value" : 25.307646510375
} ,
{
"label" : "Group B" ,
"value" : 16.756779544553
} ,
{
"label" : "Group C" ,
"value" : 18.451534877007
} ,
{
"label" : "Group D" ,
"value" : 8.6142352811805
} ,
{
"label" : "Group E" ,
"value" : 7.8082472075876
} ,
{
"label" : "Group F" ,
"value" : 5.259101026956
} ,
{
"label" : "Group G" ,
"value" : 0.30947953487127
} ,
{
"label" : "Group H" ,
"value" : 0
} ,
{
"label" : "Group I" ,
"value" : 0
}
]
}
]
JavaScriptのdata()への関数呼び出しをdataに置き換えました:
nv.addGraph(function() {
var chart = nv.models.multiBarChart();
chart.xAxis
.tickFormat(d3.format(',f'));
chart.yAxis
.tickFormat(d3.format(',.1f'));
d3.select('#chart svg')
.datum(data)
.transition().duration(500).call(chart);
nv.utils.windowResize(chart.update);
return chart;
});
グラフはシリーズを適切にラベル付けしますが、棒は表示しません。このグラフはこのタイプのデータを取得できませんか?横棒でデータを処理しましたが、できれば縦棒を使用したいと思います。
グループ/積み上げ棒グラフ(multiBarChartモデル)は、x
およびy
属性とともに使用されます。ここで、y
は棒の高さであり、 x
はラベルで、数値またはテキストの場合があります。
残念ながら、正確なデータ形式に関するドキュメントはあまりなく、私が見つけたすべての例では、いくつかの混乱する関数を使用してデータを生成しています。だからここに私が数値とテキストのラベルを混ぜて使った例があります:
var chart = nv.models.multiBarChart();
d3.select('#chart svg').datum([
{
key: "S1",
color: "#51A351",
values:
[
{ x : "A", y : 40 },
{ x : "B", y : 30 },
{ x : 5, y : 20 }
]
},
{
key: "S2",
color: "#BD362F",
values:
[
{ x : "A", y : 60 },
{ x : "B", y : 50 },
{ x : 5, y : 70 }
]
}
]).transition().duration(500).call(chart);
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.4.11/d3.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/nvd3/1.8.1/nv.d3.min.js"></script>
<link rel="stylesheet" type="text/css" href="https://cdnjs.cloudflare.com/ajax/libs/nvd3/1.8.1/nv.d3.min.css">
<div id="chart" style="height: 200px;"><svg></svg></div>
ここで、コードに2つの問題があります。
テキストでラベル付けする軸のtickFormat
を削除する必要があります。tickFormat
関数は、軸のラベルの数値形式を設定します。ラベルを数値に変換できる場合にのみ機能し、ケースではNaN
になります。
label
およびvalue
属性の名前をx
およびy
に変更するか、これらの値を提供する関数を作成する必要があります。
var chart = nv.models.multiBarChart();
chart.x(function(d) { return d.label; });
chart.y(function(d) { return d.value; });
d3.select('#chart svg')
.datum( /* your data */ )
.transition().duration(500).call(chart);