首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将SVG文件转换为多个不同大小的PNG文件

将SVG文件转换为多个不同大小的PNG文件
EN

Stack Overflow用户
提问于 2011-09-16 17:29:54
回答 9查看 18.8K关注 0票数 29

我有一个SVG格式的标志图像,我想知道是否有一种方法来生成多个不同大小的png文件。

例如,我设置了20种不同的宽度和高度,它生成了20个PNG文件。如果我一次要做5张图片,那也没问题。

我已经安装了illustrator,但想不出该怎么做。

谢谢你的帮助!

EN

回答 9

Stack Overflow用户

回答已采纳

发布于 2011-09-17 04:21:09

我不知道如何插图,但这应该很容易使用Inkscape command line options。例如,使用Ruby:

代码语言:javascript
运行
复制
$ ruby -e '[10,100,200].each { |x| `inkscape --export-png logo#{x}.png -w #{x} logo.svg` }'
票数 15
EN

Stack Overflow用户

发布于 2013-04-15 21:25:23

公认的答案是好的。有可用的official help on options。同样,基本的Shell命令在这里也能做得很好:

代码语言:javascript
运行
复制
for x in 10 100 200 ; do inkscape --export-png logo${x}.png -w ${x} logo.svg ; done

在windows的命令行上,在注释中使用@avalancha中的这一行

代码语言:javascript
运行
复制
for %x in (100 200 300) ; do inkscape --export-png logo%x.png -w %x logo.svg ; done
票数 41
EN

Stack Overflow用户

发布于 2014-03-11 09:34:17

以下是如何通过只启动一次Inkscape来使其速度更快(对于我来说,在SSD上只需5次导出),以及如何将图像导出到不同的目录(就像Android使用的那样):

代码语言:javascript
运行
复制
#!/bin/sh
# Converts the Inkscape icon file ic_launcher_web.svg to the launcher web & app png files.

PROJECT="My Project Name"
INPUT="source-assets/ic_launcher_web.svg"
MAIN="${PROJECT}/src/main/"
RES="${MAIN}res/"
DRAWABLE="${RES}/drawable"

inkscape --shell <<COMMANDS
  --export-png "${MAIN}ic_launcher-web.png"         -w 512 "${INPUT}"
  --export-png "${DRAWABLE}-mdpi/ic_launcher.png"   -w  48 "${INPUT}"
  --export-png "${DRAWABLE}-hdpi/ic_launcher.png"   -w  72 "${INPUT}"
  --export-png "${DRAWABLE}-xhdpi/ic_launcher.png"  -w  96 "${INPUT}"
  --export-png "${DRAWABLE}-xxhdpi/ic_launcher.png" -w 144 "${INPUT}"
quit
COMMANDS

这是一个bash shell脚本。在Windows上,你可以在MINGW32中运行它(例如GitHub的Git Shell),或者将其转换为Windows DOS shell脚本。(对于DOS脚本,您必须将"here document“命令更改为DOS可以处理的命令。有关将多行文本回显到临时文件等技术,请参阅heredoc for Windows batch?。)

票数 14
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7442665

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档