vue实现词云图

1、echarts实现
安装
注意版本

echarts-wordcloud@2 is for echarts@5 echarts-wordcloud@1 is for echarts@4npm install echarts@5npm install echarts-wordcloud@2

代码部分

<template><div class="cloud-wrap"><divref="cloudEl"class="cloud-box":id="title"style="height: 200px; width: 200px"></div></div>
</template><script>
import echarts from "echarts";
require('echarts-wordcloud')
// import wordcloud from "echarts-wordcloud";
export default {props: {title: "",//传过来的idchartData: {},//数据},data() {return {bgImg:"",};},watch: {},mounted() {this.drawCloud(this.title);},methods: {drawCloud(id) {var  myChart = echarts.init(document.getElementById(id));var maskImage = new Image(); //可以根据图片形状生成有形状的词云图maskImage.src = this.bgImg;let arr = this.chartData[this.title];let list = [];arr.map((item) => {let obj = {};obj.name = item.content_info;obj.value = item.frequency;obj.label = item.label_info;list.push(obj);});list.sort(function (a, b) {// return a - b; // 升序的顺序排列return a.value - b.value; // 降序的顺序排列});let colorList = ["#999999", "#666666", "#333333", "#FF060B"];let length = list.length;//按出现频率上色list.map((item, index) => {if (item.label == "不好") {item.color = 3;} else {if (index < length / 3 || index == length / 3) {item.color = 0;} else if (index < (length * 2) / 3 || index == (length * 2) / 3) {item.color = 1;} else {item.color = 2;}}});let option = {title: {text: this.title, //这里的参数是整个图标的标题 后面也可以加注释//   subtext: '888'left: "10%",textStyle: {fontSize: 12,},},tooltip: {show: true,confine:true,//限定在图表范围内},// backgroundColor:'#333944', // 画布背景色series: [{name: "评价",type: "wordCloud",// maskImage: maskImage, // 图片形状//maskImage的横纵比为1:1keepAspect: false,sizeRange: [8, 18], //词云的文字字号范围,默认是[12, 60]。rotationRange: [0, 0], //数据翻转范围shape: "star",width: "180px", //词云的宽高,默认是 75%、80%。height: "100%",// drawOutOfBound: true, // 超出画布的词汇是否隐藏drawOutOfBound: false,color: "#fff",left: "center",top: "center",right: null,bottom: null,// width: "100%",// height: "100%",gridSize: 2, //每个词之间的间距。// textPadding: 10,autoSize: {enable: true,minSize: 6,},textStyle: {normal: {fontFamily: "sans-serif",fontWeight: "bold",color: "#333", // 字体颜色color: function (params) {// 字体颜色return colorList[params.data.color];// return 'rgb(' + [//     Math.round(Math.random() * 160),//     Math.round(Math.random() * 160),//     Math.round(Math.random() * 160)// ].join(',') + ')';},},emphasis: {// focus: 'self',textStyle: {shadowBlur: 10,shadowColor: "#333",},},},data: list,},],};myChart.setOption(option,true);},},
};
</script><style>
.cloud-wrap {width: 100%;height: 100%;background-position: center;background-image: url("../../../../public/img/star.png");background-repeat: no-repeat; background-size:50%,/* background-image:'require(@/public/img/star .png)' ; */
}
.cloud-box {width: 100%;height: 100%;text-align: center;
}
</style>

Highcharts

安装
代码部分

<template><div><divref="cloudEl"class="cloud-box":id="title"style="height: 200px; width: 200px"></div></div>
</template><script>
import Highcharts from "highcharts/highcharts";
import wordcloud from "highcharts/modules/wordcloud";wordcloud(Highcharts);
export default {props: {title: "",chartData: {},},data() {return { };},watch: {},mounted() {this.drawCloud(this.title);},methods: {drawCloud(id) {let arr = this.chartData[this.title];let list=[]arr.map((item) => {let obj = {};obj.name = item.content_info;obj.weight = item.frequency;obj.label = item.label_info;list.push(obj);});list.sort(function (a, b) {// return a - b; // 升序的顺序排列return a.weight - b.weight; // 降序的顺序排列});let colorList = ["#999999", "#666666", "#333333", "#FF060B"];let length = list.length;list.map((item, index) => {if (item.label == "1") {item.color = colorList[3];} else {if (index < length / 3 || index == length / 3) {item.color = colorList[0];} else if (index < (length * 2) / 3 || index == (length * 2) / 3) {item.color = colorList[1];} else {item.color = colorList[2];}}});Highcharts.chart(id, {credits: { enabled: false },//导出exporting: { enabled: false },//提示关闭tooltip: { enabled: true },title: {text: this.title,floating: true,x: -50,style: {fontSize: 12,fontWeight: "600",},},//图形配置chart: {// spacingBottom: 15,spacingTop: 12,spacingLeft: 5,spacingRight: 5,backgroundColor: "rgba(255, 255, 255,0)",},series: [{type: "wordcloud", // 类型data: list,name: this.title,rotation: 90, //字体不旋转maxFontSize: 15,minFontSize: 8,},],});},},
};
</script>

vue实现词云图(echarts/Highcharts)相关推荐

  1. 词云图制作(wordcloud pyecharts)

    现在,网上很多可视化的方法,有一种就是词云图. 词云图,也叫文字云,是对文本中出现频率较高的"关键词"予以视觉化的展现,词云图过滤掉大量的低频低质的文本信息,方便领略文本的主旨. ...

  2. echarts 词云图使用 + vue

    介绍 根据自己定义Echarts词云图背景图,词云图可方便的对词组进行可视化的显示. 效果图 一 安装 npm install echarts-wordcloud 注意Echarts5.0的版本要对应 ...

  3. vue echarts常用配置: label 换行、词云图、数据差距过大

    一.使用柱状图时,因为数据差距过大,导致图表不好看 修改: a. 将y轴改为对数轴, b. 数组中值不能为0,需要将值修改为undefined, c. tooltip中将数值为undefined重置为 ...

  4. Echarts词云图

    水果店词云图 <!DOCTYPE html> <html> <head><meta charset="utf-8"><titl ...

  5. echarts的词云图

    echatrs词云图绘制成世界地图的形状 这是我选择的形状图片 1.检查 echarts-wordcloud版本号 首先,安装echarts和echarts-wordcloud 官网看到的说:echa ...

  6. vue前端生成词云图的方法

    我试过很多方法,自定义词云图.echarts-wordcloud.highcharts都是各种各样报错,基本是是找不到wordcloud模块,引入了也会报错,最终发现js2wordcloud可以用 i ...

  7. echarts绘制各种图表(柱形、折线、柱形、饼图、南丁格尔、环形、中国地图散点图、百度地图散点图、词云图)

    文末附带github本文所有源代码,以及bmap.js,china.js,echarts.js,echarts-wordcloud.js文件啦 1.柱形图 先来看看效果啦 重要代码如下所示,必须引入e ...

  8. ECharts:echarts-wordcloud词云图

    echarts-wordcloud词云库是基于wordcloud2.js的Apache ECharts版本实现. 词云库的引入 echarts-wordcloud词云库需要配合ECharts一起使用, ...

  9. echarts词云图形状_使用pyecharts绘制词云图-淘宝商品评论展示

    一.什么是词云图? 词云图是一种用来展现高频关键词的可视化表达,通过文字.色彩.图形的搭配,产生有冲击力地视觉效果,而且能够传达有价值的信息. 制作词云图的网站有很多,简单方便,适合小批量操作. BI ...

最新文章

  1. 有序的两个数组在满足其中一个数组的所有数都小于另外一个数组的情况下的整体的中位数
  2. 1.6 多项式回归-机器学习笔记-斯坦福吴恩达教授
  3. 数据中心水环热泵余热回收系统分析与应用
  4. 【Linux】一步一步学Linux——Linux系统常用快捷键(12) 待更新...
  5. mac VMware Fusion 虚拟机键盘可以使用,鼠标无法使用排查思路及解决方法
  6. thymeleaf 学习笔记-基础篇(中文教程)
  7. tp703n怎么做无线打印服务器,TP-Link TL-WR703N无线路由器无线AP模式怎么设置
  8. 用asp.net+Jquery+Ajax+sqlserver编写的 (英语六级记单词)
  9. 【Windows 命令行】CMD 在资源管理器中打开当前路径
  10. textfield获取其中内容_41页内容介绍电气安装工程,详细介绍施工图纸,值得收藏...
  11. MySQL 阿里巴巴JAVA开发手册-MySQL相关
  12. HiJson工具 火狐浏览器中的jsonHandle插件(以及乱码问题的解决)--来转换json串的格式
  13. imei服务器清除id_苹果绕过ID解锁
  14. html页面广告5秒之后跳过
  15. linux培训哪家好?Linux520内部培训教程
  16. 用c语言编写程序出现undecla,济南大学C程序设计基础实验指导书
  17. eclipse 工作空间的高效使用
  18. 单页面SPA和多页面MPA应用的区别
  19. 自控力极差的人如何自救-转载自知乎高赞回答
  20. 本地文件上传到github上

热门文章

  1. ROCKET PROPULSION ELEMENTS——DEFINITIONS AND FUNDAMENTALS笔记
  2. 视频画中画效果该怎么实现?这款软件让你一秒成大神
  3. android中级开发师必备_【招聘】Android开发工程师 – 中级 – 陌陌
  4. flex 实现水平布局 三等分
  5. Qt读取/写入Excel数据--QAxObject
  6. Carbon 语言【中文入门教程】
  7. 杭州考驾照-2017.4
  8. 计算机课程学习心得ppt,计算机课程学习心得体会.docx
  9. 解决 cv_bridge 与 opencv4 版本冲突问题
  10. 智能存储 | 视频增强“全家桶”,为您的视频快速“换脸”