echarts5.x 词云图使用(`[ECharts] Unkown series wordCloud`)

echarts5.x 词云图使用([ECharts] Unkown series wordCloud

已发表博客:echarts5.x 词云图使用([ECharts] Unkown series wordCloud

背景

起先还庆幸自己 echarts 用的是 5.x 的版本,似乎可以少些麻烦

结果发现按照 echarts-wordcloud 描述的操作歩鄹,词云图并出不来……

打开控制台,出现了报错:log.js:62 [ECharts] Unkown series wordCloud

估摸着就是引用不对,翻了几遍文档及网上的案例,都是那么简单的几步,并没有找到什么遗漏的操作

没有办法,就试着看看是不是引用有问题,我找了下 node_modules 目录,发现并没有 wordCloud 相关的包,居然引用也不报错?打印出来发现 undefined,找不到返回 undefined 似乎逻辑上也没什么问题……

没装上就重新装一下咯,结果发现 cnpm install echarts-wordcloud 秒过,但依赖包并没有下载过来,npm install echarts-wordcloud 等了半天装了一堆毫不相干的东西,还报了个错……


装不上……那就复制源码本地保存一份咯……

去到 echarts-wordcloud 的 github,复制了 echarts-wordcloud.min.js 代码,存在了 utils 目录下,然后用相对路径引入进来,发现就行了……

预期效果

样例代码

import * as echarts from "echarts"
import "@/utils/echarts-wordcloud.min.js"

drawLine () {
  let LineCharts = this.$refs.LineCharts;
  let myChart = echarts.init(LineCharts);
  let mockData = [{ name: '微信', value: 3328 }, { name: '南方+', value: 1045 }, { name: '东莞时间网', value: 834 }, { name: '东莞', value: 804 }, { name: '新浪微博', value: 532 }, { name: '今日头条', value: 493 }, { name: '腾讯新闻', value: 479 }, { name: '东莞阳光网', value: 387 }, { name: '东莞日报', value: 289 }, { name: '一点资讯', value: 287 }, { name: '东方头条网', value: 233 }, { name: '南方都市报', value: 228 }, { name: '新粤网', value: 207 }, { name: '南方plus', value: 206 }, { name: '网易新闻', value: 201 }, { name: '东方头条', value: 180 }, { name: '趣头条', value: 178 }, { name: '羊城派', value: 151 }, { name: '东莞时报', value: 143 }, { name: '莞讯网', value: 139 }, { name: '广州日报', value: 137 }, { name: '东莞阳光台', value: 132 }, { name: '搜狐新闻', value: 129 }, { name: '今日头条.APP', value: 116 }, { name: '东莞阳光平台', value: 108 }, { name: '腾讯新闻.APP', value: 107 }, { name: '南方网', value: 103 }, { name: 'UC头条', value: 98 }, { name: '凤凰新闻', value: 93 }, { name: '报告诉', value: 77 }, { name: '网易新闻.APP', value: 74 }, { name: '中国小康网', value: 64 }, { name: '东莞万江', value: 63 }, { name: '信息时报', value: 59 }, { name: '中国文明网', value: 58 }, { name: '东莞网', value: 57 }, { name: '搜狐新闻(自媒体)', value: 54 }, { name: '南方日报', value: 54 }, { name: '搜狐焦点', value: 53 }, { name: '阳光社区', value: 52 }, { name: '南方plus.APP', value: 47 }, { name: '阳光望牛墩', value: 46 }, { name: '中国报道', value: 43 }, { name: '新浪新闻', value: 43 }, { name: '房掌柜', value: 39 }, { name: '广州日报网', value: 38 }, { name: 'ZAKER', value: 38 }, { name: '一点资讯.APP', value: 35 }, { name: '聚焦东莞', value: 35 }, { name: '广州新闻网', value: 35 }, { name: '新浪', value: 31 }, { name: '东莞服务热线12345', value: 31 }, { name: '人民网', value: 29 }, { name: '阳光热线问政平台', value: 26 }, { name: '党报头条', value: 26 }, { name: '羊城晚报地方版', value: 24 }, { name: '网易房产', value: 23 }, { name: '中国网', value: 22 }, { name: '金羊网', value: 21 }, { name: '东莞长安', value: 21 }, { name: '百家号', value: 21 }, { name: '澎湃新闻', value: 20 }, { name: '读特', value: 19 }, { name: '东方头条.APP', value: 17 }, { name: '阳光石排', value: 16 }, { name: '新浪乐居', value: 16 }, { name: '微信邦', value: 16 }, { name: '搜狐新闻.APP', value: 16 }, { name: '人民日报', value: 16 }, { name: '百度新闻', value: 16 }, { name: '南方都市报.APP', value: 15 }, { name: '荔枝网', value: 15 }, { name: '华人头条', value: 15 }, { name: '广东建设报', value: 15 }, { name: '中国', value: 14 }, { name: '阳光黄江', value: 14 }, { name: '东方网', value: 14 }, { name: '网易', value: 12 }, { name: '搜狐网', value: 12 }, { name: '和讯', value: 12 }, { name: '文化莞城', value: 11 }, { name: '聊聊网', value: 11 }, { name: '58同镇', value: 11 }, { name: '凤凰网', value: 10 }, { name: '新浪网', value: 9 }, { name: '趣头条.APP', value: 9 }, { name: '凤岗网', value: 9 }, { name: '新快网_新快报', value: 8 }, { name: '上游新闻', value: 8 }, { name: '东莞市城市综合管理局', value: 8 }, { name: '大众网', value: 8 }, { name: '中国新闻网', value: 7 }, { name: '第一推', value: 7 }, { name: '大洋网', value: 7 }, { name: '新浪网', value: 6 }, { name: '新浪看点', value: 6 }, { name: '手机和讯网', value: 6 },].slice()

  // 随机颜色
  let randcolor = () => {
    let r = 100 + ~~(Math.random() * 100);
    let g = 135 + ~~(Math.random() * 100);
    let b = 100 + ~~(Math.random() * 100);
    return `rgb(${r}, ${g}, ${b})`
  }
  myChart.setOption({
    tooltip: {
      trigger: 'item',
      formatter: params => {
        const { name, value } = params
        return `
平台:${name} <br/>
数量:${value}
`
      }
    },
    series: [{
      type: 'wordCloud',
      gridSize: 20,
      sizeRange: [12, 50],
      rotationRange: [0, 0],
      shape: 'circle',
      textStyle: {
        color: params => {
          return randcolor()
        },
        emphasis: {
          shadowBlur: 10,
          shadowColor: '#333'
        }
      },
      data: mockData
    }]
  })
},

自定义形状

形状可以从 iconfont 找,下下来的图片可以通过在线工具转成 base64 格式然后在代码里引用

let maskImage = new Image();
maskImage.src = ""

myChart.setOption({
  series: [{
    type: 'wordCloud',
    // gridSize: 20,
    sizeRange: [12, 50],
    // rotationRange: [0, 0],
    rotationRange: [-45, 0, 45, 90],
    maskImage: maskImage, // 关键代码
    // ... 其他业务代码

动效

posted @ 2022-08-07 10:26  suwanbin  阅读(3202)  评论(0编辑  收藏  举报