2016-07-14 9 views
0

シンプルなデータセット(コードとデータの下にあります)のスタックバーチャートを作成しようとしています。d3スタックバーチャートでd3-tipとCSSホバー効果を使用する

バーの上にマウスを置くと、CSSのホバー効果を使用してバーの色を変更しようとします(.barのクラスを持つrectのsvg要素)。d3-tipを使用して、バーが属する地域名。

問題は次のとおりです。 1 - CSSのホバー効果がまったく機能していません。 (下のスタイルシートをご覧ください) 2 - ツールチップが表示されていますが、マウスカーソルをバーの下から移動して入力する必要があります。マウスカーソルをバーの左/右/上から移動すると、「マウスオーバー」が検出されないように見えます。検出されない場合、バーをクリックすると、バーが検出され、ツールチップが表示されます。 3 - ツールヒントは "d.State"(リージョンの略語テキスト)のデータを表示するはずですが、私には定義されていません。 "d.State"は棒グラフ自体でうまくいきます - 軸の目盛はこれらのデータを使って作成されます。

積み重ね棒グラフは、このいずれかに基づいて行われますhttps://bl.ocks.org/mbostock/3886208

ツールチップと効果をホバーはこの1に基づいていますhttp://bl.ocks.org/Caged/6476579

のindex.html:

<!DOCTYPE html> 
<html> 
<head> 
<meta charset="utf-8"> 
<link rel="stylesheet" type="text/css" href="style.css"> 
<script src="//d3js.org/d3.v3.min.js"></script> 
<script src="http://labratrevenge.com/d3-tip/javascripts/d3.tip.v0.6.3.js"></script> 
</head> 
<body> 
<script type="text/javascript" src="viz.js"></script> 
</body> 
</html> 

すなわち。 js:

// begin of the js file 
var margin = {top: 20, right: 20, bottom: 30, left: 40}, 
    width = 320 - margin.left - margin.right, 
    height = 320 - margin.top - margin.bottom; 

var x = d3.scale.ordinal() 
    .rangeRoundBands([0, width], .1); 

var y = d3.scale.linear() 
    .rangeRound([height, 0]); 

var color = d3.scale.ordinal() 
    .range(["#98abc5", "#7b6888", "#a05d56", "#ff8c00"]); 

var xAxis = d3.svg.axis() 
    .scale(x) 
    .orient("bottom"); 

var yAxis = d3.svg.axis() 
    .scale(y) 
    .orient("left") 
    .tickFormat(d3.format(".2s")); 

//define tooltip 
var tip = d3.tip() 
    .attr('class', 'd3-tip') 
    .offset([0, 0]) 
    .html(function(d) { 
    return "<strong>Region:</strong> <span style='color:red'>" + d.State + "</span>"; 
    }); 

var svg = d3.select("body").append("svg") 
    .attr("width", width + margin.left + margin.right) 
    .attr("height", height + margin.top + margin.bottom) 
    .append("g") 
    .attr("transform", "translate(" + margin.left + "," + margin.top + ")"); 

//call tooltip 
svg.call(tip); 

d3.csv("data.csv", function(error, data) { 
    if (error) throw error; 

    color.domain(d3.keys(data[0]).filter(function(key) { return key !== "State"; })); 

    data.forEach(function(d) { 
    var y0 = 0; 
    d.ages = color.domain().map(function(name) { return {name: name, y0: y0, y1: y0 += +d[name]}; }); 
    d.total = d.ages[d.ages.length - 1].y1; 
    }); 

    data.sort(function(a, b) { return b.total - a.total; }); 

    x.domain(data.map(function(d) { return d.State; })); 
    y.domain([0, d3.max(data, function(d) { return d.total; })]); 

    svg.append("g") 
     .attr("class", "x axis") 
     .attr("transform", "translate(0," + height + ")") 
     .call(xAxis) 
     .selectAll("text") 
      .attr("font-size", 7); 

    svg.append("g") 
     .attr("class", "y axis") 
     .call(yAxis) 
     .append("text") 
     .attr("transform", "rotate(-90)") 
     .attr("y", -40) 
     .attr("dy", ".71em") 
     .style("text-anchor", "end") 
     .text("Number of Organizations"); 

    var state = svg.selectAll(".state") 
     .data(data) 
     .enter().append("g") 
     .attr("class", "g") 
     .attr("transform", function(d) { return "translate(" + x(d.State) + ",1)"; }); 

    state.selectAll(".bar") 
     .data(function(d) { return d.ages; }) 
     .enter().append("rect") 
     .attr("class", "bar") 
     .attr("width", x.rangeBand()) 
     .attr("y", function(d) { return y(d.y1); }) 
     .attr("height", function(d) { return y(d.y0) - y(d.y1); }) 
     .style("fill", function(d) { return color(d.name); }) 
     .on("mouseover", tip.show) 
     .on("mouseout", tip.hide); 

    var legend = svg.selectAll(".legend") 
     .data(color.domain().slice().reverse()) 
     .enter().append("g") 
     .attr("class", "legend") 
     .attr("transform", function(d, i) { return "translate(0," + i * 20 + ")"; }); 

    legend.append("rect") 
     .attr("x", width - 18) 
     .attr("width", 18) 
     .attr("height", 18) 
     .style("fill", color); 

    legend.append("text") 
     .attr("x", width - 24) 
     .attr("y", 9) 
     .attr("dy", ".35em") 
     .style("text-anchor", "end") 
     .text(function(d) { return d; }); 
}); 
// end of the js file 

