数据可视化-ECharts Html项目实战(10)

在之前的文章中,我们学习了如何在ECharts中编写雷达图,实现特殊效果的插入运用,函数的插入,以及多图表雷达图。想了解的朋友可以查看这篇文章。同时,希望我的文章能帮助到你,如果觉得我的文章写的不错,请留下你宝贵的点赞,谢谢。

数据可视化-ECharts Html项目实战(9)-CSDN博客文章浏览阅读1.5k次,点赞26次,收藏21次。今天的文章,会带着大家深入学习ECharts特殊图表中的雷达图,实现特殊效果的插入运用,函数的插入,以及多图表雷达图。希望我的文章能帮助到正在学习的你,也欢迎各位来本篇文章下一起交流学习,共同进步。https://blog.csdn.net/qq_49513817/article/details/137226435今天的文章,会带着大家深入学习ECharts特殊图表中的双y图以及自定义形状词云图,希望你能在本篇文章中有所收获。

目录

一、知识回顾

二、双y图

三、自定义形状词云图

拓展-maskImage用法


一、知识回顾

在上一篇文章中我们学习了雷达图

设置雷达图其实和饼图圆环图差不多,要注意的是要将type类型更改为radar,并且添加数据数组值。

添加视觉组件则需要用到visualMap,并修改里面的配置项达到不同的效果。

最后就是我们的多图表雷达图。

它需要考虑我们的多图表的位置,通过设置不同的位置调整它们之间的间隙,不要让其重叠。

现在,开始今天的学习吧。

二、双y图

在绘制双y图(即具有两个y轴的图表)时,我们需要注意以下几个方面:

  • 数据选择与整理:首先,需要确定哪些数据需要展示在两个不同的y轴上。这些数据通常具有不同的度量单位或量级,如果放在同一个y轴上会导致可读性降低。
  • y轴刻度与范围:对于每个y轴,要分别设置合适的刻度和范围。确保每个y轴的刻度能够清晰地反映对应数据的分布情况,同时避免范围过大或过小导致信息展示不全或过于拥挤。
  • 颜色与标识:为了区分两个不同的y轴及其对应的数据系列,通常会给它们设置不同的颜色和标识。例如,在我的代码中,降水量和蒸发量分别使用了蓝色和红色的y轴,这有助于我们读表时快速区分不同的数据系列。
  • 图例与提示:确保图例清晰地列出了所有的数据系列,并正确对应到各自的y轴。同时,为图表添加提示功能(tooltip),以便读者在鼠标悬停时能够查看具体的数据点信息。
  • 布局与可读性:注意图表的布局,确保两个y轴不会相互干扰,同时保持足够的空间来展示所有的数据点。尽量使用不同的形状或样式来区分不同的数据系列,以提高图表的可读性。
  • 标签与标题:为图表添加适当的标签和标题,说明每个y轴的含义、单位以及图表的整体目的。这有助于读者更好地理解图表的内容和含义。

下面是一个双y图:

html 复制代码
<!DOCTYPE html>
<html>
 
<head>
    <meta charset="utf-8"> 
    <!--引入ECharts脚本-->
    <!-- <第一步引入脚本> -->
    <script src="js\echarts.js"></script> 
</head>
 
<body>
    <!---为ECharts准备一个具备大小(宽高)的DOM-->
    <div id="main" style="width: 800px; height: 400px"></div>
    <script type="text/javascript"> 
        //第二步基于准备好的DOM,初始化ECharts图表
        var myChart = echarts.init(document.getElementById("main"));
        //第三步指定图表的配置项和数据
    // 指定图表的配置项和数据
var option = {
            backgroundColor:'rgba(128,128,128,0.1)',
            tooltip:{trigger:'axis'},
            legend:{data:['降水量','蒸发量'],left:'center',top:12},
            xAxis:[
                {
                    type:'category',
                    data:['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月']
                }
            ],
            yAxis: [
                    {
                    type: 'value',
                    name: '降水量(mL)',
                    min:0,
                    max:250,
                    interval:50,
                    axisLine: {lineStyle:{color:'blue'}},
                    axisLabel: {formatter: '{value}'}
                    },
                    {
                    type: 'value',
                    name: '蒸发量(mL)',
                    min:0,
                    max:200,
                    position:'right',
                    offset:0,
                    axisLine: {lineStyle:{color:'red'}},
                    axisLabel: {formatter: '{value}'}
                    },
                    
                ],
            series:[
                {
                    name:'降水量(ml)',type:'bar',
                    itemStyle:{
                        normal:{
                            color:function(params){
                                var colorList = [
                                    '#fe9f4f','#feca2b','#feca2b','#fed728','#c5ee4a',
                                    '#87ee4a','#46eda9','#47e4ed','#4bbbee','#4f8fa8',
                                    '#4586d8','#4f68d8','#f4E001','#F0805A','#26c0C0'];
                                    return colorList[params.dataIndex]
                            },
                            label:{show:true,position:'top',formatter:'{b}:{c}'}
                        }
                    },
                    data:[50,75,100,150,200,248,220,180,155,130,90,75]
                },
                {
                    name:'蒸发量',type:'line',
                    yAxisIndex:1,
                    itemStyle:{normal:{color:'red'}},
                    data:[58,65,90,120,130,180,150,130,125,110,150,145]
                }
            ]
        };
        myChart.setOption(option);
