echarts5.x 词云图使用(`[ECharts] Unkown series wordCloud`)
echarts5.x + wordcloud2.x 搭配使用
·
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 格式然后在代码里引用
- 图片最好选纯黑色填充,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
更多推荐
已为社区贡献2条内容
所有评论(0)