如何用Java实现位图转矢量图?

要实现位图转矢量图,可不是一个简单的活;当然我们这里也不追求完美实现,在前文的基础上,可以想到一个实现策略

  • 首先根据位图输出字符画

  • 然后通过字符画,来生成矢量图

基于上面这个策略,第一步生成字符前一篇博文已经介绍过了;接下来重点就是如何根据输出的字符数组,来生成svg呢?

2. 实现方法

第一步位图输出字符画的代码就不贴了,有兴趣的小伙伴可以参考前文

接下来我们重点看一下如何根据生成的List<String>来生成svg图

首先我们定义一个svg模板,用于来表示基于字符输出的矢量图,如下

<?xml version="1.0" encoding="UTF-8" ?>

<svg xmlns=“http://www.w3.org/2000/svg”

viewBox=“0 0 {width} {height}”

style=“width: 100%; height: 100%; overflow: auto; fill: {BG_COLOR}”>

ux

复制代码

对于上面的模板中,有几个关键值需要替换

  • svg 标签中

  • {width}: 生成矢量图的宽度

  • {height}: 生成矢量图的高度

  • {BG_COLOR}: 背景颜色

  • style 样式设置

  • {FONT_COLOR}: 字符渲染颜色

其次tspan标签内容就是我们需要输出的字符,一行字符对应一个tspan标签

因此我们的实现逻辑就是上面这个模板的关键字替换输出了

/**

  • 字符转svg矢量图

  • @param lines

  • @param bgColor

  • @param fontColor

  • @return

*/

public static String ascii2svg(List lines, String bgColor, String fontColor) {

StringBuilder builder = new StringBuilder();

int height = lines.size();

int width = lines.stream().max(Comparator.comparingInt(String::length)).get().length();

builder.append(StrUtil.replace(SVG_START, “{width}”, String.valueOf(width), “{height}”, String.valueOf(height), “{BG_COLOR}”, bgColor, “{FONT_COLOR}”, fontColor));

// 计算tspan标签中的dy值

float dy = 100.0f / height;

String start = String.format(“<tspan x=“0” dy=”%.3f%%" textLength=“100%%” xml:space=“preserve”>", dy);

String end = “”;

for (String line : lines) {

builder.append(start)

// 转义支持

.append(StrUtil.replace(line,“&”, “&”, “”“, “””, “<”, “<”, “>”, “>”))

.append(end).append(“\n”);

}

builder.append(SVG_END);

return builder.toString();

}

复制代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值