动态生成最新行政区划 GeoJSON 数据并结合 ECharts 实现地图下钻功能

在开发基于地图的数据可视化应用时,一个常见的挑战是获取准确且最新的行政区划边界数据(GeoJSON)。许多现有的在线资源可能数据陈旧,无法反映最新的行政区划调整。本文将介绍一种解决方案,通过调用高德开放平台的 API 动态获取最新的行政区划边界,并结合 ECharts 实现可下钻的地图可视化。
map.gif

第一部分:通过高德开放平台 API 获取行政区划边界数据

高德地图提供了强大的“行政区查询服务”(AMap.DistrictSearch),可以实时获取全国范围内的行政区划信息,包括其地理边界。

1. 准备工作:引入 API 与申请 Key

首先,您需要到高德开放平台申请一个 Key,用于 API 调用。然后,在页面中引入高德地图的 JS API 脚本。

<script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.11&key=「您申请的key值」&plugin=AMap.DistrictSearch"></script>

2. 调用接口获取行政区列表

通过实例化 AMap.DistrictSearch 并调用其 search 方法,可以获取指定区域的下一级行政区列表。以获取中国所有省级单位为例:

// 初始化行政区查询实例
const opts = {subdistrict: 1,  // 返回下一级行政区showbiz: false   // 最后一级不返回街道信息
};
const district = new AMap.DistrictSearch(opts);// 查询“中国”的下一级行政区
district.search('中国', (status, result) => {if (status === 'complete') {// result.districtList[0] 包含了省级列表数据processData(result.districtList[0], 100000); }
});

3. 获取 GeoJSON 格式的边界数据

获取到行政区列表后,需要利用 AMapUIDistrictExplorer 模块来加载指定区域的边界数据(feature)。

function loadMapData(areaCode, callback) {AMapUI.loadUI(['geo/DistrictExplorer'], DistrictExplorer => {const districtExplorer = new DistrictExplorer();districtExplorer.loadAreaNode(areaCode, (error, areaNode) => {if (error) {console.error(error);return;}// 构建标准的 GeoJSON 对象const geoJson = {type: "FeatureCollection",features: areaNode.getSubFeatures() // 获取子区域的边界数据};callback(geoJson);});});
}

关键点areaNode.getSubFeatures() 返回的是一个 feature 数组,为了符合标准的 GeoJSON 格式,需要将其包裹在一个 { "type": "FeatureCollection", "features": [...] } 结构中。

第二部分:使用 ECharts 渲染地图

获取到标准的 GeoJSON 数据后,便可以利用 ECharts 将其渲染为地图。

1. 引入 ECharts 库

在项目中引入 ECharts 库,例如使用 CDN:

<script src="https://cdn.jsdelivr.net/npm/echarts@5.0.0/dist/echarts.min.js"></script>

2. 注册并配置地图

在 ECharts 中,使用 echarts.registerMap 方法注册刚才获取的 GeoJSON 数据,然后在 option 中配置 series-map

// 假设 geoJsonData 是上一步获取到的数据
// 假设 myChart 是已经初始化的 ECharts 实例// 注册地图
echarts.registerMap('currentMap', geoJsonData);// 配置 ECharts Option
const option = {series: [{type: 'map',map: 'currentMap', // 使用刚刚注册的地图roam: false,itemStyle: {// ...样式配置},data: [ /* 业务数据 */ ] }]
};myChart.setOption(option);

执行此步骤后,即可成功渲染出对应的行政区划地图。

第三部分:实现地图下钻功能

地图下钻功能的核心是监听 ECharts 的点击事件,获取被点击区域的 adcode,然后重复第一步和第二步的过程,获取并渲染更深层级的地图。

1. 监听 ECharts 点击事件

myChart.on('click', (params) => {// params.data 中应包含下一级区域的 adcodeconst cityCode = params.data.cityCode; const level = params.data.level;if (level === 'street') return; // 如果是街道级别,则不再下钻// 使用 cityCode 再次调用高德API获取下一级数据district.search(String(cityCode), (status, result) => {if (status === 'complete' && result.districtList.length > 0) {// 获取新的 geoJson 并重新渲染 EChartsloadMapData(cityCode, (geoJson) => {// ...重新执行注册和渲染的逻辑...});}});
});

:上述代码示例为核心逻辑展示,具体实现时可结合 Vue、React 等框架进行封装。


总结与资源

通过上述方法,可以构建一个数据实时、支持无限层级下钻的动态地图应用,有效解决了静态 GeoJSON 数据陈旧的问题。

对于希望直接查看完整实现或获取预生成数据的开发者,可以参考以下资源:

  • 完整示例项目:https://github.com/TangSY/echarts-map-demo
  • 在线体验与数据下载:https://geojson.hxkj.vip 该网站提供了基于此方法生成的最新省级、市级、区县级 GeoJSON 文件以及多级别行政编码数据的下载服务。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/90743.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/90743.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/90743.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spark实现WorldCount执行流程图

spark可以分区并行执行&#xff0c;同时并行执行也可以基于内存完成迭代代码对于大部分spark程序来说都是以driver开始driver结束&#xff0c;中间都是executor分布式运行

编程与数学 03-002 计算机网络 02_网络体系结构与协议

编程与数学 03-002 计算机网络 02_网络体系结构与协议一、网络体系结构的基本概念&#xff08;一&#xff09;分层体系结构的优点&#xff08;二&#xff09;协议、接口与服务的概念二、OSI参考模型&#xff08;一&#xff09;七层模型的层次划分及功能&#xff08;二&#xff…

Flutter 提取图像主色调 ColorScheme.fromImageProvider

从图像中提取主色调&#xff0c;用于动态适配颜色主题或者界面颜色。之前在 Flutter 应用里一直用的 palette_generator 插件&#xff0c;可以分析图像颜色&#xff0c;从中提取一系列主要的色调。最近发现这个谷歌官方的插件竟然不维护了&#xff0c;后续没有更新计划了。 查找…

51c自动驾驶~合集8

自己的原文哦~ https://blog.51cto.com/whaosoft/11618683 #Hierarchical BEV BEV进入定制化时代&#xff01;清华Hierarchical BEV&#xff1a;创新多模块学习框架&#xff0c;无痛落地无缝量产&#xff01;​ 论文思路 自动驾驶指通过传感器计算设备、信息通信、自…

Excel——重复值处理

识别重复行的三种方法方法1&#xff1a;COUNTIF公式法在E2单元格输入公式&#xff1a;COUNTIF($B$2:$B2,B2)>1下拉填充至所有数据行结果为TRUE的即为重复行&#xff08;会标出第二次及以后出现的重复项&#xff09;方法2&#xff1a;排序IF公式法按商机号排序&#xff08;数…

华普微Matter模块HM-MT7201,打破智能家居生态孤岛

随着智能家居渗透率与认可度的持续提升&#xff0c;消费者对于智能家居的功能诉求正从具备联网控制、远程控制与语音遥控等基础交互能力&#xff0c;升级为能通过单一的家居生态平台APP无缝控制所有的品牌设备&#xff0c;从而实现真正意义上的统一调度。这种从“单一设备联网控…

如何使用 minio 完成OceanBase社区版的归档和备份

自OceanBase社区版4.2.1BP7版本起&#xff0c;OceanBase的归档与备份功能开始兼容AWS S3及S3协议的对象存储服务&#xff0c;因此&#xff0c;许多用户选择采用 MinIO 作为其备份存储介质。因为 MinIO 兼容AWS S3云存储服务接口&#xff0c;成为了一个轻便的服务选项。 本文将…

Nacos-服务注册,服务发现(二)

Nacos健康检查 两种健康检查机制 Nacos作为注册中⼼, 需要感知服务的健康状态, 才能为服务调⽤⽅提供良好的服务。 Nacos 中提供了两种健康检查机制&#xff1a; 客⼾端主动上报机制&#xff1a; 客⼾端通过⼼跳上报⽅式告知服务端(nacos注册中⼼)健康状态, 默认⼼跳间隔5…

手写PPO_clip(FrozenLake环境)

参考&#xff1a;白话PPO训练 成功截图 算法组件 四大部分 同A2C相比&#xff0c;PPO算法额外引入了一个old_actor_model. 在PPO的训练中&#xff0c;首先使用old_actor_model与环境进行交互得到经验&#xff0c;然后利用一批经验优化actor_model&#xff0c;最后再将actor_m…

人形机器人指南(八)操作

八、环境交互与操作能力——人形机器人的“灵巧双手”环境交互与操作能力是人形机器人区别于移动平台的核心能力标志。通过仿生学设计的运动链与智能控制算法&#xff0c;机器人得以在非结构化环境中执行抓取、操纵、装配等复杂任务。本章将系统解析机械臂运动学架构、灵巧手设…

管理 GitHub Pages 站点的自定义域(Windows)

管理 GitHub Pages 站点的自定义域(Windows) 你可以设置或更新某些 DNS 记录和存储库设置,以将 GitHub Pages 站点的默认域指向自定义域。 谁可以使用此功能? GitHub Pages 在公共存储库中提供 GitHub Free 和 GitHub Free for organizations,在公共和私有存储库中提供 Gi…

【PCIe 总线及设备入门学习专栏 5.1.3 -- PCIe PERST# 时序要求】

文章目录 Overview 什么是PERST# 第一条要求 术语解释 要求含义 第二条要求 术语解释 要求含义 Perst 示例说明 过程如下 总结 Overview 首先我们看下 PCIe x协议对 PERST 的要求: A component must enter the LTSSM Detect state within 20 rms of the end of Fundamental R…

图像认知与OpenCV——图像预处理

目录 一、颜色加法 颜色加法 颜色加权加法 示例 二、颜色空间转换 RGB转Gray&#xff08;灰度&#xff09; RGB转HSV HSV转RGB 示例 三、灰度化 最大值法 平均值法 加权平均值法 四、图像二值化处理 阈值法 反阈值法 截断阈值法 低阈值零处理 超阈值法 OTSU…

Vue 3 组件通信全解析:从 Props 到 Pinia 的深入实践

引言 Vue 3 作为现代前端框架的代表之一&#xff0c;以其灵活性和高效性受到开发者的广泛喜爱。在 Vue 3 中&#xff0c;组件是构建用户界面的核心单元&#xff0c;而组件之间的通信则是实现动态交互和数据流动的关键环节。无论是简单的父子组件通信&#xff0c;还是复杂的跨组…

CodeBuddy IDE实战:用AI全栈能力快速搭建课程表网页

声明&#xff1a;本文仅是实践测评&#xff0c;并非广告 1.前言 在数字化开发的浪潮中&#xff0c;工具的革新往往是效率跃迁的起点。腾讯云 CodeBuddy IDE 是 “全球首个产设研一体 AI 全栈开发平台” &#xff0c;它不仅打破了产品、设计与研发的职能壁垒&#xff0c;更重新…

11. HTML 中 DOCTYPE 的作用

总结H5 的声明HTML5 的 DOCTYPE 声明 HTML5 中的 <!DOCTYPE html> 声明用于告诉浏览器当前文档使用的是 HTML5 的文档类型。它必须是文档中的第一行内容&#xff08;在任何 HTML 标签之前&#xff09;&#xff0c;以确保浏览器能够正确地解析和渲染页面。DOCTYPE 的作用 …

Linux C 网络基础编程

基础知识在进行网络编程之前&#xff0c;我们需要简单回顾一下计算机网络五层模型的网络层和传输层&#xff0c;这两层在面向后端编程时用的最多。物理层和链路层过于底层&#xff0c;已经完全由内核协议栈实现&#xff0c;不再细述。这里假设读者已经对计算机网络有一个大致的…

循环神经网络--NLP基础

一、简单介绍NLP&#xff08;Natural Language Processing&#xff09;&#xff1a;自然语言处理是人工智能和语言领域的一个分支&#xff0c;它涉及计算机和人类语言之间的相互作用。二、NLP基础概念词表&#xff08;词库&#xff09;&#xff1a;文本数据集出现的所有单词的集…

【Android】约束布局总结(1)

三三要成为安卓糕手 零&#xff1a;创建布局文件方式 1&#xff1a;创建步骤ctrl alt 空格 设置根元素2&#xff1a;处理老版本约束布局 在一些老的工程中&#xff0c;constrainlayout可能没有办法被直接使用&#xff0c;这里需要手动添加依赖implementation androidx.const…

S7-200 SMART 数字量 I/O 组态指南:从参数设置到实战案例

在工业自动化控制中&#xff0c;PLC 的数字量输入&#xff08;DI&#xff09;和输出&#xff08;DO&#xff09;是连接传感器、执行器与控制系统的 “神经末梢”。西门子 S7-200 SMART 作为一款高性价比的小型 PLC&#xff0c;其数字量 I/O 的灵活组态直接影响系统的稳定性与响…