位置: IT常识 - 正文

Echarts+高德地图,获取全国省市区,区域板块地图获取并高亮显示(echarts高德地图自定义区域)

编辑:rootadmin
Echarts+高德地图,获取全国省市区,区域板块地图获取并高亮显示

推荐整理分享Echarts+高德地图,获取全国省市区,区域板块地图获取并高亮显示(echarts高德地图自定义区域),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:echarts地图参数设置,echarts+高德地图绘制3维图形,echarts 地图,echarts地图geo,echarts地图geo,echarts高德地图,echarts高德地图自定义区域,echarts高德地图,内容如对您有帮助,希望把文章链接给更多的朋友!

当用户选择省市区之后,可以看到对应区域的高亮显示。

如图:

之前用户选择的是江苏省,因此当前高亮显示的是江苏省地图板块,如果之前用户选择的是成都市,那么地图则会变成四川省的版图,高亮显示成都市,如下图:

可以继续下钻,选择区域高亮显示。

这里分享一个工具: DataV.GeoAtlas地理小工具系列

通过adcode码可以查看全国的地图板块。

注意!注意!具体操作步骤来啦!

1.创建一个存放地图的容器

<div id="charts"></div>Echarts+高德地图,获取全国省市区,区域板块地图获取并高亮显示(echarts高德地图自定义区域)

2.获取容器

myChart = echarts.init(document.getElementById("charts"));

3.运用高德地图获取adcode码,此处我用的是axios来进行获取

axios .get( `https://restapi.amap.com/v3/geocode/geo?address=${ district?city:!district && city?province:!district && !city?'中国':'中国' }&output=JSON&key=af092dccf*********cf19ade46` ) .then((res) => { adcode = res.data.geocodes[0].adcode;})

这里需要注意几个地方:

${district?city:!district && city?province:!district && !city?'中国':'中国'}

以上代码意思是:如果我拿到了区名(锦江区),那么这里就应该用市名(成都市)去生成地图,如果拿到了市名(成都市),那么这里就用省名(四川省)生成地图,以此类推,如果拿到了省名(四川省),那么就用全国(中国)去生成地图。(当然这几个参数是我从后端拿到的数据哈)

key=af092dccf1***********9ade46

这个key就是你在高德地图上申请的key,具体怎么申请可以百度一下。

adcode = res.data.geocodes[0].adcode;

然后就拿到了当前选择区域的adcode

4.通过adcode码,获取到区域地图,这里是通过上面分享的工具DataV.GeoAtlas地理小工具系列

打开之后是这样的:

这里就有请求地址,可以拿到地图,地址里面的 100000也就是中国的adcode。你可以试试输入不同的adcode码左侧会显示不同的区域地图。

具体操作:

