var parentJson = null;
var parentInfo = [{
cityName: '河南',
level: 'city',
code: 410000,
},
];
getGeoJson(410000);
var timeFn = null;
// 利用高德api获取行政区边界geoJson
// adcode 行政区code 编号
function getGeoJson(adcode) {
AMapUI.loadUI(['geo/DistrictExplorer'], (DistrictExplorer) => {
var districtExplorer = new DistrictExplorer();
districtExplorer.loadAreaNode(adcode, function (error, areaNode) {
if (error) {
console.error(error);
return;
}
let Json = areaNode.getSubFeatures();
if (Json.length > 0) {
parentJson = Json;
} else if (Json.length === 0) {
Json = parentJson.filter((item) => {
if (item.properties.adcode == adcode) {
return item;
}
});
if (Json.length === 0) return;
}
proceData(Json);
});
});
} //处理数据
function proceData(Json) {
let mapData = [{
name: '郑州市',
cityCode: '410100',
value: '460',
},
{
name: '开封市',
cityCode: '410200',
value: '1372',
},
{
name: '洛阳市',
cityCode: '410300',
value: '851',
},
{
name: '平顶山市',
cityCode: '410400',
value: '720',
},
{
name: '安阳市',
cityCode: '410500',
value: '1139',
},
{
name: '鹤壁市',
cityCode: '410600',
value: '772',
},
{
name: '新乡市',
cityCode: '410700',
value: '8143',
},
{
name: '焦作市',
cityCode: '410800',
value: '723',
},
{
name: '濮阳市',
cityCode: '410900',
value: '705',
},
{
name: '许昌市',
cityCode: '411000',
value: '448',
},
{
name: '漯河市',
cityCode: '411100',
value: '1194',
},
{
name: '三门峡市',
cityCode: '411200',
value: '560',
},
{
name: '南阳市市',
cityCode: '411300',
value: '373',
},
{
name: '商丘市',
cityCode: '411400',
value: '4543',
},
{
name: '信阳市',
cityCode: '411500',
value: '716',
},
{
name: '周口市',
cityCode: '411600',
value: '521',
},
{
name: '驻马店市',
cityCode: '411700',
value: '1075',
},
{
name: '济源市',
cityCode: '419001',
value: '285',
}, ];
Json.map((item) => {
mapData.forEach((ele) => {
if (item.properties.adcode == ele.cityCode) {
ele.level = item.properties.level;
}
});
});
let mapJson = {};
//geoJson必须这种格式
mapJson.features = Json; //去渲染echarts
initEcharts(mapData, mapJson);
} function initEcharts(mapData, mapJson) {
let valArr = [];
mapData.map(function (i) {
valArr.push(i.value);
});
// 计算数据最大与最小值用于数据映射组件
let max = Math.max.apply(null, valArr);
let min = Math.min.apply(null, valArr);
//注册
echarts.registerMap('Map', mapJson); //这里加true是为了让地图重新绘制,不然如果你有筛选的时候地图会飞出去
myChart.setOption(
{
backgroundColor: 'rgb(20,28,52)',
tooltip: {
trigger: 'item',
},
visualMap: {
type: 'piecewise',
min: min,
max: max,
splitNumber: 5,
left: 35,
bottom: 50,
itemWidth: 21,
itemHeight: 8,
showLabel: false,
orient: 'horizontal',
text: ['高', '低'],
itemGap: 2,
textStyle: {
color: '#fff',
},
inRange: '',
color: [
'rgba(7, 83, 114,0.8)',
'rgba(24, 100, 141,0.9)',
'rgba(33, 122, 168,0.8)',
'rgba(28, 138, 187,0.7)',
'rgba(34, 156, 199,0.8)',
],
show: true,
}, series: [{
name: '地图',
type: 'map',
map: 'Map',
roam: true, //是否可缩放
zoom: 1, //缩放比例
aspectScale: 0.9, //长宽比0.75
data: mapData,
itemStyle: {
normal: {
show: true,
areaColor: '#2E98CA',
borderColor: 'rgb(185, 220, 227)',
borderWidth: '1',
},
},
label: {
normal: {
show: true, //显示省份标签
textStyle: {
color: 'rgb(249, 249, 249)', //省份标签字体颜色
fontSize: 12,
},
},
emphasis: {
//对应的鼠标悬浮效果
show: true,
textStyle: {
color: '#000',
},
},
},
},
],
},
true
);
// 单击下钻
} //echarts点击事件
myChart.on('click', (params) => {
clearTimeout(timeFn);
timeFn = setTimeout(function () {
// 无下级地图数据时不下钻
if (!params.value) {
alert('暂无数据');
return;
}
//如果当前是最后一级,那就直接return
if (parentInfo[parentInfo.length - 1].code == params.data.cityCode) {
return;
}
let data = params.data;
parentInfo.push({
cityName: data.name,
level: data.level,
code: data.cityCode,
});
getGeoJson(data.cityCode);
},
250);
}); // 绑定双击事件,返回上级地图
myChart.on('dblclick', function (params) {
clearTimeout(timeFn);
if (parentInfo.length < 1) {
return;
}
if (parentInfo.length === 1) {
getGeoJson(parentInfo[parentInfo.length - 1].code);
return;
}
parentInfo.pop();
getGeoJson(parentInfo[parentInfo.length - 1].code);
});

