位置: IT常识 - 正文

echarts-wordcloud 血泪总结使用说明 (配置项及其不足点优化)

发布时间:2024-01-04
echarts-wordcloud 血泪总结使用说明 (配置项及其不足点优化) 基本使用方法

推荐整理分享echarts-wordcloud 血泪总结使用说明 (配置项及其不足点优化),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

echarts-wordcloud是基于echarts的一个词云库,是我常用的一个组件,业务上用的多一点,但是这个库在echarts的官网文档里面没有说明,git上的说明也很少,有些配置需要自己摸索,下面都是我的血泪总结。官方github地址

依赖

首先要安装echarts包,这是基础包,然后还需要额外引入词云的包,对应的版本可自行选择,我这不是最新的

“echarts-wordcloud”: “^2.0.0” “echarts”: “^5.1.2”

echarts-wordcloud 血泪总结使用说明 (配置项及其不足点优化)

项目中使用:

import * as echarts from 'echarts'import 'echarts-wordcloud'echarts-wordcloud 的基本配置项

首先基本使用:

// 这里和echarts的使用一样,先拿到容器元素const chart = echarts.init(document.getElementById('tlrealtimewordcloud'))// 这里是官方给出的一些基本的配置项,我做一些说明chart.setOption({ ... series: [{ type: 'wordCloud',// shape这个属性虽然可配置,但是在词的数量不太多的时候,效果不明显,它会趋向于画一个椭圆 shape: 'circle', // 这个功能还没用过 keepAspect: false, // 这个是可以自定义背景图片的,词云会按照图片的形状排布,所以有形状限制的时候,最好用背景图来实现,而且,这个背景图一定要放base64的,不然词云画不出来 maskImage: maskImage, // 下面就是位置的配置 left: 'center', top: 'center', width: '70%', height: '80%', right: null, bottom: null, // 词的大小,最小12px,最大60px,可以在这个范围调整词的大小 sizeRange: [12, 60], // 每个词旋转的角度范围和旋转的步进 rotationRange: [-90, 90], rotationStep: 45, // 词间距,数值越小,间距越小,这里间距太小的话,会出现大词把小词套住的情况,比如一个大的口字,中间会有比较大的空隙,这时候他会把一些很小的字放在口字里面,这样的话,鼠标就无法选中里面的那个小字,这里可以用函数根据词云的数量动态返回间距 gridSize: 8,// 允许词太大的时候,超出画布的范围 drawOutOfBound: false,// 布局的时候是否有动画 layoutAnimation: true, // 这是全局的文字样式,相对应的还可以对每个词设置字体样式 textStyle: { fontFamily: 'sans-serif', fontWeight: 'bold', // 颜色可以用一个函数来返回字符串,这里是随机色 color: function () { // Random color return 'rgb(' + [ Math.round(Math.random() * 160), Math.round(Math.random() * 160), Math.round(Math.random() * 160) ].join(',') + ')'; } }, emphasis: { focus: 'self', textStyle: { textShadowBlur: 10, textShadowColor: '#333' } }, // 数据必须是一个数组,数组是对象,对象必须有name和value属性 data: [{ name: 'Farrah Abraham', value: 366, // 这里就是对每个字体的样式进行设置 textStyle: { } }] }]});优化项shape

shape也可以是一个函数,比如希望是矩形的时候(来自官方githup问答区)

shape: function shapeSquare(theta) { return Math.min( 1 / Math.abs(Math.cos(theta)), 1 / Math.abs(Math.sin(theta)) ) },gridSize

可以用一个函数根据词云的数量动态确定词间距

color

颜色可以在外面统一配置,也可以像下文那样给每个词都配置一下,这里推荐一组好看的配色

['#86D4FF', '#FF8F6C', '#2CF263', '#9FA8F7', '#1274FF', '#E6613D', '#FFC629', '#FFAB2E', '#F78289', '#FF6C96', '#45BFD4', '#4E31FF', '#31FBFB','#86D4FF', '#BF8AFD', '#FFF500', '#DE58FF', '#72ED7C', '#0BEEB8','#931CFF', '#3D25F2', '#F995C8', '#FBE9B4', '#FF4AB6']

效果是这样的

权重问题

组件会严格按照value值的大小分配权重,权重就体现在字体大小上。所以如果数据本身分布不均匀的时候,视觉效果看起来不够好,比如一个数为10000,其他的数为100-10,那么只能体现出两种权重了,即10000和其他。但是这样往往会导致视觉上,权重的分层不够明显,所以我们这个时候需要给数据分配权重,也就是改变每个词的fontSize.

代码主要思路是:

数据量少于8个的时候,仅做了颜色的处理(业务需求,只有红黑两系颜色)数据量大于8个的时候,二分法,把数据分成四部分,对于第一梯队的数据来说,一般是最重要的,至少也有两个数据,我们只对这一部分的数据做权重处理,就可以有良好的视觉效果最大的那个词,给一个最大的权重60,第二个和第三个,分别给55和40,剩下的就是(40-排名数)如果还有需求的话,可以再细化一点,如果能上相关的聚类算法,那就更完美了 大体效果为: 可以看见,排名靠前的都显示的比较好,直观而且有层次感// 这里是我自己摸索的四分法,面对数据分配不均匀的时候还是挺有效果的 const blackcolor = ['#000000', '#2a2a2a', '#545454', '#7e7e7e'] const redcolor = ['rgb(249,8,8)', 'rgba(249,8,8, 0.7)', 'rgba(249,8,8, 0.5)', 'rgba(249,8,8, 0.3)'] const iterate = (arr, i, j, l) => { if(l === 0){ for(let k = i; k <= j; k++){ if(k === 0){ arr[k].textStyle = { color: blackcolor[l], fontSize: 60 } } else if(k < 3) { if(k % 2 === 0){ arr[k].textStyle = { color: redcolor[l], fontSize: 40 } } else { arr[k].textStyle = { color: blackcolor[l], fontSize: 55 } } } else { if(k % 2 === 0){ arr[k].textStyle = { color: redcolor[l], fontSize: 40 - k } } else { arr[k].textStyle = { color: blackcolor[l], fontSize: 40 - k } } } } } else { for(let k = i; k <=j ; k++){ if(k % 2 === 0){ arr[k].textStyle = { color: redcolor[l] } } else { arr[k].textStyle = { color: blackcolor[l] } } } } } const dealworddata = (data) => { let len = data.length if(len <= 8 ){ let i = 0,j = 0,k = 0 while(k<len){ if( k % 2 === 0){ data[k].textStyle = { color: redcolor[i] } i++ } else { data[k].textStyle = { color: blackcolor[j] } j++ } k++ } } else { let mid = len >> 1 let leftmid = len >> 1 let rightmid = (len - 1 + mid) >> 1 iterate(data, 0, leftmid, 0) iterate(data, leftmid, mid, 1) iterate(data, mid, rightmid, 2) iterate(data, rightmid, len-1, 3) } }背景图片const maskImage = new Image() maskImage.src = ‘’ // 这里是base64编码 ... maskImage: maskImage
本文链接地址:https://www.jiuchutong.com/zhishi/285139.html 转载请保留说明!

上一篇:木星及木卫一的蒙太奇图像 (© NASA/Johns Hopkins University Applied Physics Laboratory/Southwest Research Institute/Goddard Space Flight Center)(木卫一距离木星多远)