myChart.showLoading(); axios .get( `https://geo.datav.aliyun.com/areas_v3/bound/${ adcode == 0 ? 100000 : adcode }_full.json` ) .then((geoJson) => { console.log(geoJson); //获取所有省、市 // console.log(geoJson.data.features); let allData = geoJson.data.features; let seriesData = []; allData.forEach((item) => { // console.log(item.properties.name); // console.log(item); let obj; if (item.properties.name) { if ( item.properties.name == province || item.properties.name == city || item.properties.name == district ) { // console.log(item.properties.center); setLongitudeLatitude(item.properties.center); obj = { name: item.properties.name, value: measure, selected: true, }; } else { obj = { name: item.properties.name, selected: false, }; } seriesData.push(obj); } }); myChart.hideLoading(); echarts.registerMap("ZG", geoJson.data); myChart.setOption( (option = { title: {}, tooltip: { trigger: "item", }, series: [ { type: "map", map: "ZG", silent: true, //禁用地图的hover事件 label: { show: true, }, data: seriesData, zoom: 1, //当前视角的缩放比例 roam: true, //是否开启平游或缩放 scaleLimit: { //滚轮缩放的极限控制 min: 1, max: 3, }, }, ], }) ); });

这里解释一个地方:以下部分代码是找到高亮显示的区域,然后加载series.data里面

接下来看看完整代码吧!

let myChart; let option; const renderChart = (province, city, district, measure) => { myChart = echarts.init(document.getElementById("charts")); let adcode; axios .get( `https://restapi.amap.com/v3/geocode/geo?address=${ district?city:!district && city?province:!district && !city?'中国':'中国' }&output=JSON&key=af092dc********cf19ade46` ) .then((res) => { adcode = res.data.geocodes[0].adcode; myChart.showLoading(); axios .get( `https://geo.datav.aliyun.com/areas_v3/bound/${ adcode == 0 ? 100000 : adcode }_full.json` ) .then((geoJson) => { console.log(geoJson); //获取所有省、市 let allData = geoJson.data.features; let seriesData = []; allData.forEach((item) => { // console.log(item.properties.name); // console.log(item); let obj; if (item.properties.name) { if ( item.properties.name == province || item.properties.name == city || item.properties.name == district ) { // console.log(item.properties.center); setLongitudeLatitude(item.properties.center); obj = { name: item.properties.name, value: measure, selected: true, }; } else { obj = { name: item.properties.name, selected: false, }; } seriesData.push(obj); } }); myChart.hideLoading(); echarts.registerMap("ZG", geoJson.data); myChart.setOption( (option = { title: {}, tooltip: { trigger: "item", }, series: [ { type: "map", map: "ZG", silent: true, //禁用地图的hover事件 label: { show: true, }, data: seriesData, zoom: 1, //当前视角的缩放比例 roam: true, //是否开启平游或缩放 scaleLimit: { //滚轮缩放的极限控制 min: 1, max: 3, }, }, ], }) ); }); }); option && myChart.setOption(option); };

有什么问题一起交流哦,不过回复有点不及时。哈哈哈哈

本文链接地址:https://www.jiuchutong.com/zhishi/287327.html 转载请保留说明!

上一篇:node_开启本地服务(node启动本地服务)

下一篇:睡莲怎么养及种植(睡莲怎样养)

  • 调整税率后增值税发票的开具
  • 培训个人所得税计算
  • 公司租房代房东缴纳租房税金
  • 小微企业免税收入有哪些
  • 未提供一般纳税人证明
  • 非正常户发票管理
  • 关税的记税依据
  • 实收资本变更做账依据
  • 建筑类没收入怎么填
  • 给政府开发票如何处理?
  • 雇主责任险税前列支
  • 个人开具建筑服务发票
  • 广告发布税收编码
  • 哪些违约金可以退回
  • 注册资本印花税按实缴还是认缴
  • 公司注销了帐户钱能办款
  • 施工企业工作流程
  • 装修公司购入材料计入什么科目
  • 经营周转资金需求
  • 未抵扣进项税额可以退税吗
  • 专家费收取多少合适
  • 王者荣耀段位分段
  • 房产证工本费怎么做账
  • springboot集成camunda+bpmn
  • mac怎么设置默认程序
  • mcappins.exe - mcappins进程是什么文件 什么意思.
  • PHP:pcntl_waitpid()的用法_PCNTL函数
  • 新车事故报废后保险公司赔多少
  • 一品红叶发黄咋回事儿
  • 采购预算测算依据
  • 存货核算的会计分录怎么写
  • 代订住宿费报销
  • ChatGPT助力校招----面试问题分享(四)
  • 营业执照贴印花税票吗
  • 织梦怎么导入数据库
  • 帝国cms如何调用网络
  • 计提税费可以记入成本吗
  • php上传文件代码iapp
  • SQL Server 2008 r2 完全卸载方法分享
  • 金税盘减免税款分录
  • 一般纳税人增值税申报操作流程
  • 债务抵销的条件
  • 建筑业简易征收的条件
  • 产业扶持资金账户是什么
  • 工业企业外购存货成本有
  • 税控设备全额抵减
  • 如何定义是应付还是应付
  • 施工图审查费计入什么会计科目
  • 会计账本怎么记账
  • 运输过程发生的合理损耗计入成本吗
  • 特殊事项税务处理
  • 自动化生产线模型
  • mysql创建用户密码命令
  • Linux平台mysql开启远程登录
  • windows版微信能运行小程序吗
  • 如何使用搜狗拼音输入法
  • Windows 2008之AD LDS轻型目录服务解析
  • freebsd怎么安装软件
  • win7系统文件夹怎么加密码
  • mac可以远程连接windows吗
  • fsm32.exe是什么进程 有什么作用 fsm32进程查询
  • 菜单按钮是什么
  • 简述js和jquery的关系
  • node分页接口
  • alt+r没用
  • python opencv
  • cocos2dx怎么用
  • ruby 递归
  • Unity3D中ScreenPointToRay函数的分析-个人见解
  • 批处理怎么操作
  • fiddler如何抓取app接口的
  • android:theme="@style/apptheme"
  • 如何用jquery
  • auto.js获取剪切板内容
  • 查验发票真伪
  • 国家辽宁税务总局
  • 河南地税网上个税怎么交
  • 孵化企业税收优惠
  • 电子保险怎么查询车船税
  • 湖北航天金税盘服务器地址
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设