位置: IT常识 - 正文

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

编辑:rootadmin
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)(内格罗斯岛)

  • 前面板的耳机排线接口(前面板没声音)(前面板和后面板的耳机孔)

    前面板的耳机排线接口(前面板没声音)(前面板和后面板的耳机孔)

  • 直接删除文件,不送入回收站的快捷键是(直接删除文件的快捷键)

    直接删除文件,不送入回收站的快捷键是(直接删除文件的快捷键)

  • 微信仅聊天别人能看到朋友圈吗(微信仅聊天别人能看到我点赞吗)

    微信仅聊天别人能看到朋友圈吗(微信仅聊天别人能看到我点赞吗)

  • 网店页面设置的基本要求(网店店铺页面布局的原则有哪些)

    网店页面设置的基本要求(网店店铺页面布局的原则有哪些)

  • 华为nova7se防水吗(华为nova 7 se手机防水吗)

    华为nova7se防水吗(华为nova 7 se手机防水吗)

  • iPhone11插耳机还是外放(iphone11插耳机的时候感觉有问题)

    iPhone11插耳机还是外放(iphone11插耳机的时候感觉有问题)

  • 苹果提醒事项前面有个圆圈(苹果提醒事项前面的点)

    苹果提醒事项前面有个圆圈(苹果提醒事项前面的点)

  • 淘宝账号可以借给别人用吗(淘宝账号可以借给别人开店吗)

    淘宝账号可以借给别人用吗(淘宝账号可以借给别人开店吗)

  • word表格打印出来没表格线(word表格打印出来有阴影)

    word表格打印出来没表格线(word表格打印出来有阴影)

  • qq更新头像自动发动态怎么关掉(qq更新头像自动更换吗)

    qq更新头像自动发动态怎么关掉(qq更新头像自动更换吗)

  • vivox27支持防水吗(vivox27防不防水视频)

    vivox27支持防水吗(vivox27防不防水视频)

  • 微信拒绝添加好友怎么设置(微信拒绝添加好友是什么意思)

    微信拒绝添加好友怎么设置(微信拒绝添加好友是什么意思)

  • 常用的段落对齐方式(段落对齐方式有5种,分别是)

    常用的段落对齐方式(段落对齐方式有5种,分别是)

  • 为什么手机相机突然变得模糊(为什么手机相机突然不能用了)

    为什么手机相机突然变得模糊(为什么手机相机突然不能用了)

  • 固态硬盘怎么接主板(固态硬盘怎么接线)

    固态硬盘怎么接主板(固态硬盘怎么接线)

  • 小米启用双4g什么意思(小米启用双4g有什么用)

    小米启用双4g什么意思(小米启用双4g有什么用)

  • 怎么关闭抖音商品橱窗(怎么关闭抖音商城免密支付)

    怎么关闭抖音商品橱窗(怎么关闭抖音商城免密支付)

  • 苹果7可以用无线耳机吗(苹果7可以用无线充电吗)

    苹果7可以用无线耳机吗(苹果7可以用无线充电吗)

  • 台式电脑强制关机按什么键(台式电脑强制关机怎么关)

    台式电脑强制关机按什么键(台式电脑强制关机怎么关)

  • vivo x27pro防水吗(vivox27有防水防尘功能吗)

    vivo x27pro防水吗(vivox27有防水防尘功能吗)

  • 屏幕使用时间密码可以输多少次(屏幕使用时间密码忘记怎么办苹果)

    屏幕使用时间密码可以输多少次(屏幕使用时间密码忘记怎么办苹果)

  • 京东退货卖家不审核怎么办(京东退货卖家不同意怎么办)

    京东退货卖家不审核怎么办(京东退货卖家不同意怎么办)

  • 小米8怎么设置来电秀(小米8怎么设置指纹解锁)

    小米8怎么设置来电秀(小米8怎么设置指纹解锁)

  • 华为p30pro保修能不能换屏(华为p30pro在保修期屏幕碎了怎么办)

    华为p30pro保修能不能换屏(华为p30pro在保修期屏幕碎了怎么办)

  • 怎样把照片上手机型号去掉(怎么把照片弄在手机上)

    怎样把照片上手机型号去掉(怎么把照片弄在手机上)

  • 音乐制作:Ableton Live 11 Suite Mac(音乐制作人评刀郎新专辑)

    音乐制作:Ableton Live 11 Suite Mac(音乐制作人评刀郎新专辑)

  • 建筑劳务公司的工资计入什么科目
  • 印花税计税依据是什么
  • 上年多计提增值税,今年如何调整
  • 子母公司有连带责任吗
  • 建筑企业异地预交税款如何处理
  • 会计法对填制审核会计凭证有哪些规定
  • 办理外汇账户开户手续
  • 金融企业税务稽查案例分析
  • 预付房租的会计科目
  • 公司和员工之间
  • 采购运输管理系统
  • 营改增后的民办养老院收入是否含增值税收入?
  • 计提年终奖金的会计分录怎么写
  • 农副产品税率及范围
  • 补充养老保险交200和500差别
  • 防伪税控服务费减免文件
  • 减半征收城建税文件
  • 中途建账期初余额错误怎么纠正
  • 第二年缴纳税控盘服务费入什么科目?
  • 购置土地税款怎么入账?
  • 外币财务报表折算未分配利润采用什么汇率
  • 应收账款重组
  • 鸿蒙系统怎么开启开发者权限
  • 华为正式发布鸿蒙官网
  • 对增值税发票开具方面有何要求?
  • 小规模减免的增值税怎么记账
  • 如何修改自己电脑物理地址
  • php函数返回值类型
  • 未知格式或损坏文件怎么办
  • 展会费用计入什么科目
  • 暂估入库结转成本后期怎么冲账
  • 收到商品的会计分录怎么写
  • ges.dll
  • 银行公户转账需要带什么
  • 2022年增值税免税政策
  • 电影剧本如何代替
  • 怎么做外资企业赚钱
  • phpmyadmin无法登陆mysql数据库
  • php oracle 连接池
  • 收到房租怎么做账务处理
  • 应收账款抵借的例题
  • 外管证预缴税款怎么做分录
  • 企业开具劳务费发票怎么开,税率多少
  • 利润表中利息费用为负数是什么意思
  • java一天速成
  • 哪些福利不需要交个税
  • 什么叫网银盾账户
  • 银行对账单由谁负责
  • 预付账款可以抵扣增值税么
  • sqlserver服务请求失败或服务未及时响应
  • 机械租赁属于什么科目
  • 企业有哪些固定资产
  • 小规模纳税人减按1%如何填报申报表
  • 公司从异地迁移到本地怎么向当地政府写申请
  • 消费税的应纳税额的计算
  • 现金折扣要扣除什么费用
  • 公司租赁办公场所,没发票怎么办
  • 偷税漏税追溯年限怎么算
  • 如何避免电子发票重复报销的情况
  • 非营利医疗机构由谁批准
  • 一个分页存储过多的文件
  • windows禁止安装
  • win10 下一代
  • xp系统怎样打开隐藏文件
  • windows vista ie9
  • ubuntu 14.04安装
  • win10无法收到wifi
  • win7文件和打印机共享
  • win7开机自动弹出注册表编辑器怎么办
  • 网页字体大小调整方案
  • javascript的面向对象
  • node写自动化脚本
  • javascript中函数
  • javascript高级程序设计最新版
  • 什么是质数
  • jquery添加属性的方法
  • 辽宁省电子税务局电话
  • 核定征收一般纳税人
  • 税务绩效工作存在的问题
  • 明星征税多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设