echarts中国地图使省份选择性滑动或点击高亮「建议收藏」

echarts中国地图使省份选择性滑动或点击高亮「建议收藏」本文介绍echarts显示中国省份图,对于需要高亮的省份进行筛选。并且对省份进行选择性交互。首先我们需要一个颜色集合,代表我们要设置多少种颜色。这里用到了dataRange。dataRange:{ show:false, x:’left’, y:’bottom’, splitList:[ …

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

本文介绍echarts显示中国省份图,对于需要高亮的省份进行筛选。并且对省份进行选择性交互。

首先我们需要一个颜色集合,代表我们要设置多少种颜色。这里用到了dataRange。

        dataRange: {
	    	show:false,
	        x: 'left',
	        y: 'bottom',
	        splitList: [
	            {start: 5, end: 5, color: 'orange'},//当值为5时,区域背景
	            {start: 10, end: 10, color: '#ff6300'},//当值为10时,区域背景
	            {start: 15, end: 15, color: '#ccc'},//当值为15时,区域背景
	        ],
	    },

然后就需要数据就行了。

        series : [
	        {
	            name: '市场分布',
	            type: 'map',
	            mapType: 'china',
	            //hoverable: false,
	            roam: false,
	            itemStyle:{
		                normal:{label:{show:true}},
		                emphasis:{label:{show:false}}
		            },
	            data:[],
	        }
	    ],

这里的data为空,因为正常情况下数据不会写死,都是从后台获取的,在这里我直接赋值。

var ini_data=[];//初始化省份数组
var provArr = ['河北', '河南', '云南', '辽宁', '黑龙江', '湖南', '安徽','山东'];//获取的省份,有可能是从后台获取

由于框架不识别’省’,‘市’的字眼,所以使用正则将字眼去掉。

    //正则省份,将省与市的字眼去掉,框架不识别
    for(var i=0;i<provArr.length;i++){
    	var str = provArr[i];
		var re = /省|市/g;  //全局匹配
		var str2 ={name:str.replace(re,''),value: 5};//拼接对象数组
		ini_data.push(str2);
    }

此时,我们有了一个完整的ini_data对象数组了。可以直接给图表赋值了。

 option.series[0].data=ini_data;//将拼接好的数组赋给参数集合
 mycharts.setOption(option);//跟新图表

结果:echarts中国地图使省份选择性滑动或点击高亮「建议收藏」

可以看到,只要在数组里的省份都变成了我设置的orange颜色,因为它们的value都是5。

下面就是交互了,我的需求是点击灰色省份无任何效果,点击orange色的省份背景变为‘#ff6300’。

    //点击事件
	mycharts.on('click', function (params) {//点击事件
			select_province(params.name);
	});
	//初始化省颜色
	function ini_province(){
		var ini_len=option.series[0].data.length;
		for(var i=0;i<ini_len;i++){
			//初始化颜色
			option.series[0].data[i].value=5;
			mycharts.setOption(option);
		}
		
	}
	//选中省颜色
	function select_province(province_name){
		var len=option.series[0].data.length;
		for(var i=0;i<len;i++){
			if(option.series[0].data[i].name==province_name){//如果匹配正确
				//先归零
				ini_province();
				//改变颜色
				option.series[0].data[i].value=10;
				mycharts.setOption(option);
			}
		}
	}

我们通过监听click事件来获得event对象,然后获得省份,经过匹配后,将原来选中的省份清零,再改变选中省份的颜色。

结果:echarts中国地图使省份选择性滑动或点击高亮「建议收藏」

至于鼠标滑过的高亮效果,是框架自带的,默认是所有省份都有,如果想去掉只要加:hoverable: false就行了,不过这样同样会取消掉橙色的省份。所以为了保留橙色省份的滑动高亮效果,我是这样写的。

    //鼠标滑过事件
	var testStr=','+provArr.join(",")+","; 
	mycharts.on('hover', function (param){
		if(testStr.indexOf(","+param.name+",")!=-1){
			return false;
		}else{
			param.value=15;
			mycharts.setOption(option);
		}
	});

这时设置的第三个颜色生效了,当鼠标滑过时没有匹配到provArr中的省份时,就设置背景颜色为#ccc,由于默认背景是#ccc的缘故,也可以重新设置背景色,只要这里设置的颜色与背景色相同就行了。

附上demo地址:https://my.weblf.cn/xly/demo/echarts/map/map2.html

稍作修改也可点击进入省内详情:https://my.weblf.cn/xly/demo/echarts/map/map_china.html

下载地址:https://tx.weblf.cn/files/echarts地图—中国进入省份.zip

附上完整代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<style>
			*{margin: 0;padding: 0;color:#333333;}
			h3,h4,h5,h6{font-weight: normal;}
			.clear{clear:both;}
			body{font-family:"微软雅黑";}
			a{text-decoration: none;color: #333;}
			#charts{width:800px;height:600px;margin:0 auto;}
			.market_map_title{font-size:32px;text-align:left;padding-left:50px;}
		</style>
	</head>
	
	<body>
		<h3 class="market_map_title">全国市场分布图</h3>
		<div id="charts"></div>
	</body>
	<!--<script src="http://echarts.baidu.com/build/dist/echarts-all.js"></script>-->
	<script src="echarts-all.js"></script>	
<script>
	var mycharts = echarts.init(document.getElementById('charts'))
		option = {
	    dataRange: {
	    	show:false,
	        x: 'left',
	        y: 'bottom',
	        splitList: [
	            {start: 5, end: 5, color: 'orange'},//当值为5时,区域背景
	            {start: 10, end: 10, color: '#ff6300'},//当值为10时,区域背景
	            {start: 15, end: 15, color: '#ccc'},//当值为15时,区域背景
	        ],
	    },
	    series : [
	        {
	            name: '市场分布',
	            type: 'map',
	            mapType: 'china',
	            //hoverable: false,
	            roam: false,
	            itemStyle:{
		                normal:{label:{show:true}},
		                emphasis:{label:{show:false}}
		            },
	            data:[],
	        }
	    ],
	    animation:false
	   
	};
	var ini_data=[];//初始化省份数组
	var provArr = ['河北', '河南', '云南', '辽宁', '黑龙江', '湖南', '安徽','山东'];//获取的省份,有可能是从后台获取
	//正则省份,将省与市的字眼去掉,框架不识别
    for(var i=0;i<provArr.length;i++){
    	var str = provArr[i];
		var re = /省|市/g;  //全局匹配
		var str2 ={name:str.replace(re,''),value: 5};//拼接对象数组
		ini_data.push(str2);
    }
    option.series[0].data=ini_data;//将拼接好的数组赋给参数集合
    mycharts.setOption(option);//跟新图表
	//鼠标滑过事件
	var testStr=','+provArr.join(",")+","; 
	mycharts.on('hover', function (param){
		if(testStr.indexOf(","+param.name+",")!=-1){
			return false;
		}else{
			param.value=15;
			mycharts.setOption(option);
		}
	});
	
	//点击事件
	mycharts.on('click', function (params) {//点击事件
			select_province(params.name);
	});
	//初始化省颜色
	function ini_province(){
		var ini_len=option.series[0].data.length;
		for(var i=0;i<ini_len;i++){
			//初始化颜色
			option.series[0].data[i].value=5;
			mycharts.setOption(option);
		}
		
	}
	//选中省颜色
	function select_province(province_name){
		var len=option.series[0].data.length;
		for(var i=0;i<len;i++){
			if(option.series[0].data[i].name==province_name){//如果匹配正确
				//先归零
				ini_province();
				//改变颜色
				option.series[0].data[i].value=10;
				mycharts.setOption(option);
			}
		}
	}
	</script>
</html>

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/179655.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • matlab三个自变量拟合函数_matlab拟合二元函数

    matlab三个自变量拟合函数_matlab拟合二元函数如何用matlab数据拟合函数?用matlab求解多元线性方程www.zhiqu.org时间:2020-12-08Matlab有一个功能强大的曲线拟合工具箱cftool,使用方便,能实现多种类型的线性、非线性曲线拟合。下面结合我使用的MatlabR2007b来简单介绍如何使用这个工具箱。假设我们要拟合的函数形式是y=A*x*x+B*x,且A>0,B>0…

    2025年9月26日
    8
  • GoLand 2021.2.3 激活码(在线激活)

    GoLand 2021.2.3 激活码(在线激活),https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月14日
    523
  • 从零开始学python微课视频版-从零开始学Python(微课视频版)

    从零开始学python微课视频版-从零开始学Python(微课视频版)基本信息书名:从零开始学Python(微课视频版):89.80元作者:何明编著著出版社:中国水利水电出版社出版日期:2020_04_01ISBN:9787517083818字数:644000页码:390版次:1装帧:平装开本:16开商品重量:编辑推荐这是一本针对零基础的读者设计的Python程序设计的入门教程、视频教程。该书以基础知识、实例和实战案例相结合的形式全面详尽地介绍了Python编程…

    2022年6月3日
    41
  • 【图像处理算法】直方图均衡化「建议收藏」

    【图像处理算法】直方图均衡化「建议收藏」参考文献:RafaelC.Gonzalez,RichardE.Woods,DigitalImageProcessing(ThirdEdition) 胡学龙.数字图像处理(第三版) 左飞.图像处理中的数学修炼目录直方图均衡化的介绍直方图的概念直方图均衡化的理论基础手工实现直方图均衡化MATLAB上实现直方图均衡化直方图均衡化的缺点直方图均衡…

    2022年5月17日
    88
  • vmware15虚拟机激活码(JetBrains全家桶)[通俗易懂]

    (vmware15虚拟机激活码)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlMLZPB5EL5Q-eyJsaWNlbnNlSW…

    2022年3月21日
    127
  • 特立独行的理解_幸福在一起第14集

    特立独行的理解_幸福在一起第14集原题链接对一个十进制数的各位数字做一次平方和,称作一次迭代。如果一个十进制数能通过若干次迭代得到 1,就称该数为幸福数。1 是一个幸福数。此外,例如 19 经过 1 次迭代得到 82,2 次迭代后得到 68,3 次迭代后得到 100,最后得到 1。则 19 就是幸福数。显然,在一个幸福数迭代到 1 的过程中经过的数字都是幸福数,它们的幸福是依附于初始数字的。例如 82、68、100 的幸福是依附于 19 的。而一个特立独行的幸福数,是在一个有限的区间内不依附于任何其它数字的;其独立性就是依附于它的的幸福数

    2022年8月8日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号