20

nvd3 を使用して積み上げ縦棒グラフを作成しようとしています。ウェブサイトの例のようにランダムに生成された値とは対照的に、個別のデータ値を使用します。

グループ/積み上げ棒グラフのライブ コード例を試してみて、独自の値を含む JSON データを挿入しました。私が試みたのは、横棒グラフから JSON データを取得し、それを縦棒グラフのデータとして配置することでした。

これは、グループ/積み上げ棒グラフのデータの代わりにライブ コード例で使用したデータです。

[
  {
    "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;
});

グラフはシリーズに適切にラベルを付けていますが、バーは表示されません。このグラフはこのタイプのデータを取りませんか? 水平バーを使用してデータを処理しましたが、可能であれば垂直バーを使用したいと考えています。

4

1 に答える 1

44

グループ/スタック棒グラフ(multiBarChartモデル)はxy属性とともに使用されます。ここ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つの問題があります。

  1. tickFormatテキストでラベル付けする予定のfor軸を削除する必要があります。
    このtickFormat関数は、軸のラベルの数値形式を設定します。これは、ラベルを数値に変換できる場合にのみ機能し、結果としてNaNあなたのケースになります。

  2. 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); 
    
于 2012-11-24T13:39:23.090 に答える