位置: 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启动本地服务)

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

  • 一般纳税人减免增值税政策
  • 增值税进项税销项税
  • 销项税额是开票金额么
  • 收付转记账凭证图片
  • 为什么营业成本比营业收入大的时候没有计提减值准备呢
  • 预估应付账款该怎么冲销
  • 房改房增值税
  • 帮客人清关的费用如何做会计核算合适呢?
  • 应付票据保证金的会计分录怎么写
  • 收到银行的贷款
  • 一般销售商品业务
  • 营改增的税收政策
  • 股权转让个人所得税
  • 已认证未抵扣发票冲红流程
  • 电子银行承兑汇票有风险吗
  • 公司购买地下停车位如何入账
  • 个人所得税承租承包经营所得
  • 股权转让收益算利润吗
  • 母公司向子公司收取管理费
  • 固定资产产权转移
  • 已经销售但是没货怎么办
  • 零申报的印花税怎么打印
  • 机动车抵扣联是什么
  • 造价咨询暂定级能接业务吗
  • 库存商品的进项可以抵扣吗
  • 公对公转账不开票可以吗
  • 核销后怎么反核销
  • 会计分录是怎么写的
  • 上年度的费用今年怎么算
  • mac睡眠后无法正常唤醒
  • linux怎么设置读写权限
  • linux系统如何更改主机名
  • lnmgr.exe是什么
  • el-upload上传文件大小限制
  • 已缴增值税的账务处理
  • 相关企业之间的竞争
  • 销售地下车库缴纳哪些税
  • 期末应交增值税转入未交增值税
  • 亚运村夜宵地方
  • 汇算清缴补税的情况有哪些
  • 公司组织员工旅游费可以在税前扣除吗
  • 资产负债表的编制原理
  • 现金折扣退回要考虑财务费用吗
  • 留言板系统php
  • db2原理
  • 开工程款发票有什么规定?
  • 免税农产品范围目录的文件
  • 股权并购与收购的区别
  • 以前年度的应收账款收不回来怎么办
  • 个人扣税是怎么扣的
  • 银行承兑到期后未兑付
  • 结转损益主营业务收入在借方
  • 固定资产的资本化和费用化
  • 返利开红字发票怎么做账
  • 委托设置什么意思
  • win10无法新建文件夹怎么办?(已解决)
  • 详述目标成本法的内容和步骤
  • linux系统百科
  • efi shell有什么用
  • linux参数命令
  • win10 win8.1双系统
  • winxp如何设置文件共享
  • window8所有程序在哪
  • windows开始界面
  • 装系统无法选择
  • Linux编译内核无法启动
  • cocos2dx怎么用啊
  • jquery虚拟dom
  • bootstrap基础
  • bootstrap技术教程
  • vue实现分页功能
  • 如何用jquery
  • Android中SQLite数据库的使用
  • shell脚本-lt
  • jquery查找方法
  • js获取鼠标点击位置
  • 详解js跨域原理是什么
  • 怎么查询企业类别
  • 省税务局属于什么级别
  • 浙江税务局网络发票页无法打字
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设