【问题标题】:Tooltip scaled(zoom) along with d3 geo map工具提示缩放(缩放)以及 d3 地理地图
【发布时间】:2016-05-07 19:17:02
【问题描述】:

我正在绘制带有缩放和平移功能的世界地图。我在某些城市上画圆,圆的半径是由数据决定的。当鼠标悬停在这些圆圈上时,会出现一个工具提示来显示数据。

代码的结构是 // 在此选择上调用缩放行为 - 让我们调用此 parentGroup
// 捕获所有鼠标和触摸事件 // 调用这个子组 // 隐藏工具提示组 - 将在鼠标悬停时显示/隐藏 // 调用这个工具提示组

这里的问题是

  1. 如果 toolTipGgroup 附加到 parentGroup 并作为 childGroup 的兄弟,然后当地图缩放时提示 位置乱了。我尝试从投影中获取 (x,y) 并在工具提示上应用了 translate(x,y) 。 tooltipGroup 是 已翻译,但由于应用了缩放,因此无关紧要。
  2. 如果toolTipGroup附加到childGroup,当地图是 缩放 toolTipGroup 的位置是完整的,但它随着缩放 子组。 如何阻止工具提示随地图缩放(保持其原始大小)?

注意:我通过在缩放行为的回调中使用新的radius = oldRadius/currentScale重新绘制每个圆圈来控制圆圈的大小

【问题讨论】:

标签: javascript html d3.js charts maps


【解决方案1】:

我不明白你的陈述The negation of scale works on an image but in my case it doesnt work on a toolTipGroup (includes text, rect image and path)。这应该可以正常工作,将其全部包装在 g 中并反向缩放。棘手的部分是重新计算工具提示相对于缩放的位置。这是一个快速示例,它在我的家乡马里兰州巴尔的摩市放置了一个工具提示:

<!DOCTYPE html>
<meta charset="utf-8">
<style>

.states {
  fill: none;
  stroke: #fff;
  stroke-linejoin: round;
}

</style>
<body>
<script src="//d3js.org/d3.v3.min.js"></script>
<script src="//d3js.org/topojson.v1.min.js"></script>
<script>

var width = 960,
    height = 500;

var fill = d3.scale.log()
    .domain([10, 500])
    .range(["brown", "steelblue"]);

var path = d3.geo.path();

var svg = d3.select("body").append("svg")
    .attr("width", width)
    .attr("height", height);
    
var zoom = d3.behavior.zoom()
    .scaleExtent([1, 15])
    .on("zoom", zoomed);
    
svg.append("rect")
    .attr("class", "overlay")
    .attr("width", width)
    .attr("height", height);
    
var g = svg.append("g");

var tooltip,
    tipPosition = [722, 160],
    tipSize = [85,50];
    
d3.json("https://rawgit.com/mbostock/topojson/master/examples/us-10m.json", function(error, us) {
  if (error) throw error;

  g.append("g")
      .attr("class", "counties")
    .selectAll("path")
      .data(topojson.feature(us, us.objects.counties).features)
    .enter().append("path")
      .attr("d", path)
      .style("fill", function(d) { return fill(path.area(d)); });

  g.append("path")
      .datum(topojson.mesh(us, us.objects.states, function(a, b) { return a.id !== b.id; }))
      .attr("class", "states")
      .attr("d", path);
      
      tooltip = g.append("g")
  .attr("transform","translate(" + tipPosition + ")")
  .attr("class","tooltip");

tooltip
  .append("rect")
  .style("fill", "steelblue")
  .attr("width", tipSize[0])
  .attr("height", tipSize[1] - 10)
  .attr("rx", "10")
  
tooltip
  .append("path")
  .attr("d", function(){
    var rv = "";
    rv += "M";
    rv += tipSize[0]/2 - 5;
    rv += ","
    rv += tipSize[1] - 10;
    rv += "L";
    rv += tipSize[0]/2 + 5;
    rv += ","
    rv += tipSize[1] - 10;
    rv += "L";
    rv += tipSize[0]/2;
    rv += ","
    rv += tipSize[1];
    rv += "Z";
    return rv;
  })
  .style("fill", "steelblue");
  
tooltip
  .append("text")
  .text("Baltimore")
  .attr("transform","translate(" + (tipSize[0]/2) + "," + (tipSize[1]/2) + ")")
  .attr("text-anchor", "middle")
  .style("fill","black")
  .style("font-family","arial");
  
 svg
    .call(zoom)
    .call(zoom.event);
});


function zoomed() {
  // apply zoom
  g.attr("transform", "translate(" + d3.event.translate + ")scale(" + d3.event.scale + ")");
  // calculate position with respect to zoom
  var trans = [tipPosition[0]  + (tipSize[0]/2 * (1-1/d3.event.scale)), tipPosition[1] + (tipSize[1] * (1-1/d3.event.scale))];
  // inverse scale zoom
  tooltip.attr("transform", "translate(" + trans + ")scale(" + 1/d3.event.scale +")")
}

</script>

【讨论】:

    【解决方案2】:

    将 Tooltip 组移出路径组为我解决了这个问题。但是我必须计算获取鼠标指针的位置来计算先前根据圆心自动计算的工具提示位置。

    【讨论】:

      猜你喜欢
      • 2017-07-11
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-12-17
      • 1970-01-01
      • 2014-11-07
      • 2014-03-06
      • 2016-11-04
      相关资源
      最近更新 更多