要实现位图转矢量图,可不是一个简单的活;当然我们这里也不追求完美实现,在前文的基础上,可以想到一个实现策略
-
首先根据位图输出字符画
-
然后通过字符画,来生成矢量图
基于上面这个策略,第一步生成字符前一篇博文已经介绍过了;接下来重点就是如何根据输出的字符数组,来生成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}”>
复制代码
对于上面的模板中,有几个关键值需要替换
-
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();
}
复制代码

2402

被折叠的 条评论
为什么被折叠?



