Echarts3之全国地图和省市地图二合一整合

2023-12-21 10:30

本文主要是介绍Echarts3之全国地图和省市地图二合一整合,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

没图说个ji  先上图


开始接触时是echarts 2 ,echarts升级至echarts 3 之后没怎么接触,通过介绍了解到,echarts3变得更加人性化,将一些底层的方法开放出来,增加的echarts的扩展性。

很遗憾echarts3并没有提供市级的地图的demo。

于是将echarts2中的demo直接拿来改

下面是代码:希望能帮助到你

<!DOCTYPE html><head><meta charset="utf-8"><title>ECharts</title><!-- ECharts单文件引入 --><script src="js/echarts3.js"></script><script src="js/china.js"></script><script src="js/shandong.js"></script><script src="js/hebei.js"></script>
</head><body><!-- 为ECharts准备一个具备大小(宽高)的Dom --><div id="main" style="height:400px"></div>
</body>
<script type="text/javascript">var myChart = echarts.init(document.getElementById('main'));var option = {tooltip: {trigger: 'item'},legend: {orient: 'vertical',x: 'left',data: ['iphone3']},visualMap : {min: 0,max: 1000,x: 'left',y: 'bottom',color: ['orangered','yellow','lightskyblue'],text: ['高', '低'], // 文本,默认为数值文本calculable: true},toolbox: {show: true,orient: 'vertical',x: 'right',y: 'center',feature: {mark: {show: true},dataView: {show: true,readOnly: false}}},series: [{tooltip: {trigger: 'item',},name: 'iphone3',type: 'map',mapType: 'china',left: 10,selectedMode: 'single',label: {normal: {show: true,textStyle: {fontSize: 9,}},emphasis: {show: true,textStyle: {fontStyle: 'oblique',fontSize: 9,}}},showLegendSymbol: false,data: [{name: '北京',selected: false,value: Math.round(Math.random() * 1000)}, {name: '天津',selected: false,value: Math.round(Math.random() * 1000)}, {name: '上海',selected: false,value: Math.round(Math.random() * 1000)}, {name: '重庆',selected: false,value: Math.round(Math.random() * 1000)}, {name: '河北',selected: false,value: Math.round(Math.random() * 1000)}, {name: '河南',selected: false,value: Math.round(Math.random() * 1000)}, {name: '云南',selected: false,value: Math.round(Math.random() * 1000)}, {name: '辽宁',selected: false,value: Math.round(Math.random() * 1000)}, {name: '黑龙江',selected: false,value: Math.round(Math.random() * 1000)}, {name: '湖南',selected: false,value: Math.round(Math.random() * 1000)}, {name: '安徽',selected: false,value: Math.round(Math.random() * 1000)}, {name: '山东',selected: false,value: Math.round(Math.random() * 1000)}, {name: '新疆',selected: false,value: Math.round(Math.random() * 1000)}, {name: '江苏',selected: false,value: Math.round(Math.random() * 1000)}, {name: '浙江',selected: false,value: Math.round(Math.random() * 1000)}, {name: '江西',selected: false,value: Math.round(Math.random() * 1000)}, {name: '湖北',selected: false,value: Math.round(Math.random() * 1000)}, {name: '广西',selected: false,value: Math.round(Math.random() * 1000)}, {name: '甘肃',selected: false,value: Math.round(Math.random() * 1000)}, {name: '山西',selected: false,value: Math.round(Math.random() * 1000)}, {name: '内蒙古',selected: false,value: Math.round(Math.random() * 1000)}, {name: '陕西',selected: false,value: Math.round(Math.random() * 1000)}, {name: '吉林',selected: false,value: Math.round(Math.random() * 1000)}, {name: '福建',selected: false,value: Math.round(Math.random() * 1000)}, {name: '贵州',selected: false,value: Math.round(Math.random() * 1000)}, {name: '广东',selected: false,value: Math.round(Math.random() * 1000)}, {name: '青海',selected: false,value: Math.round(Math.random() * 1000)}, {name: '西藏',selected: false,value: Math.round(Math.random() * 1000)}, {name: '四川',selected: false,value: Math.round(Math.random() * 1000)}, {name: '宁夏',selected: false,value: Math.round(Math.random() * 1000)}, {name: '海南',selected: false,value: Math.round(Math.random() * 1000)}, {name: '台湾',selected: false,value: Math.round(Math.random() * 1000)}, {name: '香港',selected: false,value: Math.round(Math.random() * 1000)}, {name: '澳门',selected: false,value: Math.round(Math.random() * 1000)}]}, ],};myChart.on('mapselectchanged', function(param) {var selected = param.selected;var selectedProvince;var name;for(var i = 0, l = option.series[0].data.length; i < l; i++) {name = option.series[0].data[i].name;option.series[0].data[i].selected = selected[name];if(selected[name]) {selectedProvince = name;}}if(typeof selectedProvince == 'undefined') {option.series.splice(1);myChart.setOption(option, true);return;}option.series[1] = {name: '随机数据',type: 'map',mapType: selectedProvince,showLegendSymbol: false,label: {normal: {show: true,textStyle: {fontSize: 9,}},emphasis: {show: true,textStyle: {fontStyle: 'oblique',fontSize: 9,}}},mapLocation: {x: '35%'},roam: true,data: [{name: '烟台市',value: Math.round(Math.random() * 1000)}, {name: '临沂市',value: Math.round(Math.random() * 1000)}, {name: '潍坊市',value: Math.round(Math.random() * 1000)}, {name: '青岛市',value: Math.round(Math.random() * 1000)}, {name: '菏泽市',value: Math.round(Math.random() * 1000)}, {name: '济宁市',value: Math.round(Math.random() * 1000)}, {name: '德州市',value: Math.round(Math.random() * 1000)}, {name: '滨州市',value: Math.round(Math.random() * 1000)}, {name: '聊城市',value: Math.round(Math.random() * 1000)}, {name: '东营市',value: Math.round(Math.random() * 1000)}, {name: '济南市',value: Math.round(Math.random() * 1000)}, {name: '泰安市',value: Math.round(Math.random() * 1000)}, {name: '威海市',value: Math.round(Math.random() * 1000)}, {name: '日照市',value: Math.round(Math.random() * 1000)}, {name: '淄博市',value: Math.round(Math.random() * 1000)}, {name: '枣庄市',value: Math.round(Math.random() * 1000)}, {name: '莱芜市',value: Math.round(Math.random() * 1000)}, {name: '张家口市',value: Math.round(Math.random() * 1000)}, {name: '保定市',value: Math.round(Math.random() * 1000)}, {name: '唐山市',value: Math.round(Math.random() * 1000)}, {name: '沧州市',value: Math.round(Math.random() * 1000)}, {name: '石家庄市',value: Math.round(Math.random() * 1000)}, {name: '邢台市',value: Math.round(Math.random() * 1000)}, {name: '邯郸市',value: Math.round(Math.random() * 1000)}, {name: '秦皇岛市',value: Math.round(Math.random() * 1000)}, {name: '衡水市',value: Math.round(Math.random() * 1000)}, {name: '廊坊市',value: Math.round(Math.random() * 1000)}, ]};option.legend = {orient: 'vertical',x: 'left',data: ['iphone3']};option.visualMap = {min: 0,max: 1000,x: 'left',y: 'bottom',color: ['orangered','yellow','lightskyblue'],text: ['高', '低'], // 文本,默认为数值文本calculable: true};myChart.setOption(option, true);});// 为echarts对象加载数据 myChart.setOption(option);
</script>


但是这个程序有很多限制的因素:

①全国各省和省内各市数据共用同一套dataRange,在省内数据和省内各市数据相差比较大的时候,市内数据颜色变化不明显,影响用户体验。

②点击地图内省会触发一个mapselectchanged的函数,当选中省的时候触发获取到点击省的详细信息,但是如果取消选中的话,程序传入的对象就变成了undefined,需要找到判断undefined的代码处修改,当初我找的时候走了很多弯路,(取消选中的时候怎么可能传入的是undefined!!!但是事实上就是这样)。当初想对选中和取消选中进行单独的处理,但是最后以失败告终(主要是dispatchAction不太会用,或者根本在这没什么卵用
以上就是主要的问题

OK



这篇关于Echarts3之全国地图和省市地图二合一整合的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/519640

相关文章

SpringBoot 整合 Grizzly的过程

《SpringBoot整合Grizzly的过程》Grizzly是一个高性能的、异步的、非阻塞的HTTP服务器框架,它可以与SpringBoot一起提供比传统的Tomcat或Jet... 目录为什么选择 Grizzly?Spring Boot + Grizzly 整合的优势添加依赖自定义 Grizzly 作为

springboot整合gateway的详细过程

《springboot整合gateway的详细过程》本文介绍了如何配置和使用SpringCloudGateway构建一个API网关,通过实例代码介绍了springboot整合gateway的过程,需要... 目录1. 添加依赖2. 配置网关路由3. 启用Eureka客户端(可选)4. 创建主应用类5. 自定

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

SpringBoot整合kaptcha验证码过程(复制粘贴即可用)

《SpringBoot整合kaptcha验证码过程(复制粘贴即可用)》本文介绍了如何在SpringBoot项目中整合Kaptcha验证码实现,通过配置和编写相应的Controller、工具类以及前端页... 目录SpringBoot整合kaptcha验证码程序目录参考有两种方式在springboot中使用k

Spring Boot 中整合 MyBatis-Plus详细步骤(最新推荐)

《SpringBoot中整合MyBatis-Plus详细步骤(最新推荐)》本文详细介绍了如何在SpringBoot项目中整合MyBatis-Plus,包括整合步骤、基本CRUD操作、分页查询、批... 目录一、整合步骤1. 创建 Spring Boot 项目2. 配置项目依赖3. 配置数据源4. 创建实体类

SpringBoot整合InfluxDB的详细过程

《SpringBoot整合InfluxDB的详细过程》InfluxDB是一个开源的时间序列数据库,由Go语言编写,适用于存储和查询按时间顺序产生的数据,它具有高效的数据存储和查询机制,支持高并发写入和... 目录一、简单介绍InfluxDB是什么?1、主要特点2、应用场景二、使用步骤1、集成原生的Influ

SpringBoot整合Canal+RabbitMQ监听数据变更详解

《SpringBoot整合Canal+RabbitMQ监听数据变更详解》在现代分布式系统中,实时获取数据库的变更信息是一个常见的需求,本文将介绍SpringBoot如何通过整合Canal和Rabbit... 目录需求步骤环境搭建整合SpringBoot与Canal实现客户端Canal整合RabbitMQSp

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

RabbitMQ使用及与spring boot整合

1.MQ   消息队列(Message Queue,简称MQ)——应用程序和应用程序之间的通信方法   应用:不同进程Process/线程Thread之间通信   比较流行的中间件:     ActiveMQ     RabbitMQ(非常重量级,更适合于企业级的开发)     Kafka(高吞吐量的分布式发布订阅消息系统)     RocketMQ   在高并发、可靠性、成熟度等

springboot整合swagger2之最佳实践

来源:https://blog.lqdev.cn/2018/07/21/springboot/chapter-ten/ Swagger是一款RESTful接口的文档在线自动生成、功能测试功能框架。 一个规范和完整的框架,用于生成、描述、调用和可视化RESTful风格的Web服务,加上swagger-ui,可以有很好的呈现。 SpringBoot集成 pom <!--swagge