2016-06-21 169 views
0

我在D3中有一個具有兩個「級別」數據的分層條形圖,我想顯示具有兩個不同項目的圖例。將圖例添加到D3中的hierchical條形圖中

當用戶單擊條形圖值X進入下一級時,我希望X(即字符串)的值出現在新圖表的圖例中。這樣,用戶總是知道他們剛剛點擊了什麼價值/類別。

圖例的第二部分是我希望圖表上所有值的聚合計數顯示在某處。所以如果我有一個值爲10,15,25的圖表,我希望能夠在圖表的圖例中顯示50。

回答

1

我會asumme你與這個工作:http://bl.ocks.org/mbostock/1283663

第一添加文字:

var parent = svg.append("text").attr("x",-margin.left).attr("y",0) 

下來功能更新文本:

parent.text("Position:"+d.name+" Value:"+d.value) 

功能:

parent.text("Position:"+d.parent.name+" Value:"+d.parent.value) 

這裏working code

如果你不想顯示根:

功能:

if (d.name == "flare") { 
    parent.text("") 
    } else { 
    parent.text("Position:"+d.name+" Value:"+d.value) 
    } 

功能:

if (d.parent.name == "flare") { 
    parent.text("") 
    } else { 
    parent.text("Position:"+d.name+" Value:"+d.parent.value) 
    } 

要在每個名稱欄後顯示值,請調整功能欄(d):

bar.append("text") 
     .attr("x", -6) 
     .attr("y", barHeight/2) 
     .attr("dy", ".35em") 
     .style("text-anchor", "end") 
     .text(function(d) { return d.name+" : "+d.value; }); // <-- Here made mods 
+0

非常有趣的方法。如何修改它以便在圖表第一次打開時不顯示新的文本元素?我希望文本元素最初爲空白,然後只在用戶單擊欄時才更改。 –

+0

「Flare」它的根。如果(root)沒有顯示,則可以在根目錄中輸入簡單的空名稱,也可以添加條件。 – Klaujesi

+0

非常感謝你的回答。我習慣於D3如此複雜,以至於我很喜歡這種簡單的方式。 –