Echarts词云图

Echarts词云图

在这里插入图片描述

下载

npm install echarts-wordcloud
<template>
  <div>
    <p class="trave_title">{{title}}</p>
    <div :style="'width: 100%;'+'height:'+height+';'" :id="id"></div>
  </div>
</template>
<script>
import * as echarts from "echarts";
import "echarts-wordcloud";
export default {
  name: "VueWordCloud",
  props: {
    id: String,
    title: String,
    colorArr: Object,
    height:String,
  },
  data() {
    return {
      msg: "Welcome to Your Vue.js App",
      worddata: [
        {
          name: "总出行9次",
          value: 3000,
        },
        {
          name: "特级席次偏好",
          value: 2500,
        },
        {
          name: "6-12出行偏好",
          value: 2300,
        },
        {
          name: "价格不敏感",
          value: 2000,
        },
        {
          name: "时间敏感",
          value: 1900,
        },
        {
          name: "高铁偏好",
          value: 1800,
        },
        {
          name: "常用北京南站",
          value: 1700,
        },

        {
          name: "总出行9次",
          value: 3100,
        },
        {
          name: "特级席次偏好",
          value: 2150,
        },
        {
          name: "6-12出行偏好",
          value: 2020,
        },
        {
          name: "价格不敏感",
          value: 2100,
        },
        {
          name: "时间敏感",
          value: 1910,
        },
        {
          name: "高铁偏好",
          value: 1810,
        },
        {
          name: "常用北京南站",
          value: 1720,
        },
        {
          name: "6-12出行偏好",
          value: 202214,
        },
        {
          name: "价格不敏感",
          value: 21014,
        },
        {
          name: "时间敏感",
          value: 19114,
        },
        {
          name: "高铁偏好",
          value: 18114,
        },
        {
          name: "常用北京南站",
          value: 114214,
        },

        {
          name: "6-12出行偏好",
          value: 1020,
        },
        {
          name: "价格不敏感",
          value: 1100,
        },
        {
          name: "6-12出行偏好",
          value: 120,
        },
        {
          name: "价格不敏感",
          value: 100,
        },
      ],
      image:
        "",
    };
  },
  created() {},
  mounted() {
    this.initChart(this.id);
  },
  methods: {
    initChart(id) {
      var myChart = echarts.init(document.getElementById(id));
      var maskResource = new Image();
      maskResource.src = this.image;
      const option = {
        title: {
          text: "词云图",
          x: "center",
          show: false,
        },
        // backgroundColor: "#fff",
        backgroundColor: this.colorArr.bgColor,
        tooltip: {
          trigger: "item",
          confine: true,
        },
        series: [
          {
            type: "wordCloud",
            //用来调整词之间的距离
            gridSize: 5,
            //用来调整字的大小范围
            // Text size range which the value in data will be mapped to.
            // Default to have minimum 12px and maximum 60px size.
            sizeRange: [14, 18],
            // Text rotation range and step in degree. Text will be rotated randomly in range [-90,                                                                             90] by rotationStep 45
            //用来调整词的旋转方向,,[0,0]--代表着没有角度,也就是词为水平方向,需要设置角度参考注释内容
            // rotationRange: [-45, 0, 45, 90],
            // rotationRange: [ 0,90],
            rotationRange: [0, 0],
            //随机生成字体颜色
            maskImage: maskResource,
            // maskImage: maskImage,
            // textStyle: {
            //   color: "rgb(214,20,15)",
            // },
            textStyle: {
              color: function () {
                  return (
                    "rgb(" +
                    Math.round(Math.random() * 255) +
                    ", " +
                    Math.round(Math.random() * 255) +
                    ", " +
                    Math.round(Math.random() * 255) +
                    ")"
                  );
                },
            },
            //位置相关设置
            // Folllowing left/top/width/height/right/bottom are used for positioning the word cloud
            // Default to be put in the center and has 75% x 80% size.
            left: "center",
            top: "center",
            right: null,
            bottom: null,
            //数据
            data: this.worddata,
          },
        ],
      };
      // myChart.setOption(option);
      //加载图像,将数据放在图像中
      maskResource.onload = function () {
        myChart.setOption(option);
      };
    },
  },
};
</script>
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Echarts 是一个非常流行的数据可视化库,它支持多种图表类型,包括词云图。下面是一个简单的使用 Echarts 绘制词云图的示例: ```html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Echarts 词云图</title> <!-- 引入 Echarts 库 --> <script src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"></script> </head> <body> <!-- 使用 Echarts 绘制词云图的容器 --> <div id="wordcloud" style="width: 600px; height: 400px;"></div> <script> // 基于准备好的dom,初始化echarts实例 var myChart = echarts.init(document.getElementById('wordcloud')); // 定义词云图的数据 var data = [ {name: '张三', value: 100}, {name: '李四', value: 80}, {name: '王五', value: 70}, {name: '赵六', value: 60}, {name: '钱七', value: 50}, {name: '孙八', value: 40}, {name: '周九', value: 30}, {name: '吴十', value: 20}, ]; // 配置词云图的参数 var option = { series: [{ type: 'wordCloud', shape: 'circle', left: 'center', top: 'center', width: '80%', height: '80%', right: null, bottom: null, sizeRange: [12, 60], rotationRange: [-90, 90], rotationStep: 45, gridSize: 8, drawOutOfBound: false, textStyle: { normal: { 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(',') + ')'; } }, emphasis: { shadowBlur: 10, shadowColor: '#333' } }, data: data }] }; // 使用刚指定的配置项和数据显示图表。 myChart.setOption(option); </script> </body> </html> ``` 这个示例中,我们首先引入了 Echarts 库,然后在页面中创建一个容器用于显示词云图。接着,我们定义了词云图的数据,包括每个词的名称和权重。最后,我们使用 Echarts 的 `wordCloud` 类型来创建词云图,并通过配置参数来指定词云图的样式和数据。最终,我们将配置项和数据传递给 Echarts 的实例对象,并通过调用 `setOption` 方法显示图表。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值