词云组件(随机颜色,设置颜色,设置字体大小,设置词云形状)

news/2024/7/10 2:23:14 标签: echarts, vue

请添加图片描述
请添加图片描述

依赖
yarn add echarts@5.4.2
yarn add echarts-wordcloud@2.0.0

词云组件

<template>
  <div ref="wordCloud"></div>
</template>

<script>
import * as echarts from 'echarts'
import 'echarts-wordcloud'
import props from './props'
export default {
  name: 'DgzWordCloud',
  props: props,
  data() {
    return {}
  },
  created() {},
  mounted() {
    this.initEchart()
  },
  methods: {
    initEchart() {
      const myChart = echarts.init(this.$refs?.wordCloud)
      const maskImage = new Image()
      maskImage.src = this.imgBase64
      // 规范化数据并排序
      const data = this.data
        ?.map(it => ({ ...it, name: it?.[this.nameKey], value: it?.[this.valueKey] }))
        ?.sort((a, b) => b?.value - a?.value)
      let fontSize = this.fontSizeMax
      const options = {
        series: [
          {
            type: 'wordCloud',
            layout: 'random',
            width: '100%',
            height: '100%',
            rotationRange: [-45, 45],
            rotationStep: 45,
            gridSize: 5,
            emphasis: { focus: 'self' },
            drawOutOfBound: false, // 允许展示在词云外面
            shrinkToFit: false, // 控制词云图中词语的大小是否根据容器的大小进行缩放
            layoutAnimation: true, // 使用动画效果进行平滑的过渡
            maskImage: maskImage, // 此处添加图片的base64格式
            sizeRange: [this.fontSizeMin, this.fontSizeMax],
            data: data?.map((item, index) => {
              let color
              if (this.colors && this.colors.length !== 0) {
                const i = Math.floor(Math.random() * this.colors.length)
                color = this.colors[i]
              } else {
                color =
                  'rgb(' +
                  [
                    Math.round(Math.random() * 160),
                    Math.round(Math.random() * 160),
                    Math.round(Math.random() * 160)
                  ].join(',') +
                  ')'
              }
              // 减到最小字体就不再减了
              if (fontSize - this.otherFontSizeStep < this.fontSizeMin) {
                fontSize = this.fontSizeMin
              } else {
                // 前prefix个字体一次减prefixStep
                if (index < this.prefix) {
                  fontSize = fontSize - this.prefixFontSizeStep
                } else {
                  // 其他的每chunk个减一次 index+prefix逢chunk减otherFontSizeStep,其他不变
                  if ((index - this.prefix) % this.chunk === 0) {
                    fontSize = fontSize - this.otherFontSizeStep
                  }
                }
              }
              return { ...item, textStyle: { fontSize, color, ...this.textStyle } }
            }),
            ...this.seriesConfig
          }
        ]
      }
      myChart.setOption(options)
      // 随着屏幕大小调节图表
      window.addEventListener('resize', () => {
        myChart.resize()
      })
    }
  }
}
</script>

props.js:组件属性

import { base64 } from './base64'
export default {
  data: {
    type: Array,
    default: () => [],
    description: '词云数据'
  },
  nameKey: {
    type: String,
    default: 'name',
    description: '值的名'
  },
  valueKey: {
    type: String,
    default: 'value',
    description: '键的名'
  },
  imgBase64: {
    type: String,
    default: base64,
    description: '词云形状图片的base64格式,注意:图片词云填充部分不能为白色,其他部分必须为白色'
  },
  colors: {
    type: Array,
    default: () => [],
    description: '词云字体颜色'
  },
  fontSizeMin: {
    type: Number,
    default: 10,
    description: '词云字体最小值'
  },
  fontSizeMax: {
    type: Number,
    default: 80,
    description: '词云字体最大值'
  },
  textStyle: {
    type: Object,
    default: () => {},
    description: 'textStyle的其他参数'
  },
  seriesConfig: {
    type: Object,
    default: () => {},
    description: 'series的其他参数'
  },
  prefix: {
    type: Number,
    default: 5,
    description: '词云突出展示数据数量(大字体)'
  },
  prefixFontSizeStep: {
    type: Number,
    default: 10,
    description: '词云突出展示数据字体大小一次减少的步长'
  },
  chunk: {
    type: Number,
    default: 10,
    description: '词云其他数据隔几个字体大小减一次'
  },
  otherFontSizeStep: {
    type: Number,
    default: 5,
    description: '词云其他字体大小一次减少的步长'
  }
}

