news 2026/4/23 11:50:51

Highcharts词云图表开发文档

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Highcharts词云图表开发文档

词云图

词云是一种可视化一组单词的方式,其中单词的大小和位置由其权重决定。

点击 这里 here 查看代码

需求

词云图表需要以下模块:modules/wordcloud.js.

选项

点击 这里 here 查看所有可用的词云系列选项的概述。

数据结构

每个词云系列中的点都必须包含一个 name 和一个 weight。 名称决定了在可视化中显示的文本内容,而权重 决定了其优先级。优先级最高的点会先被绘制, 并且字体会更大。

data:[{name:'Lorem',weight:3},{name:'Ipsum',weight:2},{name:'Dolor',weight:1}]

高级用法

自定义螺旋算法

螺旋用于在单词与其他单词碰撞或边界发生碰撞后,将单词移动到初始位置之外。 若要实现自定义螺旋,可以参考 archimedeanSpiral 函数,例如:

/** * archimedeanSpiral - Gives a set of coordinates for an Archimedian Spiral. * * @param {number} t How far along the spiral we have traversed. * @return {object} Resulting coordinates, x and y. */vararchimedeanSpiral=functionarchimedeanSpiral(t){t*=0.1;return{x:t*Math.cos(t),y:t*Math.sin(t)};};

螺旋算法通过将其附加到 spirals 属性上实现了访问:

Highcharts.seriesTypes.wordcloud.prototype.spirals.archimedean=archimedeanSpiral;

之后,你可以通过指定选项series<wordcloud>.spiral来使用该算法:

Highcharts.chart(...,{series:[{type:'wordcloud',spiral:'archimedean'}]});

自定义布局策略

策略用于决定单词的旋转角度和初始位置。 若要实现自定义策略,可以参考 randomPlacement 函数,例如:

varrandomPlacement=functionrandomPlacement(point,options){varfield=options.field,r=options.rotation;return{x:getRandomPosition(field.width)-(field.width/2),y:getRandomPosition(field.height)-(field.height/2),rotation:getRotation(r.orientations,r.from,r.to)};};

放置算法通过将其附加到placementStrategy属性上实现了访问:property:

Highcharts.seriesTypes.wordcloud.prototype.placementStrategy.random=randomPlacement;

之后你可以通过指定选项series<wordcloud>.placementStrategy来使用该算法:

Highcharts.chart(...,{series:[{type:'wordcloud',placementStrategy:'random'}]});

自定义字体大小

字体的大小由函数deriveFont计算得出,该函数根据单词的相对权重来确定结果。权重的范围是0到1,表示该单词相对于最大权重单词的大小。当自定义字体大小时,应注意,较大的字体可能会导致布局算法运行变慢,而较小的字体则可能使单词的排布更加分散。

// Include this snippet after loading Highcharts and before Highcharts.chart is executed.Highcharts.seriesTypes.wordcloud.prototype.deriveFontSize=function(relativeWeight){varmaxFontSize=25;// Will return a fontSize between 0px and 25px.returnMath.floor(maxFontSize*relativeWeight);};

需要注意的事项

  • 当单词以非90度倍数的角度旋转时,它们之间会有很多空隙。
    • 当前的碰撞算法没有考虑旋转,只会检查两个单词的外部区域是否碰撞。为了解决这个问题,我们可以利用 分离轴定理 Separating Axis Theorem
  • 当我导出我的图表时,单词的位置发生了变化。
    • 出时会重新渲染数据,这会导致单词在不同的坐标位置,而不是原始图表中的位置。
  • 出时会重新渲染数据,这会导致单词在不同的坐标位置,而不是原始图表中的位置。
    • 当前我们在词云系列中使用的默认字体没有安装在导出服务器上。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/7 11:22:40

全网最全!10个论文降aigc神器,支持免费降ai率【建议收藏】

其实呢&#xff0c;作为刚毕业的学生&#xff0c;平时没少用AI辅助。话说回来&#xff0c;AI写的东西总被导师说“味道太浓”。举个例子&#xff0c;我第一次交稿&#xff0c;直接被批AI痕迹重。 后来&#xff0c;我试了好多降AI率工具&#xff0c;就想把降低AI率搞明白。 今…

作者头像 李华
网站建设 2026/4/23 11:50:05

基于java + vue药店管理系统(源码+数据库+文档)

药店管理 目录 基于springboot vue网上订餐系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue药店管理系统 一、前言 博主介绍&#xff1a;✌️大…

作者头像 李华
网站建设 2026/4/18 6:37:50

细胞力学仿真软件:CellPACK_(14).案例分析与实践

案例分析与实践 在这一部分&#xff0c;我们将通过具体的案例分析和实践操作&#xff0c;深入探讨如何利用细胞力学仿真软件进行二次开发。通过这些案例&#xff0c;您将能够更好地理解软件的功能和应用场景&#xff0c;并掌握如何根据具体需求进行定制化的开发。 案例1&…

作者头像 李华
网站建设 2026/4/21 7:19:09

Unity DOTS核心概念之 Entity(实体)

目录 前言 一、Entity 的核心定义与本质特性 1.1 Entity 的官方定义 1.2 Entity 与 GameObject 的核心区别 1.3 Entity 的关键特性 二、Entity 的核心管理工具:EntityManager 2.1 EntityManager 的核心作用 2.2 EntityManager 操作 Entity 的常用 API 2.3 EntityMana…

作者头像 李华
网站建设 2026/4/20 11:15:24

9款实测AI降AIGC率工具,毕业生必备收藏

毕业季一到&#xff0c;不少学生都愁眉苦脸地问&#xff1a;"唉&#xff0c;论文被检出AI生成内容超标了&#xff0c;咋办啊&#xff1f;" 学术写作中&#xff0c;论文降重与降低AI生成痕迹&#xff08;AIGC率&#xff09;是确保学术诚信的关键环节。传统方法包括人…

作者头像 李华