</script>
</body>
</html>

在代码中可以看到我们定义了两条y轴,名称分别为降水量和蒸发量。降水量值的范围从0到250,位置默认颜色设置了一个blue蓝色,而蒸发量值的范围设置了从0到200,颜色为red红色,位置也设置了右边,现在运行代码看看效果。

可以看到和我们预期的效果一致,这就是我们需要的一个双y图。

三、自定义形状词云图

词云图在之前的文章中我们以及学习过了,那么更改为自定义形状,我们需要注意以下几点:

我们需要下载需要的形状图片,最好为黑色填充,我们可以去这里下载iconfont-阿里巴巴矢量图标库

其次我们需要转化图片的格式为base64,再插入到我们的代码中。我们可以去这里转化base64图片在线转换工具

转化完成后该怎么操作呢?看代码:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>词云图</title>
    
    <script type="text/javascript" src="js/echarts.js"></script>
    <script type="text/javascript" src="js/echarts-wordcloud.min.js"></script>
</head>
<body>
    
    <div id="main" style="width: 600px;height: 500px; "></div>

    <script >
        var mycharts = echarts.init(document.getElementById("main"));
        var jsonlist = [];
        jsonlist.push(
            {
						name: "Java",
						value: 50
					}, {
						name: "C",
						value: 1150
					},
					{
						name: "Python",
						value: 142
					}, {
						name: "C++",
						value: 135
					},
					{
						name: "C#",
						value: 165
					}, {
						name: "VB.NET",
						value: 175
					},
					{
						name: "Ruby",
						value: 168
					}, {
						name: "Assembly",
						value: 132
					},
					{
						name: "R",
						value: 155
					}, {
						name: "Delphi",
						value: 135
					},
					{
						name: "VB",
						value: 152
					}, {
						name: "Go",
						value: 127
					},
					{
						name: "Delphi",
						value: 188
					}, {
						name: "SAS",
						value: 195
					},
					{
						name: "Perl",
						value: 176
					}, {
						name: "Matlab",
						value: 145
					},
					{
						name: "PL/SQL",
						value: 152
					}, {
						name: "D",
						value: 135
					},
					{
						name: "Scheme",
						value: 193
					}, {
						name: "COBEL",
						value: 174
					},
					{
						name: "Scratch",
						value: 173
					}, {
						name: "Dart",
						value: 178
					},
					{
						name: "ABAP",
						value: 146
					}, {
						name: "Scala",
						value: 168
					},
					{
						name: "Fortran",
						value: 172
					}, {
						name: "LiveCode",
						value: 169
					},
					{
						name: "Lisp",
						value: 178
					}, {
						name: "F#",
						value: 138
					}, 
					{
						name: "Rust",
						value: 356
					}, {
						name: "Kotlin",
						value: 319
					},
					{
						name: "Ada",
						value: 316
					}, {
						name: "Logo",
						value: 261
					},
					{
						name: "SQL",
						value: 138
					}, {
						name: "RPG",
						value: 274
					},
					{
						name: "PHP",
						value: 30
					}, {
						name: "LabVIEW",
						value: 50
					},
					{
						name: "Haskell",
						value: 20
					}, {
						name: "Bash",
						value: 40
					},
					{
						name: "ActionScript",
						value: 90
					}, {
						name: "Transact-SQL",
						value: 40
					},
					{
						name: "PowerShell",
						value: 20
					}, {
						name: "VBScript",
						value: 40
					},
					{
						name: "JavaScript",
						value: 50
					}, {
						name: "TypeScript",
						value: 50
					},
					{
						name: "Objective-C",
						value: 65
					}, {
						name: "Prolog",
						value: 54
					},
					{
						name: "Groovy",
						value: 23
					}, {
						name: "Swift",
						value: 35
					},
					{
						name: "Crystal",
						value: 37
					}, {
						name: "Lua",
						value: 45
					},
					{
						name: "Julia",
						value: 42
					},

                    {
						name: "Delphi",
						value: 43
					}, {
						name: "SAS",
						value: 45
					},
					{
						name: "Perl",
						value: 68
					}, {
						name: "Matlab",
						value: 73
					},
					{
						name: "PL/SQL",
						value: 78
					}, {
						name: "D",
						value: 90
					},
					{
						name: "Scheme",
						value: 92
					}, {
						name: "COBEL",
						value: 93
					},
					{
						name: "Scratch",
						value: 95
					}, {
						name: "Dart",
						value: 98
					},
					{
						name: "ABAP",
						value: 47
					}, {
						name: "Scala",
						value: 74
					},
					{
						name: "Fortran",
						value: 78
					}, {
						name: "LiveCode",
						value: 79
					},
					{
						name: "Lisp",
						value: 156
					}, {
						name: "F#",
						value: 43
					}, 
					{
						name: "Rust",
						value: 46
					}, {
						name: "Kotlin",
						value: 49
					},
					{
						name: "Ada",
						value: 79
					}, {
						name: "Logo",
						value: 67
					},
					{
						name: "SQL",
						value: 53
					}, {
						name: "RPG",
						value: 58
					},
					{
						name: "PHP",
						value: 91
					}, {
						name: "LabVIEW",
						value: 73
					},
					{
						name: "Haskell",
						value: 13
					}, {
						name: "Bash",
						value: 17
					},
					{
						name: "ActionScript",
						value: 12
					}, {
						name: "Transact-SQL",
						value: 26
					},
					{
						name: "PowerShell",
						value: 28
					}, {
						name: "VBScript",
						value: 31
					},
					{
						name: "JavaScript",
						value: 32
					}, {
						name: "TypeScript",
						value: 65
					},
					{
						name: "Objective-C",
						value: 36
					}, {
						name: "Prolog",
						value: 42
					},
					{
						name: "Groovy",
						value: 16
					}, {
						name: "Swift",
						value: 12
					},
					{
						name: "Crystal",
						value: 32
					}, {
						name: "Lua",
						value: 80
					},
					{
						name: "Julia",
						value: 60
					},
                    {
						name: "Lisp",
						value: 178
					}, {
						name: "F#",
						value: 138
					}, 
					{
						name: "Rust",
						value: 356
					}, {
						name: "Kotlin",
						value: 319
					},
					{
						name: "Ada",
						value: 316
					}, {
						name: "Logo",
						value: 261
					},
					{
						name: "SQL",
						value: 138
					}, {
						name: "RPG",
						value: 274
					},
					{
						name: "PHP",
						value: 30
					}, {
						name: "LabVIEW",
						value: 50
					},
					{
						name: "Haskell",
						value: 20
					}, {
						name: "Bash",
						value: 40
					},
					{
						name: "ActionScript",
						value: 90
					}, {
						name: "Transact-SQL",
						value: 40
					},
					{
						name: "PowerShell",
						value: 20
					}, {
						name: "VBScript",
						value: 40
					},
					{
						name: "JavaScript",
						value: 50
					}, {
						name: "TypeScript",
						value: 50
					},
					{
						name: "Objective-C",
						value: 65
					}, {
						name: "Prolog",
						value: 54
					},
					{
						name: "Groovy",
						value: 23
					}, {
						name: "Swift",
						value: 35
					},
					{
						name: "Crystal",
						value: 37
					}, {
						name: "Lua",
						value: 45
					},
					{
						name: "Julia",
						value: 42
					},

                    {
						name: "Delphi",
						value: 43
					}, {
						name: "SAS",
						value: 45
					},
					{
						name: "Perl",
						value: 68
					}, {
						name: "Matlab",
						value: 73
					},
					{
						name: "PL/SQL",
						value: 78
					}, {
						name: "D",
						value: 90
					},
					{
						name: "Scheme",
						value: 92
					}, {
						name: "COBEL",
						value: 93
					},
					{
						name: "Scratch",
						value: 95
					}, {
						name: "Dart",
						value: 98
					},
					{
						name: "ABAP",
						value: 47
					}, {
						name: "Scala",
						value: 74
					},
					{
						name: "Fortran",
						value: 78
					}, {
						name: "LiveCode",
						value: 79
					},
					{
						name: "Lisp",
						value: 156
					}, {
						name: "F#",
						value: 43
					}, 
					{
						name: "Rust",
						value: 46
					}, {
						name: "Kotlin",
						value: 49
					},
					{
						name: "Ada",
						value: 79
					}, {
						name: "Logo",
						value: 67
					},
					{
						name: "SQL",
						value: 53
					}, {
						name: "RPG",
						value: 58
					},
					{
						name: "PHP",
						value: 91
					}, {
						name: "LabVIEW",
						value: 73
					},
					{
						name: "Haskell",
						value: 13
					}, {
						name: "Bash",
						value: 17
					},
					{
						name: "ActionScript",
						value: 12
					}, {
						name: "Transact-SQL",
						value: 26
					},
					{
						name: "PowerShell",
						value: 28
					}, {
						name: "VBScript",
						value: 31
					},
					{
						name: "JavaScript",
						value: 32
					}, {
						name: "TypeScript",
						value: 65
					},
					{
						name: "Objective-C",
						value: 36
					}, {
						name: "Prolog",
						value: 42
					},
					{
						name: "Groovy",
						value: 16
					}, {
						name: "Swift",
						value: 12
					},
					{
						name: "Crystal",
						value: 32
					}, {
						name: "Lua",
						value: 80
					},
					{
						name: "Julia",
						value: 60
					},
                    
    );
    // 图片的base64编码
        image1= ""
        var maskResource = new Image()
        maskResource.src=image1;
        var option ={
            //设置标题,居中显示
            title:{
                text: 'E词云图',
                left:'center',
             },
            //数据可以点击
            tooltip:{

            },

            series:[
                {
                    maskImage:maskResource,
                    //词的类型
                    type: 'wordCloud',
                    //设置字符大小范围
                    sizeRange:[6,78],
                    rotationRange:[-45,90],
                    textStyle: {
                        normal:{
                            //生成随机的字体颜色
                            color:function () {
                                return 'rgb(' + [
                                    Math.round(Math.random() * 160),
                                    Math.round(Math.random() * 160),
                                    Math.round(Math.random() * 160)
                                ].join(',')+')';

                            }
                        }

                    },
                       data:jsonlist

                 }
            ]

        };
        //加载图像,将数据放在图像中
        maskResource.onload = function(){
            mycharts.setOption(option)

            };
    </script>