base64.js:默认词云形状的base64

// 要求图片底色是白色,内部是其他颜色,因为词云会将白色以外的部分排除在外
export const base64 =
  ''

使用:注意:本用例里面的background使用的不是完整链接,请注意

<DgzWordCloud 
   :data="list"
   nameKey="surname"
   valueKey="count"
   style="width: 330px; height: 300px;background:url(/point/2023-12-28/zhb-6e1f2044-85d6-bc3b-7ecf-a709cdd7f0c4.png) no-repeat 0 0 / 100% 100%;" 
/>

更改词云颜色

<DgzWordCloud 
   :data="list"
   nameKey="surname"
   valueKey="count"
   :colors="['#1CA461', '#86C05F', '#E8BA00', '#6ED3DB', '#FFBE00', '#FF8E8E']"
   style="width: 330px; height: 300px;background:url(/point/2023-12-28/zhb-6e1f2044-85d6-bc3b-7ecf-a709cdd7f0c4.png) no-repeat 0 0 / 100% 100%;" 
/>

更改词云形状

请添加图片描述
阿里iconfont图标库获取矢量图:在这里选择自己想要的形状,一个背景图放到style的background里面,一个白底其他颜色的背景图片
请添加图片描述

请添加图片描述

图片转换为base64格式:使用这个网址将白底图片转换为base64格式放到imgBase64属性中

<DgzWordCloud 
   :data="list"
   nameKey="surname"
   valueKey="count"
   :imgBase64="imgBase64"
   style="width: 420px; height: 300px;background:url(/point/2023-12-28/zhb-edf5a0e9-0ff0-c2c9-92c7-2a940f779d06.jpg) no-repeat 0 0 / 100% 100%;" 
/>

更改词云字体大小

<DgzWordCloud 
   :data="list"
   nameKey="surname"
   valueKey="count"
   style="width: 330px; height: 300px;background:url(/point/2023-12-28/zhb-6e1f2044-85d6-bc3b-7ecf-a709cdd7f0c4.png) no-repeat 0 0 / 100% 100%;" 
   :prefix="8"
   :prefixFontSizeStep="5"
   :chunk="20"
   :otherFontSizeStep="4"
/>

配置config.js

export const list = [
  '王',
  '李',
  '张',
  '刘',
  '陈',
  '杨',
  '赵',
  '长孙',
  '澹台',
  '淳于',
  '公冶',
  '黄',
  '周',
  '吴',
  '徐',
  '孙',
  '胡',
  '朱',
  '高',
  '林',
  '东方',
  '宇文',
  '皇甫',
  '何',
  '郭',
  '马',
  '罗',
  '梁',
  '宋',
  '郑',
  '谢',
  '韩',
  '唐',
  '冯',
  '于',
  '公孙',
  '令狐',
  '赫连',
  '钟离',
  '闻人',
  '董',
  '萧',
  '程',
  '曹',
  '袁',
  '邓',
  '许',
  '傅',
  '沈',
  '曾',
  '彭',
  '吕',
  '苏',
  '卢',
  '蒋',
  '蔡',
  '贾',
  '丁',
  '魏',
  '欧阳',
  '慕容',
  '司马',
  '上官',
  '夏侯',
  '诸葛',
  '薛',
  '叶',
  '阎',
  '余',
  '潘',
  '杜',
  '戴',
  '夏',
  '金',
  '谭',
  '邹',
  '熊',
  '秦',
  '邱',
  '江',
  '尹',
  '姚',
  '肖',
  '汪',
  '王',
  '李',
  '张',
  '刘',
  '陈',
  '杨',
  '赵',
  '长孙',
  '澹台',
  '淳于',
  '公冶',
  '黄',
  '周',
  '吴',
  '徐',
  '孙',
  '胡',
  '朱',
  '高',
  '林',
  '东方',
  '宇文',
  '皇甫',
  '何',
  '郭',
  '马',
  '罗',
  '梁',
  '宋',
  '郑',
  '谢',
  '韩',
  '唐',
  '冯',
  '于',
  '公孙',
  '令狐',
  '赫连',
  '钟离',
  '闻人',
  '董',
  '萧',
  '程',
  '曹',
  '袁',
  '邓',
  '许',
  '傅',
  '沈',
  '曾',
  '彭',
  '吕',
  '苏',
  '卢',
  '蒋',
  '蔡',
  '贾',
  '丁',
  '魏',
  '欧阳',
  '慕容',
  '司马',
  '上官',
  '夏侯',
  '诸葛',
  '薛',
  '叶',
  '阎',
  '余',
  '潘',
  '杜',
  '戴',
  '夏',
  '金',
  '谭',
  '邹',
  '熊',
  '秦',
  '邱',
  '江',
  '尹',
  '姚',
  '肖',
  '汪'
]?.map((it, i) => ({ surname: it, count: i * 1000 }))

