概述
本文讲述在echart下基于行政区划的地图逐级钻取功能。主要实现:
1、点击地图展示下一级地图;
2、通过区域导航可返回上一级地图;
效果
1.png
data:image/s3,"s3://crabby-images/4f5ac/4f5ac275673267bbacad05a5b4710853077b0fb9" alt=""
data:image/s3,"s3://crabby-images/f9e3d/f9e3d3838357fe8e8f44a5f8829b15a830511e98" alt=""
实现代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>map</title>
<style>
html, body, #map{
margin: 0;
padding: 0;
overflow: hidden;
width: 100%;
height: 100%;
}
.zone-nav{
position: absolute;
top:10px;
left: 10px;
padding: 5px 10px;
z-index: 99;
background: #fff;
box-shadow: 1px 1px 2px #ccc;
border-radius: 4px;
}
.zone-nav a{
font-size: 13px;
text-decoration: none;
color: black;
}
</style>
</head>
<body>
<div class="zone-nav" id="nav">
<a href="#" id="boundry" title="全国" index="0">全国</a>
<a href="#" id="province" index="1"></a>
<a href="#" id="city" index="2"></a>
</div>
<div id="map"></div>
<script src="../../plugin/jquery/jquery-3.1.1.min.js"></script>
<script src="../../plugin/echart3/echarts-all-3.js"></script>
<script>
var mapDatas = {
"全国": "china.json",
};
var index = 0,
chart = null;
addMap("全国");
$("#boundry, #province, #city").on("click", function () {
index = parseInt($(this).attr("index"));
addMap($(this).attr("title"));
});
function addMap(zone) {
switch (index){
case 1:{
$("#province").html(">>"+zone).attr("title", zone);
$("#city").html("");
break;
}
case 2:{
$("#city").html(">>"+zone).attr("title", zone);
break;
}
default:{
$("#province").html("");
$("#city").html("");
break;
}
}
if(chart) chart.dispose();
chart = echarts.init(document.getElementById('map'));
chart.on('click', function (result) {
index++;
if(index<3){
addMap(result.name);
}
});
var url = "./mapdata/";
if(index===1){//省级
url+="geometryProvince/";
}else if(index===2){
url+="geometryCouties/";
}
url+=mapDatas[zone];
$.get(url, function (mapdata) {
var features = mapdata.features;
for(var i=0;i<features.length;i++){
var feature = features[i];
if(!mapDatas[feature.properties.name]){
var jsonfile = feature.properties.id;
if(index===1) jsonfile+="00";
mapDatas[feature.properties.name] = jsonfile + ".json";
}
}
echarts.registerMap(zone, mapdata);
chart.setOption({
roam: true,
series: [{
type: 'map',
map: zone,
scaleLimit: { min: 0.8, max: 1.9 },//缩放
mapLocation:{
y:60
},
itemSytle:{
emphasis:{label:{show:false}}
},
label: {
normal: {
show: true
},
emphasis: {
show: true
}
},
data : []
}]
});
});
}
</script>
</body>
</html>
说明:
- 数据组织结构如下
├─mapdata
│ ├─china.json
│ ├─geometryCouties
│ │ ├─110100.json
│ │ ├─120100.json
│ │ └─...
│ ├─geometryProvince
│ │ ├─11.json
│ │ ├─12.json
│ │ └─... - 数据和源代码可从地址获得。
技术博客
CSDN:http://blog.csdn.NET/gisshixisheng
在线教程
https://edu.csdn.net/course/detail/799
https://edu.csdn.net/course/detail/7471
联系方式
类型 | 内容 |
---|---|
1004740957 | |
公众号 | lzugis15 |
niujp08@qq.com | |
webgis群 | 452117357 |
Android群 | 337469080 |
GIS数据可视化群 | 458292378 |
“GIS讲堂”知识星球开通了,在星球,我将提供一对一的问答服务,你问我答,期待与你相见。
data:image/s3,"s3://crabby-images/18242/18242e1e656f8e24fd1af0874bf8c2103cec0acf" alt=""
网友评论