登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
业界区
›
业界
›
一次小而美的重构:使用 C# 在 Avalonia 中生成真正好看 ...
一次小而美的重构:使用 C# 在 Avalonia 中生成真正好看的词云
[ 复制链接 ]
威割
2025-6-2 22:10:19
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
前言
我之前不是用 Avalonia 开发了
StarBlogPublisher
(一款为 StarBlog 设计的 Markdown 文章发布工具)吗?
当时里面有个分类
词云(Word Cloud)
展示功能。
初版的词云虽然 "能用",但效果极其粗糙——基本只是简单堆叠文字,完全没有体现出词云那种灵动、密集、错落有致的美感。
于是,我决定
彻底重构
这一模块,重新寻找合适的词云生成方案。
选型
在 Avalonia 生态中是没有直接可用的词云组件的。
不过没事,C# 的生态还算丰富,基本要啥有啥,词云自然不在话下。
在调研阶段,我找到了两个比较流行的 C# 词云库:
Sdcb.WordCloud
KnowledgePicker/WordCloud
简单对比一下:
特性Sdcb.WordCloudKnowledgePicker.WordCloud渲染引擎SkiaSharp(跨平台)SkiaSharp(跨平台)输出格式图片(PNG)、SVG、JSON图片(Bitmap)、SVG(需要自绘)自定义程度高(遮罩、字体、多方向、JSON输出等)中(字体、颜色、布局可定制,但不支持遮罩)遮罩功能✅ 原生支持遮罩图生成特定形状词云❌ 暂不支持遮罩,生成规则矩形词云最近维护状态活跃(2024年持续更新)活跃(2024年有提交)使用复杂度中(配置多、自由度高)中(较简洁,适合快速集成)
共同点
两者都使用 SkiaSharp,意味着可以在
Windows、Linux、macOS
等多平台运行。
都支持灵活配置字体、布局、颜色,并且速度非常快。
主要区别
Sdcb.WordCloud
更注重视觉效果(支持复杂遮罩图案),适合追求自定义形状、炫酷效果的场景。
KnowledgePicker.WordCloud
更注重性能和简洁性,适合标准矩形词云生成,不追求复杂形状。
最终,我选择了功能更强大、兼容性更好的
Sdcb.WordCloud
。
Sdcb.WordCloud简介
Sdcb.WordCloud
是一个基于 SkiaSharp 的跨平台词云生成库,具备以下特点:
跨平台兼容
:Windows、Linux、macOS 均可使用。
多种输出
:支持生成图片、SVG文件或JSON数据。
高度可定制
:自定义字体、颜色、遮罩图案、文本排列方式等。
无依赖System.Drawing
:在服务器环境也能轻松部署。
开源友好
:MIT License,开发者自由扩展。
安装
dotnet add package Sdcb.WordCloud
复制代码
实战:在 StarBlogPublisher 中应用
重构后的词云生成逻辑主要分为两步:
获取词频数据
首先,从后端API请求分类词频数据,并进行简单扩充(让词云密度更高)。
private async Task<List<WordScore>?> GetWordScores() {
var response = await ApiService.Instance.Categories.GetWordCloud();
if (response.Data == null) throw new Exception("获取词云数据失败");
var originalScores = response.Data
.Select(e => new WordScore(Score: e.Value, Word: e.Name))
.ToList();
var extendedScores = new List<WordScore>();
foreach (var score in originalScores) {
for (int i = 0; i < 10; i++) {
extendedScores.Add(score);
}
}
return extendedScores;
}
复制代码
这里小技巧:
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
一次
小而
美的
重构
使用
相关帖子
nordic nrf5340使用笔记
PaddlePaddle RapidOcr 使用一则
一步一步学习使用FireMonkey动画(4) 使用Delphi的基本动画组件类
OpenCVSharp:使用CaffeModel
Nuxt.js v4中使用quill富文本组件
Obsidian的Bases数据库入门教程,使用数据库实现Todo待办管理系统
使用typora来写md文件时配置文件存放图片的路径
从 Spring Boot 2.x 到 3.5.x + JDK21:一次完整的生产环境迁移实战
如何使用 vxe-gantt table 甘特图来实现多个维度视图展示
js框架使用
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
安全
nordic nrf5340使用笔记
0
905
表弊捞
2025-12-02
安全
PaddlePaddle RapidOcr 使用一则
0
586
粉押淫
2025-12-02
业界
一步一步学习使用FireMonkey动画(4) 使用Delphi的基本动画组件类
1
768
崔瑜然
2025-12-03
业界
OpenCVSharp:使用CaffeModel
0
213
渭茱瀑
2025-12-03
业界
Nuxt.js v4中使用quill富文本组件
1
299
汲佩杉
2025-12-04
业界
Obsidian的Bases数据库入门教程,使用数据库实现Todo待办管理系统
0
387
焦尔蕾
2025-12-06
业界
使用typora来写md文件时配置文件存放图片的路径
0
711
董绣梓
2025-12-06
业界
从 Spring Boot 2.x 到 3.5.x + JDK21:一次完整的生产环境迁移实战
0
836
人弧
2025-12-06
代码
如何使用 vxe-gantt table 甘特图来实现多个维度视图展示
0
449
馏栩梓
2025-12-07
代码
js框架使用
0
11
新程序
2025-12-07
回复
(4)
阜逐忍
2025-11-26 17:42:21
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
新版吗?好像是停更了吧。
康器
昨天 00:53
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
谢谢分享,试用一下
佟棠华
昨天 10:36
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
谢谢分享,试用一下
洪势
4 小时前
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
新版吗?好像是停更了吧。
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
代码
签约作者
程序园优秀签约作者
发帖
威割
4 小时前
关注
0
粉丝关注
14
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
anyue1937
9994893
kk14977
6845355
3934307807
991122
4
xiangqian
638210
5
宋子
9987
6
闰咄阅
9991
7
刎唇
9993
8
俞瑛瑶
9998
9
蓬森莉
9952
10
匝抽
9986
查看更多