export const imgBase64 =
  ''

http://www.niftyadmin.cn/n/5292112.html

相关文章

可用于blender制作3D动画的全身动捕设备

随着动捕设备的进步&#xff0c;在3D建模和动画制作领域中&#xff0c;动捕设备被广泛应用&#xff0c;以便创建更加真实和自然的角色动画。其中&#xff0c;blender作为一款开源的3D建模和动画软件&#xff0c;搭配全身动捕设备使用&#xff0c;更加激发了用户角色动画创作灵感…

OSPF被动接口配置-新版(14)

目录 整体拓扑 操作步骤 1.基本配置 1.1 配置R1的IP 1.2 配置R2的IP 1.4 配置R4的IP 1.5 配置R5的IP 1.6 配置PC-1的IP地址 1.7 配置PC-2的IP地址 1.8 配置PC-3的IP地址 1.9 配置PC-4的IP地址 1.10 检测R1与PC3连通性 1.11 检测R2与PC4连通性 1.12 检测R4与PC1连…

【51单片机系列】DS18B20温度传感器扩展实验之设计一个智能温控系统

本文是关于DS18B20温度传感器的一个扩展实验。 文章目录 一、相关元件介绍二、实验分析三、proteus原理图设计四、软件设计 本扩展实验实现的功能&#xff1a;利用DS18B20设计一个智能温度控制系统&#xff0c;具有温度上下限值设定。当温度高于上限值时&#xff0c;电机开启&a…

34道ZooKeeper面试题带答案(很全)

1. Zookeeper是什么&#xff1f; Zookeeper是一个开放源码的 分布式协调服务 &#xff0c;它是集群的管理者&#xff0c;监视着集群中各个节点的状态根据节点提交的反馈进行下一步合理操作。最终&#xff0c;将简单易用的接口和性能高效、功能稳定的系统提供给用户。 分布式应…

编程语言的未来?

随着科技的飞速发展&#xff0c;编程语言在计算机领域中扮演着至关重要的角色。它们是软件开发的核心&#xff0c;为程序员提供了与机器沟通的桥梁。那么&#xff0c;在技术不断进步的未来&#xff0c;编程语言的走向又将如何呢&#xff1f; 一、当前编程语言的发展趋势 1、向…

MetalLB:本地Kubernetes集群的LoadBalancer负载均衡利器

背景 在本地集群进行测试时&#xff0c;我们常常面临一个棘手的问题&#xff1a;Service Type不支持LoadBalancer&#xff0c;而我们只能选择使用NodePort作为替代。这种情况下&#xff0c;我们通常会配置Service为NodePort&#xff0c;并使用externalIPs将流量导入Kubernetes…

table表格中使用el-popover 无效问题解决

实例只针对单个的按钮管用在表格里每一列都有el-popover相当于是v-for遍历了 所以我们在触发按钮的时候并不是单个的触发某一个 主要执行 代码 <el-popover placement"left" :ref"popover-${scope.$index}"> 动态绑定了ref 关闭弹窗 执行deltask…

NXP实战笔记(三):S32K3xx基于RTD-SDK在S32DS上配置WDT配置

目录 1、WDT概述 2、SWT配置 2.1、超时时间&#xff0c;复位方式的配置 2.2、中断形式 1、WDT概述 SWT 编程模型只允许 32 位&#xff08;字&#xff09;访问。 以下任何尝试访问都是无效的: •非32位访问 •写入只读寄存器 •启用SWT时&#xff0c;将不正确的值写入SR…