下一篇:东内格罗斯省沿海的鹦嘴鱼,菲律宾 (© Tim Fitzharris/Minden Pictures)(内格罗斯岛)

  • 通话记录生成器app(通话记录)(通话记录生成器下载)

    通话记录生成器app(通话记录)(通话记录生成器下载)

  • 手机流量不够用怎么办?我是移动卡(手机流量不够用怎么办)

    手机流量不够用怎么办?我是移动卡(手机流量不够用怎么办)

  • 苹果x耳机插上还是扬声器有声音(iphone耳机插上)

    苹果x耳机插上还是扬声器有声音(iphone耳机插上)

  • 苹果照片权限开启不了怎么办(苹果 照片权限 打开)

    苹果照片权限开启不了怎么办(苹果 照片权限 打开)

  • 购买相机时需要注意什么问题(购买相机时需要注意什么)

    购买相机时需要注意什么问题(购买相机时需要注意什么)

  • 微店是腾讯的吗(微店是腾讯旗下产品吗)

    微店是腾讯的吗(微店是腾讯旗下产品吗)

  • 表格内数字显示E 是什么情况(表格内数字显示不全)

    表格内数字显示E 是什么情况(表格内数字显示不全)

  • qq一方解除关联会怎样(qq一方解除关联另一方能不能看到聊天记录)

    qq一方解除关联会怎样(qq一方解除关联另一方能不能看到聊天记录)

  • 系统设计包括哪两个阶段(系统设计包括哪两大部分)

    系统设计包括哪两个阶段(系统设计包括哪两大部分)

  • 编码和译码是互逆的吗(编码和译码是互译的过程)

    编码和译码是互逆的吗(编码和译码是互译的过程)

  • 苹果手机听筒进油了怎么办(苹果手机听筒进水了有影响吗)

    苹果手机听筒进油了怎么办(苹果手机听筒进水了有影响吗)

  • 监控内存卡初始化失败(监控内存卡初始化不了怎么办)

    监控内存卡初始化失败(监控内存卡初始化不了怎么办)

  • 电位器三个引脚怎么接(电位器三个引脚的定义)

    电位器三个引脚怎么接(电位器三个引脚的定义)

  • 无效的音频文件路径是咋回事(无效的音频文件路径)

    无效的音频文件路径是咋回事(无效的音频文件路径)

  • 手机屏幕漏液是内屏还是外屏(手机屏幕漏液是什么原因)

    手机屏幕漏液是内屏还是外屏(手机屏幕漏液是什么原因)

  • 红米note4充不进电是什么原因(红米note4突然充不了电)

    红米note4充不进电是什么原因(红米note4突然充不了电)

  • 支付宝怎么在相册扫福卡(支付宝怎么相互扫红包)

    支付宝怎么在相册扫福卡(支付宝怎么相互扫红包)

  • ip地址由几个字节组成(ip地址由几个字节二进制数表示)

    ip地址由几个字节组成(ip地址由几个字节二进制数表示)

  • 京东待评价如何清空(京东的待评价是到货了吗)

    京东待评价如何清空(京东的待评价是到货了吗)

  • soul软件怎么隐身上线(soul软件怎么隐藏关注的人)

    soul软件怎么隐身上线(soul软件怎么隐藏关注的人)

  • 苹果手机私密照片设置(苹果手机私密照片放在哪里最安全)

    苹果手机私密照片设置(苹果手机私密照片放在哪里最安全)

  • xsmax有抬头灯吗(苹果xs max抬头灯唤醒在哪里)

    xsmax有抬头灯吗(苹果xs max抬头灯唤醒在哪里)

  • 荣耀9x是typec吗

    荣耀9x是typec吗

  • 苹果11是什么材质的机身(苹果11是什么材质的边框)

    苹果11是什么材质的机身(苹果11是什么材质的边框)

  • 如何删除收藏的内容(如何删除收藏的作品)

    如何删除收藏的内容(如何删除收藏的作品)

  • etc和手机蓝牙连接不上(etc和手机蓝牙连在一起)

    etc和手机蓝牙连接不上(etc和手机蓝牙连在一起)

  • ap怎么设置(ap怎么设置屏幕旋转)

    ap怎么设置(ap怎么设置屏幕旋转)

  • 微软官方教你如何绕过Win11 TPM和CPU检查(微软官方教你如何验机)

    微软官方教你如何绕过Win11 TPM和CPU检查(微软官方教你如何验机)

  • MAC怎么显示农历日历?苹果电脑系统显示农历日历方法介绍(mac的日历)

    MAC怎么显示农历日历?苹果电脑系统显示农历日历方法介绍(mac的日历)

  • 小规模纳税人预缴企业所得税
  • 预提费用
  • 新准则下对亏损的规定
  • 小微企业亏损还用缴残保金吗
  • 委托加工白酒怎么入账
  • 固定资产出售增值税税率
  • 免税苗木发票如何抵扣计算
  • 生产中的原料回收如何做会计帐务处理?
  • 在建工程非应税项目有哪些?
  • 研发物资
  • 资本公积提取比例怎么算
  • 做内账有风险还是做外账有风险
  • 降低房租
  • 无偿提供服务需要交增值税吗
  • 合并报表利润表是当期还是累计
  • 上市公司企业股东转让股份交什么税费
  • 专项维修基金所得税可税前扣除吗?
  • 售后服务对客户满意度的影响论文
  • 计提坏账的应收账款收回
  • 公转私合理吗
  • 工资薪金所得个人所得税税率表
  • 流氓软件怎么卸载?
  • 鸿蒙系统垃圾清理
  • 所得税费用是什么账户类型
  • 以前年度多计提的税金怎么调整
  • linux查看文件的权限
  • PHP has encountered an Access Violation
  • 编写守护进程
  • 车辆年审收费么
  • vue设置宽度
  • pyecharts怎么用
  • 学计算机选择什么专业
  • php数学
  • 普通发票收款人填管理员可以吗
  • python列表排序sorted
  • mysql索引是否生效
  • mysql union or
  • 织梦自定义模型调用
  • 其他收益包含
  • 劳务派遣差额征税政策
  • 视同销售是填在申报表的哪一栏?
  • 商贸公司成本大吗
  • 差旅费报销原因
  • 注销营业执照的app
  • 弥补以前年度亏损报表怎么填
  • 坏账准备是资产减值损失吗
  • 培训学校的主营业务是什么
  • 超市返利账务处理
  • 已认证的红字发票要给购买方吗
  • 销售商品发生的运输费计入什么科目
  • 公司注销怎么做
  • 公司无偿更换产品违法吗
  • 免税蔬菜交企业所得税吗
  • 小规模纳税人租赁不动产税率
  • 制造费用影响什么
  • linux防御
  • WFXMOD32.EXE - WFXMOD32是什么进程
  • windows开机自启动程序
  • win10系统功能大全
  • 怎么激活win7旗舰版系统
  • linux用户账户管理
  • windows102021年更新
  • linux如何安装wget命令
  • 开关光驱是平移还是旋转
  • win7架设ftp服务器
  • linux查找文件语句
  • unity加载gif
  • opencli
  • js数组entries
  • Expand、Fasthelp、Fc命令的用法
  • 重定向stdout
  • cmd命令怎么重启
  • 安卓手机管家怎么关闭
  • 4种JavaScript实现简单tab选项卡切换的方法
  • animate如何拖动图片
  • python魔法方法有啥用
  • 唐山宴订餐电话是多少
  • 以划拨方式取得的土地使用权
  • 医院等级怎么查询系统
  • 宝安区西乡税务所长
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号