Echarts河南地图下钻的更多相关文章

  1. Echarts Map地图下钻至县级

    **准备工作:**1.首先使用vue-cli的脚手架生成vue项目. 2.然后使用npm安装echartsnpm install echarts -S 3.安装完后再mian.js中挂载到vue的实例 ...

  2. 数据视化Echarts+百度地图API实现市县区级下钻

    开始 这两天公司有个页面需要做数据可视化的展示,数据视化采用的是Echarts+百度地图API做展示,需要用到县级区级下钻的一个联动效果发现网上关于Echarts做到县区级下钻的资料很少,有的话也不是 ...

  3. 关于echarts地图下钻。

     在去年十二月份,前端老大交代个任务,关于地图下钻.这里做了个简单的青岛地图下钻,初学echarts,做的不精,凑合看看吧. 第一步呢,先引入echarts等文件,这是最基本的.  第二步,到官网下载 ...

  4. vue 下实现 echarts 全国到省份的地图下钻

    vue 下实现 echarts 全国到省份的地图下钻 项目地址:https://github.com/cag2050/vue_echarts_v3_demo

  5. vue+echarts可视化大屏,全国地图下钻,页面自适应

    之前写过一篇关于数据大屏及地图下钻的文章 https://www.cnblogs.com/weijiutao/p/13977011.html ,但是存在诸多问题,如地图边界线及行政区划老旧,无法自适应 ...

  6. echarts map地图中绘制浙江省市区县乡镇多级联动边界下钻的最新geojson数据文件获取和更新

    目录 ECharts Map地图的显示 GeoJSON数据文件获取 在ECharts中绘制浙江省的数据 ECharts Map地图的显示 ECharts支持地理坐标显示,专门提供了一个geo组件,在s ...

  7. 关于echarts3地图下钻省市

    最近关于echarts3弄了个地图下钻,也许是因为运气不好,开始上来需要传递到的城市是成都,结果成都地图(js)加载下来总是挤到了一起,好尴尬,各方实验查找后发现原来是js文件中,成都市地图有个县市并 ...

  8. echarts Map(地图) 不同颜色区块显示

    以河南地图为例: 代码如下: <h3>天翼日必达完成率</h3> <div id="map" style="height:340px; te ...

  9. echarts的地图点击事件

    1.echarts的地图展示,有时候展示出的数据,虽然鼠标点击上去某个省份或者某个地方会有数据显示,但是点击一下地图没有任何动态效果,如何添加地图点击效果呢,这里自己也是坐下笔记,方便以后使用. 参考 ...

  10. echarts中国地图

    echarts中国地图效果图: =================== 需要引入echarts的js文件:(1.echarts.min.js:2.china.js) 下载地址: echarts.min ...

随机推荐

  1. pyinstaller打包后运行提示“No module named 'PyQt5' "

    记录遇到的一个很傻的问题 脚本用到了PyQt5模块,安装成功脚本可以正常运行,但是使用pyinstaller 打包后,运行 exe文件提示 No module named 'PyQt5' 原因: 因为 ...

  2. Javascript高级程序设计(000)

    该分类下为学习Javascript高级程序设计的笔记,希望自己可以坚持学习,努力学习!加油! 一.组织结构 第 1 章,介绍 JavaScript 的起源:从哪里来,如何发展,以及现今的状况.这一章会 ...

  3. 洛谷 P4048更新题面

    [JSOI2010]冷冻波 题目描述 WJJ 喜欢"魔兽争霸"这个游戏.在游戏中,巫妖是一种强大的英雄,它的技能 Frozen Nova 每次可以杀死一个小精灵.我们认为,巫妖和小 ...

  4. USB设备判断接入和移除

    目录 以沁恒的CH582芯片为例,主机模式下,在R8_USB_INT_EN中可以使能RB_UIE_DETECT位,由中断来提醒检测USB设备的接入和移除:从机模式下,USB设备没有这样的中断功能(上述 ...

  5. Nextjs Contentful GraphQL Vercel Edges

    配置contentful 1. 创建免费账号 2. 根据提示进行操作, Content Model - 创建页面属性模板 (personalWebsite) content entry  -  根据属 ...

  6. Burp学院-OS命令注入

    1.OS command injection, simple case. 最简单的命令执行,[|] 两个只要有一个为True就执行 2.Blind OS command injection with ...

  7. python中下拉框选择

    如选择省区城市 provice = driver.find_element_by_id('****') #先给定位的元素付个变量 select(prvice).select_by_bisible_te ...

  8. PaaS和SaaS的区别是什么?

    PaaS是Platform-as-a-Service的缩写,意思是"平台即服务" SaaS是Software-as-a-Service的缩写,意思是"软件即服务" ...

  9. 教你如何自己搭环境部署华为FusionCompute虚拟化系统

    https://www.bilibili.com/video/BV1iy4y177f4?p=10 实用的干货快先码起来,说不定以后会用到哟

  10. 推荐一个 python学习网站

    kaggle python课程: https://www.kaggle.com/learn/python 知乎有个博主在专栏放了课程的中文版: https://www.zhihu.com/people ...