</body>
</html>

首先我们创建了一个image1来存放刚才图片转成的base64码,再给到我们的maskResource.src,最后在series中添加 maskImage:maskResource,末尾修改成 maskResource.onload = function(){ mycharts.setOption(option)};即可

现在,运行代码看看效果,我的代码图片是一个爱心

可以看到我们的词云图成功变成一个爱心。

在这里面我们有一点需要注意,词云图的数据不要过少且大小过大,否则可能会显示不明显看不出效果。

拓展-maskImage用法

属性名 描述 示例值
image 遮罩图片的路径或 DataURL 'path/to/your/image.png' 或 DataURL
width 遮罩图片的宽度(像素) 500
height 遮罩图片的高度(像素) 500
silent 是否静默加载图片 false
相关推荐
天天进步20151 分钟前
Vue项目重构实践:如何构建可维护的企业级应用
前端·vue.js·重构
小华同学ai4 分钟前
vue-office:Star 4.2k,款支持多种Office文件预览的Vue组件库,一站式Office文件预览方案,真心不错
前端·javascript·vue.js·开源·github·office
百家方案5 分钟前
「下载」智慧产业园区-数字孪生建设解决方案:重构产业全景图,打造虚实结合的园区数字化底座
大数据·人工智能·智慧园区·数智化园区
APP 肖提莫5 分钟前
MyBatis-Plus分页拦截器,源码的重构(重构total总数的计算逻辑)
java·前端·算法
forestsea12 分钟前
【Elasticsearch】分片与副本机制:优化数据存储与查询性能
大数据·elasticsearch·搜索引擎
问道飞鱼17 分钟前
【前端知识】强大的js动画组件anime.js
开发语言·前端·javascript·anime.js
k093318 分钟前
vue中proxy代理配置(测试一)
前端·javascript·vue.js
开着拖拉机回家19 分钟前
【Ambari】使用 Knox 进行 LDAP 身份认证
大数据·hadoop·gateway·ambari·ldap·knox
傻小胖20 分钟前
React 脚手架使用指南
前端·react.js·前端框架
地球资源数据云25 分钟前
全国30米分辨率逐年植被覆盖度(FVC)数据集
大数据·运维·服务器·数据库·均值算法