使用D3.js和GeoJson在地图上显示States上的一些文本
Displaying some text on States on Map using D3.js and GeoJson
我一直在使用Storm和Redis,为了可视化从Redis获取的数据,我需要渲染一张地图(印度)并根据状态放置数据。我已经正确地绘制了地图,但不知道如何在各自的州边界内显示文本。任何帮助都将不胜感激。谢谢
<!DOCTYPE html>
<html lang="en">
<head>
<title>Visualization Demo</title>
<script type="text/javascript" src="d3.min.js"></script>
<script type="text/javascript" src="d3.geo.min.js"></script>
<link type="text/css" rel="stylesheet" href="color-scheme.css"/>
<style type="text/css">
svg {
background: #282828;
}
body {
background: #282828;
}
h1 {
color:#999999;
}
#india {
fill: #99FFCC;
opacity: .9;
stroke: white;
stroke-width: 1.0;
}
#chart {
margin-left:150px;
}
</style>
</head>
<body>
<h1><center>VISUALIZATION</center></h1>
<div id="chart"></div>
<script type="text/javascript">
var w = 1000;
var h = 1500;
var proj = d3.geo.mercator();
var path = d3.geo.path().projection(proj);
var t = proj.translate(); // the projection's default translation
var s = proj.scale() // the projection's default scale
var map = d3.select("#chart").append("svg:svg")
.attr("width", w)
.attr("height", h)
.call(initialize);
var india = map.append("svg:g")
.attr("id", "india");
d3.json("india-states.json", function (json) {
india.selectAll("path")
.data(json.features)
.enter().append("path")
.attr("d", path);
});
function initialize() {
proj.scale(9000);
proj.translate([-1520, 1000]);
}
</script>
</body>
</html>
在d3.json
函数中试试这个:
india.selectAll("text")
.data(json.features)
.enter()
.append("text")
.attr("fill", "black")
.attr("transform", function(d) {
var centroid = path.centroid(d);
return "translate(" + centroid[0] + "," + centroid[1] + ")"
})
.attr("text-anchor", "middle")
.attr("dy", ".35em")
.text(function(d) {
return d.properties.STATE_NAME;
});
您可能没有properties.STATE_NAME
作为状态的名称,但只需在JSON中检查一下您应该在这里使用什么。
相关文章:
- 从桌面读取python文件时高亮显示代码
- 使用JS如何动态更改显示的html文件中的文本背景颜色
- 如何在生成下载文件时显示加载动画
- React重新渲染但未显示正确的组件
- nodejs-expressjs上传图像并显示它们
- 使用JSP从服务器检索和显示图像
- 音频控件在mouseover上显示,在mouseout上淡出
- 让文本输入幻灯片显示输入时的新文本输入?然后向后滑动
- 使用电话间隙在Android应用程序中显示SQL Lite的数据
- 显示5秒后隐藏潜水
- 画廊图像未显示
- 不显示带有本地json文件数据的谷歌地图脚本
- 如何将json数据显示为html
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- Windows8应用程序(html&Javascript):从图片库(除了文件选择器)显示图像的另一种方式
- 高亮显示时编辑文本大小和颜色
- 有时数据是't显示在浏览器中
- 当鼠标悬停在文本中的单词上时显示警报
- 角度图表;t显示在我的页面中
- 使用D3.js和GeoJson在地图上显示States上的一些文本