[英]Plot polygon using D3
我正在嘗試使用 .json 文件繪制多邊形。
*編輯以添加樣本坐標
{ "type": "FeatureCollection", "features": [ {
"type": "Feature",
"geometry": {
"type": "Polygon",
"coordinates": [
[
[
-0.0691250297447329,
51.5462448874379
],
[
-0.0691510961928943,
51.5459630404703
],
[
-0.0692056531364391,
51.5456827414947
],
[
-0.0692883661627076,
51.5454050640766
],
[
-0.0693070134960316,
51.545356361588
],.....
腳本看起來像
var width = 960;
var height = 600;
var svg = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height);
d3.json("/GeoJsonFiles/samplePolygon1.json", function (error, json) {
if (error) console.error(error);
var projection = d3.geoMercator()
.fitSize([width, height], json);
var path = d3.geoPath().projection(projection);
svg.selectAll("path")
.data(json.features)
.enter()
.append("path")
.attr("d", path)
.attr("fill", "gray")
.attr("stroke", "black");});
據我所知,沒有錯誤,但 svg 沒有顯示任何內容。 我也嘗試過scale()
center()
和offset()
。 到目前為止沒有任何效果。 這是我的第一個 D3 腳本 - 提供幫助。
發現這個D3 多邊形原來下面的代碼是必不可少的。
.attr("points", function (d) {
return d.map;
})
完整代碼如下。
d3.json("/GeoJsonFiles/samplePolygon1.json", function (error, json) {
if (error) console.error(error);
var projection = d3.geoMercator()
.fitSize([width, height], json);
var path = d3.geoPath().projection(projection);
svg.selectAll("path")
.data([json])
.enter()
.append("path")
.attr("points", function (d) {
return d.map;
})
.attr("d", path)
.attr("fill", "gray")
.attr("stroke", "black");
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.