文章目录

  • 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 } = paramsreturn `
平台:${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 格式然后在代码里引用

  • 图片最好选纯黑色填充,120px 左右大小(我试了好多种图片,只有2种成功了,匹配度还不是很高,后续用到了再探索吧……)
  • 参考:关于Echarts词云图自定义形状如何实现
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, // 关键代码// ... 其他业务代码

动效

  • 未研究,留个看着靠谱的参考:圆形词云(旋转)TagCanvas

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

  1. vue [ECharts] Unkown series surface

    echarts引用3d图形首先需要引入echarts其次在引入echarts-gl import * as echarts from "echarts"; import " ...

  2. vue实现词云图(echarts/Highcharts)

    vue实现词云图 1.echarts实现 安装 注意版本 echarts-wordcloud@2 is for echarts@5 echarts-wordcloud@1 is for echarts ...

  3. 自定义文字云/词云图----基于echarts

    demo连接 :自定义文字云/词云图 效果如下: 人形态 小鸟形态 参考 https://github.com/ecomfe/echarts-wordcloud, https://blog.csdn. ...

  4. python词云图实验报告_Python实现Wordcloud生成词云图的示例

    wordcloud是Python扩展库中一种将词语用图片表达出来的一种形式,通过词云生成的图片,我们可以更加直观的看出某篇文章的故事梗概. 首先贴出一张词云图(以哈利波特小说为例): 在生成词云图之前 ...

  5. b站《双城之战》主题曲《孤勇者》视频评论爬取+简单数据分析+基本可视化(条形图,饼图,词云图)

    双城之战更新啦!!!!!<孤勇者>也在b站上线了!!!! <孤勇者> 是真的好听!!!!没听的快给我去听:<双城之战>也是真的好看,没看到快给我去看!!!! 今天我 ...

  6. 商品评论获取与词云图可视化分析

    商品评论获取解析与可视化词云图制作 本篇文章主要介绍如何手写爬虫爬取电商平台评论数据,以及对爬取到的内容进行解析,导入mysql数据库并进行词频统计,可视化制作词云图. 涉及的技术点如下: 电商网站页 ...

  7. python 画云图_【词云图】如何用python的第三方库jieba和wordcloud画词云图

    一直想学一下如何用python画词云图,觉得很好玩,本文就写一下我自己的一些尝试. 1.提前准备 一般准备以下四样就可以啦. 第一,电脑安装python,我装的是3.6. 第二,安装第三方库jieba ...

  8. python词云图代码示例 无jieba_【词云图】如何用python的第三方库jieba和wordcloud画词云图...

    一直想学一下如何用python画词云图,觉得很好玩,本文就写一下我自己的一些尝试. 1.提前准备 一般准备以下四样就可以啦. 第一,电脑安装python,我装的是3.6. 第二,安装第三方库jieba ...

  9. python实战1.1——根据1.0做词云图

    python实战1.1--根据1.0做词云图 最基础的词云图制作 import jieba import wordcloud import matplotlib.pyplot as pltm=open ...

最新文章

  1. oracle查询正在执行的语句和kill session
  2. InnoDB调优-索引优化策略
  3. Could not find codec parameters for stream 0 (Video: h264, none)
  4. 若依微服务版后台服务通过jar包部署到Windows服务器
  5. koa2 mysql增删改查_koa2实现对mysql的增删改查函数封装
  6. 前端知识点总结---面试专用
  7. 分布式系统:SrpingBoot整合Zookeeper和Dubbo的版本匹配问题
  8. mongo数据库插入数据_深入研究Mongo数据库
  9. 在使用 Elasticsearch 时要注意什么?
  10. 老王讲设计模式(一)——策略模式
  11. 英特尔加入 GPU 战局,终用上 6nm 工艺?
  12. python模块之httplib(在py3中功能进一步强大,请详看文档)
  13. eclipse java machine_打开Eclipse弹出“No java virtual machine was found...的解决方法
  14. Linux进程的管理与调度(一)--- Linux进程描述符task_struct结构体详解
  15. UNITY_DOTWEEN_PATH路径动画的使用
  16. 数学模型建立常用方法
  17. 微信和qq默认表情代码对照表及表情文件下载
  18. Apizza在线接口工具动态绑定API参数依赖
  19. 如何在快手批量下载高清不含水印视频
  20. SAP那些事-理论篇-18-如何做SAP售前

热门文章

  1. 如何设置App的启动图
  2. ae教程 (六)人物滤镜 (三)皮肤润饰
  3. 人工智能之数学基础篇—高等数学基础(下篇)
  4. 合伙人退出机制如何设定
  5. NS3安装步骤【MAC系统】
  6. SIDUS HEROES链游相关分析
  7. Google新三驾马车
  8. linux修改文件夹磁盘,linux下修改磁盘卷标
  9. 神了,这5大预言 都将在2020年显现
  10. Excel基础:开始菜单之字体的华丽转身