style.css:

body { 
    font: 10px sans-serif; 
} 

.axis path, 
.axis line { 
    fill: none; 
    stroke: #000; 
    shape-rendering: crispEdges; 
} 

.bar:hover { 
    fill: steelblue; 
    pointer-events: all; 
} 

.x.axis path { 
    display: none; 
} 

.d3-tip { 
    line-height: 1; 
    font-weight: bold; 
    padding: 12px; 
    background: rgba(0, 0, 0, 0.8); 
    color: #fff; 
    border-radius: 2px; 
} 

/* Creates a small triangle extender for the tooltip */ 
.d3-tip:after { 
    box-sizing: border-box; 
    display: inline; 
    font-size: 10px; 
    width: 100%; 
    line-height: 1; 
    color: rgba(0, 0, 0, 0.8); 
    content: "\25BC"; 
    position: absolute; 
    text-align: center; 
} 

/* Style northward tooltips differently */ 
.d3-tip.n:after { 
    margin: -1px 0 0 0; 
    top: 100%; 
    left: 0; 
} 

data.csv:

State,Non Profit,For Profit,Developer Group,Other 
EP,28,142,15,16 
EC,81,292,39,22 
LC,73,91,23,9 
MN,3,5,2,1 
NA,102,561,26,19 
SA,11,49,9,4 
SS,28,10,10,3 

いずれかの部分が明確ではないがある場合は私に知らせてください。私はd3とstackoverflowの新しいです。ありがとう!

答えて

0
  1. CSSホバー効果は全く機能していません。(私は推測行方不明になったではない?)

    問題は、それがすでにD3を使用して充填したでした。オーバーライドするには、ホバーフィルに重要なものを追加してください。

    fill:steelblue!important;

  2. ツールチップが表示されていますが、マウスカーソルをバーの下から移動して入力する必要があります。マウスカーソルを左/右/上から動かすと(コードに問題はありませんでした)

    私は正確に何が問題なのかよくわかりませんが、私の推測はonmouseoverですあなたがそれに乗るときにのみ動作します。したがって、マウスポインタが生成される前に既にグラフ上にある場合、ツールチップは表示されません。

  3. ツールチップは、「d.State」のデータを表示することになっています。

    ここでの問題は、状態データが要素に添付されていない、つまりd.agesに状態値が含まれていないことです。データをバインドしている間に状態値を付加するだけです。

var margin = {top: 20, right: 20, bottom: 30, left: 40}, 
 
    width = 320 - margin.left - margin.right, 
 
    height = 320 - margin.top - margin.bottom; 
 

 
var x = d3.scale.ordinal() 
 
    .rangeRoundBands([0, width], .1); 
 

 
var y = d3.scale.linear() 
 
    .rangeRound([height, 0]); 
 

 
var color = d3.scale.ordinal() 
 
    .range(["#98abc5", "#7b6888", "#a05d56", "#ff8c00"]); 
 

 
var xAxis = d3.svg.axis() 
 
    .scale(x) 
 
    .orient("bottom"); 
 

 
var yAxis = d3.svg.axis() 
 
    .scale(y) 
 
    .orient("left") 
 
    .tickFormat(d3.format(".2s")); 
 

 
//define tooltip 
 
var tip = d3.tip() 
 
    .attr('class', 'd3-tip') 
 
    .offset([0, 0]) 
 
    .html(function(d) { 
 
    return "<strong>Region:</strong> <span style='color:red'>" + d.State + "</span>"; 
 
    }); 
 

 
var svg = d3.select("body").append("svg") 
 
    .attr("width", width + margin.left + margin.right) 
 
    .attr("height", height + margin.top + margin.bottom) 
 
    .append("g") 
 
    .attr("transform", "translate(" + margin.left + "," + margin.top + ")"); 
 

 
//call tooltip 
 
