词云图

由于echarts官网没有词云图的配置,网上太多也不全,这里写一份关于词云图配置的文章,包括自定义图形,透明度等



一、用到的网站

1、阿里巴巴图标库
2、图片转base64网站
3、echarts-wordcloud.min.js文件
4、echarts.min.js文件

二、全部代码

如果要使用自定义图案需要注意:
1、创建图片:var maskImage = new Image();
2、设置图片地址:maskImage.src = url;
3、载入配置:maskImage: maskImage;
4、待图片加载好以后再配置option:maskImage.onload

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script src="js/echarts.min.js"></script>
		<script src="./js/echarts-wordcloud.min.js"></script>
		<style>
			#main {
				width: 700px;
				height: 500px;
				box-shadow: 0 0 15px 3px aqua;
				margin: 100px auto 50px;
				border-radius: 15px;
			}
		</style>
	</head>
	<body>
		<div id="main"></div>
	</body>
	<script>
		var myChart = echarts.init(document.getElementById('main'));
		
		// 数据源
		var keyWords = [{
				name: '腾越街道',
				value: 1,
			},
			{
				name: '西源街道',
				value: 11,
			},
			{
				name: '固东镇',
				value: 12,
			},
			{
				name: '滇滩镇',
				value: 12,
			},
			{
				name: '猴桥镇',
				value: 18,
			},
			{
				name: '和顺镇',
				value: 13,
			},
			{
				name: '界头镇',
				value: 14,
			},
			{
				name: '曲石镇',
				value: 21,
			},
			{
				name: '明光镇',
				value: 18,
			},
			{
				name: '中和镇',
				value: 22,
			},
			{
				name: '芒棒镇',
				value: 26,
			},
			{
				name: '荷花镇',
				value: 24,
			},
			{
				name: '北海镇',
				value: 15,
			},
			{
				name: '清水镇',
				value: 18,
			},
			{
				name: '明光镇',
				value: 18,
			},
			{
				name: '中和镇',
				value: 22,
			},
			{
				name: '芒果镇',
				value: 26,
			},
			{
				name: '荷花镇',
				value: 24,
			},
			{
				name: '北海镇',
				value: 15,
			},
			{
				name: '清水镇',
				value: 18,
			},
			{
				name: '马站乡',
				value: 15,
			},
			{
				name: '五合乡',
				value: 10,
			},
			{
				name: '新华乡',
				value: 17,
			},
			{
				name: '蒲川乡',
				value: 15,
			},
			{
				name: '团田乡',
				value: 16,
			},
			{
				name: '北海乡',
				value: 1,
			},
			{
				name: '腾越镇',
				value: 6,
			},
			{
				name: '清水乡',
				value: 7,
			},
			{
				name: '马站乡',
				value: 15,
			},
			{
				name: '五合乡',
				value: 10,
			},
			{
				name: '新华乡',
				value: 17,
			},
			{
				name: '蒲川乡',
				value: 15,
			},
			{
				name: '团田乡',
				value: 16,
			},
			{
				name: '北海乡',
				value: 1,
			},
			{
				name: '腾越镇',
				value: 6,
			},
			{
				name: '清水乡',
				value: 7,
			}
		]
		
		// 求出最大值用来计算透明度
		var max = 0
		// 方法一
		for (let item of keyWords) {
			if(item.value > max){
				max = item.value
			}
		}
		// 方法二,利用map方法
		// max = Math.max(...keyWords.map(item=>item.value))
		
		// 自定义图片
		var maskImage = new Image();
		// 图片在iconfont上找,图片的黑色区域表示被填充
		maskImage.src = ""
		
		var option = {
			backgroundColor: '#fff',
			tooltip: {
				show: true
			},
			series: [{
				type: 'wordCloud',
				// 单词间隔的大小
				gridSize: 0, 
				// 字体大小范围
				sizeRange: [8, 38],
				// 文字旋转角度范围
				rotationRange: [-45, 45],
				// 自定义词云图形状
				maskImage: maskImage,
				// 形状有(circle)圆形(默认)、(cardioid)心形,(diamond)菱形,
				// (triangle-forward)三角形向前,(triangle)三角形,(pentagon)五边形和(star)星形。*/
				shape: 'star',
				textStyle: {
					color: function(e) {
						var a = [
							Math.round(Math.random() * 255),
							Math.round(Math.random() * 255),
							Math.round(Math.random() * 255),
							(e.data.value / max) < 0.3 ? 0.3 : e.data.value
						]
						return 'rgba(' + a.join(',') + ')'
					}
				},
				//设置显示区域的位置以及大小
				left: 'center',
				top: 'center',
				width: '100%',
				height: '100%',
				// 源数据
				data: keyWords,
				// 鼠标放上样式
				emphasis: {
					textStyle: {
						fontWeight: 'bold',
						color: '#ff0000',
					}
				}
			}]
		}

		// myChart.setOption(option)
		// 图片加载好以后再设置配置
		maskImage.onload = function() {
			myChart.setOption(option)
		}
	</script>
</html>

三、结果展示

在这里插入图片描述

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