将 SVG 转换为具有锐边的 PNG

Convert SVG to PNG with sharp edges

我需要转换图像以进行对象检测。我从具有多个多边形的 svg 图像开始。示例:

<svg ...>
<rect width = "100%" height = "100%" fill = "rgb(0,0,0)" />
<polygon points="..." fill="rgb(221,221,221)" fill-opacity="1.0" />
<polygon points="..." fill="rgb(100,100,100)" fill-opacity="0.5" />
</svg>

结果是黑色背景,对象 A 的颜色为 rgb(221,221,221),对象 B 的颜色为 rgb(50,50,50),并且两个对象在任何地方重叠 rgb(160,160,160)。检测算法(无法修改)根据像素值确定对象。

我已经使用 inkscape、svgr-convert 或 ImageMagikk 成功地将 svg 转换为 png。然而,这些 png 图像的边缘总是模糊的,这会干扰我的对象检测。

有什么方法可以转换成清晰的边缘吗? This image shows the conversion adding blurred pixels with incorrect values. I have zoomed into an edge to make it obvious.

编辑:完整图像示例

<svg viewBox="17.874 6.66874 74.0131 70.817" xmlns="http://www.w3.org/2000/svg">
<rect width = "100%" height = "100%" fill="black" fill-opacity="1.000000" stroke="black" stroke-opacity="1.000000" stroke-width ="0.000000"/>
<polygon points="66.499391,34.862972 35.730400,51.495089 68.667463,64.499553 " fill="rgb(221,221,221)" fill-opacity="1.000000" />
<polygon points="47.613765,49.254424 23.219703,52.458598 47.246912,50.965952 48.078815,51.599703 49.620943,52.471096 62.516253,65.471290 65.077318,43.877861 51.086443,12.014429 34.861708,20.532821 " fill="rgb(100,100,100)" fill-opacity="0.500000" />
</svg>

您需要做的是在读取 SVG 文件时增加密度。您可以按某个系数增加密度并保存该结果,或者可以按系数增加密度,然后按相反的系数调整大小。 SVG 的默认密度为 96 dpi。所以在 Imagemagick 6 中,基本命令是:

convert test.svg test.png


相同
convert -density 96 test.svg test1.png


现在你可以将密度增加 4 到 384。

convert -density 384 test.svg test2.png


或者对于需要以原始分辨率保留的带有线条图的较大图像,您可以将尺寸缩小 1/4 或 25%

convert -density 384 test.svg -resize 25% test3.png


对于 Imagemagick 7,将 convert 更改为 magick。

添加:

这里是使用密度1200放大的版本,除非你放大超过全分辨率,否则看起来会很平滑。

convert -density 1200 test.svg test4.png


<svg>元素中添加属性(被所有子元素继承)

shape-rendering="crispEdges"

虽然从我的简短测试来看,Inkscape 似乎不支持这一点,但 rsvg-convert 支持。对于您的 Imagemagick 设置,您应该确保它委托给 librsvg,而不是 Inkscape。