1

已解决:jsfiddle

问题 #1:有一个分组条形图。如果组中的任何条被鼠标悬停,我希望该组突出显示。

目前在鼠标悬停时,将所有具有“bar”类的矩形设置为不透明度 0.5,然后将特定矩形设置为不透明度 1。但是如何将节点或条组设置为不透明度 1,以便它们与其他矩形突出显示?

.on("mouseover", function(d, i, node) { //this is repeated should be in a function
        d3.selectAll(".bar").transition()
          .style("opacity", 0.3); //all groups given opacity 0
        d3.select(this).transition()
          .style("opacity", 1); //give opacity 1 to group on which it hovers.
        return tooltip
          .style("visibility", "visible")
          .html("<span style=font-size:30px;> " + "name:" + d.name +
            "</span>"
          )
      })
      .on("mouseout", function(d) {
        d3.selectAll(".bar").transition()
          .style("opacity", 1);
        return tooltip.style("visibility", "hidden");
      })

问题 #2:我也希望条形图的 x 轴标签表现类似。这样除当前条形之外的所有名称都具有不透明度 0.5

我确实尝试在 xAxis 文本中添加一个 bar 类,但不起作用,

.call(xAxis)
      .selectAll("text")
      .style("text-anchor", "end")
      .style("font", "20px times")
      .attr("dx", "-.8em")
      .attr("dy", ".15em")
      .attr("class", "bar")
      .attr("transform", "rotate(-65)");

我尝试从这篇文章中实现想法

D3 分组条形图 - 选择整个组?

但我无法让它工作。

我尝试为组中的每个条提供一个 d.name + index 类。但是我不能选择,返回“。” + d.name 没有像我预期的那样工作。

      .attr("class", function(d, i) {
       return d.name.replace(/\s/g, '') + i + " bar"
      })
      .on("mouseover", function(d, i, node) { 
        d3.selectAll(".bar").transition()
          .style("opacity", 0.3); 
        d3.selectAll("." + d.name.replace(/\s/g) + i)
          .transition()
          .style("opacity", 1); 
        return tooltip
          .style("visibility", "visible")
          .html("<span style=font-size:30px;> " + "name:" + d.name +
            "</span>");
      })

选择应该是,

d3.selectAll("." + d.name.replace(/\s/g, '') + i)

实际上,每个组中的每个条都可以被赋予一个“组+索引”类。不需要正则表达式。

除了 xAxis 上的文本外,突出显示现在工作正常。

任何帮助将不胜感激,

谢谢

4

2 回答 2

2

您可以将所有条的不透明度基于其 .name 值(在您的示例中这是每个组的通用属性),例如

.on("mouseover", function(d) { 
    let selectedName = d.name;
    d3.selectAll(".bar")
      .style("opacity", function(d) {
        return d.name == selectedName ? 1 : 0.3;
      })

    //etc
于 2017-08-09T23:07:04.760 回答
0

这适用于jsFiddle

.on("mouseover", function(d, i, node) {
        d3.selectAll(".bar").transition()
          .style("opacity", 0.3);
        d3.selectAll(".xAxisText").transition()
          .style("fill", "lightgray")
          .style("font-weight", "100"); //all groups given opacity 0
        d3.selectAll(".groupText" + i)
          .transition()
          .style("font-weight", "900")
          .style("fill", "black"); //give opacity 1 to group on which it hovers.
        d3.selectAll(".group" + i)
          .transition()
          .style("opacity", 1);
        return tooltip
          .style("visibility", "visible")
          .html("<span style=font-size:30px;> " + "name: " + d.name +
            " (on blue bar)</span>");
      })
      .on("mouseout", function(d) {
        d3.selectAll(".bar").transition()
          .style("opacity", 1);
        d3.selectAll(".xAxisText").transition()
          .style("fill", "black")
          .style("font-weight", "normal");
        return tooltip.style("visibility", "hidden");
      })
于 2017-08-10T15:07:52.800 回答