gpt4 book ai didi

d3.js - D3如何改变SVG的宽度和长度

转载 作者:行者123 更新时间:2023-12-03 14:48:26 25 4
gpt4 key购买 nike

我在谷歌地图上创建了一个 SVG,我想控制 SVG 对象的宽度和长度

大小还可以,但问题是 SVG 的位置不在正确的位置。

我如何控制对象的位置?

我试图为

.attr("transform", "translate(" + width / 2 + "," + height / 2 + ")")

但后来尺寸不起作用。
当我还尝试添加比例并转换为投影时,大小也不起作用。
你能告诉我如何控制位置和大小吗?
SVG的第一个位置应该是相同的位置,只是大小应该改变,但位置应该始终相同。
当前的问题是,当我更改缩放比例时,SVG 也会更改位置
   <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://mbostock.github.com/d3/d3.v2.js?2.8.1"></script>
<script type="text/javascript"
src="http://maps.google.com/maps/api/js?sensor=true"></script>
<style>
html,body,#map {
width: 95%;
height: 95%;
margin: 0;
padding: 0;
}

.stations,.stations svg {
position: absolute;
}

.stations svg {
width: 60px;
height: 20px;
padding-right: 100px;
font: 10px sans-serif;
}

.stations circle {
fill: brown;
stroke: black;
stroke-width: 1.5px;
}

.background {
fill: none;
pointer-events: all;
}

#states path:hover {
stroke: white;
}

#state-titels text {
font-family: "ff-dagny-web-pro-1", "ff-dagny-web-pro-2", sans-serif;
font-size: 8px;
font-weight: 700;
font-style: normal;
font-size-adjust: none;
color: #333333;
text-transform: none;
text-decoration: none;
letter-spacing: normal;
word-spacing: 0;
text-align: start;
vertical-align: baseline;
direction: ltr;
text-overflow: clip;
}

#states path {
fill: #ccc;
stroke: #fff;
stroke-width: 1.5px;
}
</style>
</head>
<body>
<div id="map"></div>
<script type="text/javascript">
//Create the Google Map…

var first = 1;
var zoom = 2;
var map = new google.maps.Map(d3.select("#map").node(), {
zoom : 2,
center : new google.maps.LatLng(-53.76487, -110.41948),
mapTypeId : google.maps.MapTypeId.TERRAIN
});

google.maps.event.addListener(map, 'zoom_changed', function() {
zoom = map.getZoom();
});

var width = 10000, height = 1000, centered;

var projection = d3.geo.albersUsa();

var path = d3.geo.path().projection(projection);

var count = 1;

d3.json("../d3/us-states.json", function(json) {

var overlay = new google.maps.OverlayView();
overlay.onAdd = function() {


var layer = d3.select(this.getPanes().overlayLayer).append("div");

var width1 = 1000;
var height1 = 1000;
var svg = layer.append("svg").attr("width", width1).attr(
"height", height1);


var states = svg.append("g").attr("id",
"states");

states.selectAll("path").data(json.features).enter()
.append("path").attr("d", path)//.attr("transform", "scale(" + (zoom) + ")")//.each(transform)
.style("opacity", "0.7");

overlay.draw = function() {
if ( zoom == 2)
states.transition().attr("transform", "scale(" + (zoom / 8 ) + ")").style("stroke-width", 2 / zoom + "px");
else if ( zoom == 3)
states.transition().attr("transform", "scale(" + (zoom / 6 ) + ")").style("stroke-width", 2 / zoom + "px");
else if ( zoom == 4)
states.transition().attr("transform", "scale(" + (zoom / 4 ) + ")").style("stroke-width", 2 / zoom + "px");
else if ( zoom == 5)
states.transition().attr("transform", "scale(" + (zoom / 2 ) + ")").style("stroke-width", 2 / zoom + "px");

};

};

overlay.setMap(map);

});
</script>
</body>
</html>

最佳答案

除非我误解了这个问题,否则您应该能够简单地通过使用 CSS 来控制 SVG 的大小。因此,使用 d3,而不是使用 attr()使用 style() :

layer.append("svg")
.style("width", width1 + 'px')
.style("height", height1 + 'px');

同样,您可以使用 .style("left", ...) 控制位置。和 .style("top", ...) ,假设你的 svg 是绝对定位的。

关于d3.js - D3如何改变SVG的宽度和长度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10883523/

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