svg.call(tip); 
 

 
d3.csv("data.csv", function(error, data) { 
 
    if (error) throw error; 
 

 
    color.domain(d3.keys(data[0]).filter(function(key) { return key !== "State"; })); 
 

 
    data.forEach(function(d) { 
 
    var y0 = 0; 
 
    d.ages = color.domain().map(function(name) { return {name: name, y0: y0, y1: y0 += +d[name]}; }); 
 
    d.total = d.ages[d.ages.length - 1].y1; 
 
    }); 
 

 
    data.sort(function(a, b) { return b.total - a.total; }); 
 

 
    x.domain(data.map(function(d) { return d.State; })); 
 
    y.domain([0, d3.max(data, function(d) { return d.total; })]); 
 

 
    svg.append("g") 
 
     .attr("class", "x axis") 
 
     .attr("transform", "translate(0," + height + ")") 
 
     .call(xAxis) 
 
     .selectAll("text") 
 
      .attr("font-size", 7); 
 

 
    svg.append("g") 
 
     .attr("class", "y axis") 
 
     .call(yAxis) 
 
     .append("text") 
 
     .attr("transform", "rotate(-90)") 
 
     .attr("y", -40) 
 
     .attr("dy", ".71em") 
 
     .style("text-anchor", "end") 
 
     .text("Number of Organizations"); 
 

 
    var state = svg.selectAll(".state") 
 
     .data(data) 
 
     .enter().append("g") 
 
     .attr("class", "g") 
 
     .attr("transform", function(d) { return "translate(" + x(d.State) + ",1)"; }); 
 

 
    state.selectAll(".bar") 
 
     .data(function(d) { 
 
\t \t for(var l = 0 ; l < d.ages.length ; l++) { 
 
\t \t \t d.ages[l].State = d.State; 
 
\t \t } 
 
\t \t return d.ages; }) 
 
     .enter().append("rect") 
 
     .attr("class", "bar") 
 
     .attr("width", x.rangeBand()) 
 
     .attr("y", function(d) { 
 
\t \t return y(d.y1); }) 
 
     .attr("height", function(d) { return y(d.y0) - y(d.y1); }) 
 
     .style("fill", function(d) { return color(d.name); }) 
 
     .on("mouseover", tip.show) 
 
     .on("mouseout", tip.hide); 
 

 
    var legend = svg.selectAll(".legend") 
 
     .data(color.domain().slice().reverse()) 
 
     .enter().append("g") 
 
     .attr("class", "legend") 
 
     .attr("transform", function(d, i) { return "translate(0," + i * 20 + ")"; }); 
 

 
    legend.append("rect") 
 
     .attr("x", width - 18) 
 
     .attr("width", 18) 
 
     .attr("height", 18) 
 
     .style("fill", color); 
 

 
    legend.append("text") 
 
     .attr("x", width - 24) 
 
     .attr("y", 9) 
 
     .attr("dy", ".35em") 
 
     .style("text-anchor", "end") 
 
     .text(function(d) { return d; }); 
 
});
body { 
 
    font: 10px sans-serif; 
 
} 
 

 
.axis path, 
 
.axis line { 
 
    fill: none; 
 
    stroke: #000; 
 
    shape-rendering: crispEdges; 
 
} 
 

 
.bar:hover { 
 
    fill: steelblue !important; 
 
    pointer-events: all; 
 
} 
 

 
.x.axis path { 
 
    display: none; 
 
} 
 

 
.d3-tip { 
 
    line-height: 1; 
 
    font-weight: bold; 
 
    padding: 12px; 
 
    background: rgba(0, 0, 0, 0.8); 
 
    color: #fff; 
 
    border-radius: 2px; 
 
} 
 

 
/* Creates a small triangle extender for the tooltip */ 
 
.d3-tip:after { 
 
    box-sizing: border-box; 
 
    display: inline; 
 
    font-size: 10px; 
 
    width: 100%; 
 
    line-height: 1; 
 
    color: rgba(0, 0, 0, 0.8); 
 
    content: "\25BC"; 
 
    position: absolute; 
 
    text-align: center; 
 
} 
 

 
/* Style northward tooltips differently */ 
 
.d3-tip.n:after { 
 
    margin: -1px 0 0 0; 
 
    top: 100%; 
 
    left: 0; 
 
}
<!DOCTYPE html> 
 
<html> 
 
<head> 
 
<meta charset="utf-8"> 
 
<link rel="stylesheet" type="text/css" href="style.css"> 
 
<script src="//d3js.org/d3.v3.min.js"></script> 
 
<script src="http://labratrevenge.com/d3-tip/javascripts/d3.tip.v0.6.3.js"></script> 
 
</head> 
 
<body> 
 
<script type="text/javascript" src="viz.js"></script> 
 
</body> 
 
</html>

+0

ありがとうございました!私はそれがすべての私の問題を解決すると思う:) – Noah

関連する問題