Echarts—词云库(echarts-wordcloud)配置详解和使用(可自定义形状)

Echarts—词云库(echarts-wordcloud)配置详解和使用(可自定义形状)

安装

echarts-wordcloud是基于echarts的一个插件,所以我们要首先安装echarts包,然后再安装echarts-wordcloud的包,这里我的练习项目安装的版本;当然,你可以随意安装你需要的版本;

npm install echarts@5.3.3
npm install echarts-wordcloud@2.0.0

基本配置详解

词库云的使用方式其实跟echart组件是一样的,也是首先需要一个容器,然后对其进行配置,我们先来看一下他的一下配置项,最后我们再把详细的使用方法以及代码展示出来;
echarts-wordcloud官方github地址

<template>
  <div id="container" class="wordcloud-wrapper"></div>
</template>

<script>
  export default {
    data() {
      return {
        fruits: [
          { name: "互联网服务", value: 1000 },
          { name: "交通运输", value: 850 },
          { name: "公司", value: 800 },
          { name: "军工", value: 600 },
          { name: "医药", value: 900 },
          { name: "商务服务", value: 600 },
          { name: "城乡规划", value: 800 },
          { name: "家政服务", value: 400 },
          { name: "安防", value: 850 },
          { name: "医疗服务", value: 200 },
          { name: "电子科技", value: 8000 },
          { name: "航空航天", value: 1500 },
          { name: "食品饮料", value: 1500 },
          { name: "能源", value: 800 },
          { name: "教育培训", value: 200 },
          { name: "金融", value: 100 },
          { name: "文化娱乐", value: 250 },
          { name: "电力", value: 1200 },
          { name: "石油化工", value: 300 },
          { name: "电子商务", value: 900 },
          { name: "建筑", value: 700 },
          { name: "旅游", value: 550 },
          { name: "环保", value: 750 },
          { name: "地产", value: 1100 },
          { name: "体育", value: 300 },
          { name: "通信", value: 950 },
          { name: "科研", value: 1200 },
          { name: "物流", value: 1300 },
          { name: "咨询", value: 600 },
          { name: "游戏", value: 850 },
          { name: "人力资源", value: 500 },
          { name: "水务", value: 300 },
          { name: "舞蹈艺术", value: 150 },
          { name: "汽车制造", value: 1100 },
          { name: "电影制作", value: 350 },
          { name: "游乐园", value: 250 },
          { name: "新能源", value: 900 },
          { name: "服装设计", value: 400 },
          { name: "采矿", value: 700 },
          { name: "信息安全", value: 800 },
          { name: "化妆品", value: 600 },
          { name: "音乐产业", value: 750 },
          { name: "物联网", value: 1200 },
          { name: "绿色建筑", value: 850 },
          { name: "社交媒体", value: 950 },
          { name: "人工智能", value: 1000 },
          { name: "水产养殖", value: 320 },
          { name: "医学研究", value: 1800 },
          { name: "动物保护", value: 130 },
          { name: "航海", value: 1000 }
        ],
        chart: null
      }
    },
    mounted() {
      this.initChart()
    },
    methods: {
      initChart() {
        this.chart = this.$echarts.init(document.getElementById("container"))
        const maskImage = new Image()
		//自定义形状,矢量图 base64    
		//矢量图可以从iconfont下载  地址:https://www.iconfont.cn/
        maskImage.src =
          ""
        this.chart.setOption({
          title: {
            text: "",

            link: "http://www.google.com/trends/hottrends"
          },

          tooltip: {
            show: true
          },

          grid: {
            left: "5%",

            right: "5%",

            bottom: "5%",

            top: "5%",

            containLabel: true
          },

          series: [
            {
              type: "wordCloud",

              // maskImage: maskImage, //自定义形状

              gridSize: 8, // 控制词云图的网格大小,值越大词语之间的间距越大

              sizeRange: [10, 80], // 控制词语的大小范围

              rotationRange: [0, 0], // 控制词语的旋转角度范围

              rotationStep: 45, // 控制词语旋转的步长

              shape: "circle", // 控制词云图的形状,可选值为 'circle', 'cardioid', 'diamond', 'triangle-forward', 'triangle', 'pentagon', 'star'

              drawOutOfBound: false, // 控制词云图是否允许词语超出绘制区域

              // 布局的时候是否有动画

              layoutAnimation: true,

              // 图的位置

              left: "center",

              top: "center",
              // 词汇样式

              textStyle: {
                fontFamily: "sans-serif",

                // fontWeight: 'bold',

                color: function () {
                  return (
                    "rgb(" +
                    [
                      Math.round(Math.random() * 160),

                      Math.round(Math.random() * 160),

                      Math.round(Math.random() * 160)
                    ].join(",") +
                    ")"
                  )
                }
              },

              data: this.fruits,

              emphasis: {
                focus: "self",

                textStyle: {
                  fontSize: 20 // 点击的词放大
                }
              }
            }
          ]
        }),
          // 添加词的点击事件处理函数

          this.chart.on("click", function (data) {
            console.log("click", data)
          })

        // 监听词云图中词语的鼠标移入事件

        this.chart.on("mouseover", function (data) {
          console.log("mouseover", data)
        })
      }
    }
  }
</script>

<style lang="scss" scoped>
  .wordcloud-wrapper {
    width: 800px;
    height: 500px;
  }
</style>

你可能感兴趣的:(javascript,echarts)