gpt4 book ai didi

javascript - 工具提示随 d3 地理 map 缩放(缩放)

转载 作者:行者123 更新时间:2023-11-28 06:26:22 27 4
gpt4 key购买 nike

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

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

这里的问题是

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

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

enter image description here enter image description here enter image description here

最佳答案

我不明白你的说法比例的否定适用于图像,但就我而言,它不适用于toolTipGroup(包括文本、矩形图像和路径)。这应该可以正常工作,将其全部包装在 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>

关于javascript - 工具提示随 d3 地理 map 缩放(缩放),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35094944/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com