ECharts:echarts-wordcloud词云图

         echarts-wordcloud词云库是基于wordcloud2.js的Apache ECharts版本实现。

词云库的引入

        echarts-wordcloud词云库需要配合ECharts一起使用,引入方式为:

        ①直接通过script标签引入,

<script src="echarts.min.js"></script>
<script src="echarts-wordcloud.min.js"></script>

        ②使用npm命令引入,

npm install echarts
npm install echarts-wordcloud

        使用方式如下,

import * as echarts from 'echarts';
import 'echarts-wordcloud';

词云库的版本匹配问题

         echarts-wordcloud的github官网做了如下版本匹配规则介绍:

echarts-wordcloud@2 is for echarts@5

echarts-wordcloud@1 is for echarts@4

使用示例

         完整示例代码如下,

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>82-ECharts词云图.html</title>
  <!-- 引入依赖库 -->
  <script src="./node_modules/echarts/dist/echarts.js"></script>
  <script src="./node_modules/echarts-wordcloud/dist/echarts-wordcloud.js"></script>
  <style>
    #main {
      width: 400px;
      height: 400px;
      border: 1px solid #ccc;
    }
  </style>
</head>

<body>
  <img
    src=""
    alt="">
  <div id="main"></div>
</body>
<script>
  const data = {
    value: [
    {
      "name": "开源项目",
      "value": 1437
    },{
      "name": "openSource",
      "value": 1146
    },
    {
      "name": "openSource",
      "value": 928
    },
    {
      "name": "openSource",
      "value": 906
    },
    {
      "name": "openSource",
      "value": 825
    },
    {
      "name": "openSource",
      "value": 514
    },
    {
      "name": "openSource",
      "value": 486
    },
    {
      "name": "openSource",
      "value": 53
    },
    {
      "name": "openSource",
      "value": 163
    },
    {
      "name": "openSource",
      "value": 86
    },
    {
      "name": "openSource",
      "value": 17
    },
    {
      "name": "openSource",
      "value": 6
    },
    {
      "name": "openSource",
      "value": 1
    },
   

    ],
    //小鸟图片
    image: ""
  }
  const maskImage = new Image();
  maskImage.src = data.image;
  maskImage.onload = () => {
    const canvas = document.createElement("canvas");
    const context = canvas.getContext("2d");
    console.log(maskImage.width, maskImage.height)
    canvas.width = maskImage.width;
    canvas.height = maskImage.height;
    context.drawImage(maskImage, 0, 0);

    const chart = echarts.init(document.getElementById('main'));

    chart.setOption({
      series: [{
        type: 'wordCloud',

        // The shape of the "cloud" to draw. Can be any polar equation represented as a
        // callback function, or a keyword present. Available presents are circle (default),
        // cardioid (apple or heart shape curve, the most known polar equation), diamond (
        // alias of square), triangle-forward, triangle, (alias of triangle-upright, pentagon, and star.

        shape: 'circle', //形状参数

        // Keep aspect ratio of maskImage or 1:1 for shapes
        // This option is supported since echarts-wordcloud@2.1.0
        keepAspect: false,//

        // A silhouette image which the white area will be excluded from drawing texts.
        // The shape option will continue to apply as the shape of the cloud to grow.

        maskImage: canvas,//掩膜图像

        // 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',
        width: '100%',
        height: '100%',
        right: null,
        bottom: null,

        // Text size range which the value in data will be mapped to.
        // Default to have minimum 12px and maximum 60px size.

        sizeRange: [12, 60], //文字之间的距离

        // Text rotation range and step in degree. Text will be rotated randomly in range [-90, 90] by rotationStep 45

        rotationRange: [-90, 90],//文字旋转角度的范围
        rotationStep: 45,//文字旋转角度的步长值

        // size of the grid in pixels for marking the availability of the canvas
        // the larger the grid size, the bigger the gap between words.

        gridSize: 8,

        // set to true to allow word to be drawn partly outside of the canvas.
        // Allow word bigger than the size of the canvas to be drawn
        // This option is supported since echarts-wordcloud@2.1.0
        drawOutOfBound: false,

        // if the font size is too large for the text to be displayed,
        // whether to shrink the text. If it is set to false, the text will
        // not be rendered. If it is set to true, the text will be shrinked.
        // This option is supported since echarts-wordcloud@2.1.0
        shrinkToFit: false,

        // If perform layout animation.
        // NOTE disable it will lead to UI blocking when there is lots of words.
        layoutAnimation: true,

        // Global text style
        textStyle: {
          fontFamily: 'sans-serif',
          fontWeight: 'bold',
          // Color can be a callback function or a color string
          color: function () {
            //颜色
            // Random color-随机颜色(r,g,b)
            const randomColor = 'rgb(' + [
              Math.round(Math.random() * 255),
              Math.round(Math.random() * 255),
              Math.round(Math.random() * 255)
            ].join(',') + ')';
            return randomColor;
          }
        },
        emphasis: {
          focus: 'self',

          textStyle: {
            textShadowBlur: 10,
            textShadowColor: '#333'
          }
        },

        // Data is an array. Each array item must have name and value property.
        data:data.value
      }]
    });
  }


</script>

</html>

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在Vue项目中使用echarts-wordcloud绘制词云图,可以按照以下步骤操作: 1. 安装echartsecharts-wordcloud插件 ```bash npm install echarts --save npm install echarts-wordcloud --save ``` 2. 在需要使用词云图的组件中引入echarts ```javascript import echarts from 'echarts' ``` 3. 在mounted生命周期中初始化echarts实例,并设置词云图的配置项 ```javascript mounted() { const chartDom = this.$refs.chart const myChart = echarts.init(chartDom) const option = { series: [{ type: 'wordCloud', shape: 'circle', sizeRange: [20, 80], rotationRange: [-90, 90], rotationStep: 45, gridSize: 2, textStyle: { normal: { fontFamily: 'sans-serif', fontWeight: 'bold', color: function () { return 'rgb(' + [ Math.round(Math.random() * 255), Math.round(Math.random() * 255), Math.round(Math.random() * 255) ].join(',') + ')' } } }, data: [ { name: 'Apple', value: 10000 }, { name: 'Banana', value: 6181 }, { name: 'Orange', value: 4386 }, { name: 'Watermelon', value: 4055 }, { name: 'Pineapple', value: 2467 }, { name: 'Grape', value: 2244 }, { name: 'Mango', value: 1898 }, { name: 'Pear', value: 1484 }, { name: 'Cherry', value: 1001 }, { name: 'Peach', value: 987 }, { name: 'Kiwi', value: 900 } ] }] } myChart.setOption(option) } ``` 4. 在模板中添加echarts实例的容器 ```html <template> <div> <div ref="chart" style="width: 600px; height: 400px;"></div> </div> </template> ``` 以上就是在Vue项目中使用echarts-wordcloud绘制词云图的步骤,需要注意的是,词云图的配置项需要根据实际需求进行修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是席木木啊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值