angular使用echarts词云图wordCloud

环境

angular cli: 8.3.8
node: 10.17.0

安装

项目中安装echarts,echarts-wordCloud两个库;
wordCloud是echarts的插件;

npm install echarts--save
npm install echarts-wordcloud --save

检查

package.json中添加两个依赖;
在这里插入图片描述

使用

在需要使用的component中引入两个库

import * as echarts from 'echarts';
import "echarts-wordcloud/src/wordCloud.js";

对应的serious的type设置为wordCloud跟其他的柱状图bar,饼图pie差不多一样的用法

series: [{
        type: 'wordCloud',
        size: ['9%', '50%'],
        sizeRange: [10, 30],
        textRotation: [0, 45, 90, -45],
        rotationRange: [-45, 90],
        gridSize: 8,
        shape: 'diamond',
        drawOutOfBound: false,
        autoSize: {
          enable: true,
          minSize: 6
        },
        textStyle: {
          normal: {
            color: () => {
              return 'rgb(' + [
                Math.round(Math.random() * 160),
                Math.round(Math.random() * 160),
                Math.round(Math.random() * 160)
              ].join(',') + ')';
            }
          },
          emphasis: {
            shadowBlur: 10,
            shadowColor: 'rgba(0, 0, 0, 0.15)'
          }
        },
        data: data.value
      }]

效果图

在这里插入图片描述
在这里插入图片描述

贴一个完整的设置echarts方法


  initWordCloud() {
    let data = {
      value: [
        { "value": 123, "name": "张继科换 情侣  头像" },
        { "value": 124, "name": "何猷君 文物 上 涂鸦" },
        { "value": 126, "name": "微信 520元 红包" },
        { "value": 122, "name": "谷歌  停止  华为  合作" },
        { "value": 121, "name": "男子 验 出月 经 推迟" },
        { "value": 122, "name": "江苏  校园 反杀案" },
        { "value": 132, "name": "圆通  速递  猥亵  客户" },
        { "value": 112, "name": "日本  偶遇  梁朝 伟" },
        { "value": 114, "name": "梅西获金靴" },
        { "value": 132, "name": "哈文生" },
        { "value": 88, "name": "姜潮" },
        { "value": 99, "name": "何猷君" },
        { "value": 132, "name": "男婴" },
        { "value": 134, "name": "杭州" },
        { "value": 122, "name": "合照" },
        { "value": 66, "name": "赵帅" },
        { "value": 98, "name": "杭州" },
        { "value": 99, "name": "成都" },
        { "value": 96, "name": "张紫妍案 调查结果" },
        { "value": 204, "name": "A股爱囤房" },
        { "value": 231, "name": "部分  合作" },
        { "value": 123, "name": "刘士余案" },
        { "value": 123, "name": "酒后玻璃" },
        { "value": 124, "name": "首都 备降" },
        { "value": 123, "name": "靓号被使用" },
        { "value": 111, "name": "施瓦辛格踹" },
        { "value": 112, "name": "联想  造谣者  道歉" },
        { "value": 114, "name": "埃及  巴士  炸弹  袭击" },
        { "value": 116, "name": "高三  女孩 弃考 救母" },
        { "value": 165, "name": "郑姝音遭 争议 判罚" },
        { "value": 147, "name": "长沙 公交 连撞  10 车" },
        { "value": 134, "name": "散步  晕倒  男婴  被盗" },
        { "value": 132, "name": "松原  5.1 级 地震" },
        { "value": 143, "name": "印第安纳州  枪击案" },
        { "value": 156, "name": "苏志 燮赵 恩情  恋情" }
      ],
      //小鸟图片
      image: ""
    }
    this.myChart2 = echarts.init(document.getElementById('echart_word'));
    //温馨提示:image 选取有严格要求不可过大;,否则firefox不兼容  iconfont上面的图标可以
    let maskImage = new Image();
    maskImage.src = data.image

    // maskImage.onload = function () {
    this.myChart2.setOption({
      backgroundColor: '#fff',
      color: this.colorList,
      tooltip: {
        show: false
      },
      series: [{
        type: 'wordCloud',
        size: ['9%', '50%'],
        sizeRange: [10, 30],
        textRotation: [0, 45, 90, -45],
        rotationRange: [-45, 90],
        gridSize: 8,
        shape: 'diamond',
        drawOutOfBound: false,
        autoSize: {
          enable: true,
          minSize: 6
        },
        textStyle: {
          normal: {
            color: () => {
              return 'rgb(' + [
                Math.round(Math.random() * 160),
                Math.round(Math.random() * 160),
                Math.round(Math.random() * 160)
              ].join(',') + ')';
            }
          },
          emphasis: {
            shadowBlur: 10,
            shadowColor: 'rgba(0, 0, 0, 0.15)'
          }
        },
        data: data.value
      }]
    })

  }

猜你喜欢

转载自blog.csdn.net/qwe1314225/article/details/112041609