rsvg-convert renders SVG documents into PNG raster images, or converts them to PDF or PS as vector
objects. By default rsvg-convert will render an SVG document to a raster PNG image and write it to
standard output:
rsvg-convertinput.svg>output.png
To select another format, use the --format option:
rsvg-convert--format=pdfinput.svg>output.pdf
You can use rsvg-convert as part of a pipeline; without an argument for the input filename it will read
the document from standard input:
catinput.svg|rsvg-convert>output.pngSPECIFYINGTHERENDEREDSIZE
You can use the --width and --height options to specify the size of the output image. Most of the time
you should specify --keep-aspect-ratio to scale the image proportionally; for compatibility with old
versions this is not the default.
rsvg-convert--width=100--height=200--keep-aspect-ratioinput.svg>output.png
You can also specify dimensions as CSS lengths, for example 10px or 8.5in. The unit specifiers supported
are as follows:
┌────┬───────────────────────────────────────┐
│ px │ pixels (the unit specifier can be │
│ │ omitted) │
├────┼───────────────────────────────────────┤
│ in │ inches │
├────┼───────────────────────────────────────┤
│ cm │ centimeters │
├────┼───────────────────────────────────────┤
│ mm │ millimeters │
├────┼───────────────────────────────────────┤
│ pt │ points, 1/72 inch │
├────┼───────────────────────────────────────┤
│ pc │ picas, 1/6 inch │
└────┴───────────────────────────────────────┘
The following will create a 600*900 pixel PNG, or 2*3 inches at 300 dots-per-inch:
rsvg-convert--width=2in--height=3in--keep-aspect-ratio--dpi-x=300--dpi-y=300input.svg>output.png
This will scale an SVG document to fit in an A4 page and convert it to PDF:
rsvg-convert--format=pdf--width=210mm--height=297mm--keep-aspect-ratioinput.svg>output.pdfSPECIFYINGAPAGESIZE
By default the size of the output comes from the rendered size, which can be specified with the --width
and --height options, but you can specify a page size independently of the rendered size with
--page-width and --page-height, together with --top and --left to control the position of the rendered
image within the page. In short:
• --page-width and --page-height together - set the page size.
• --top and --left - set the margins.
• --width and --height - set the rendered size.
This will create a PDF with a landscape A4 page, by scaling an SVG document to 10*10 cm, and placing it
with its top-left corner 5 cm away from the top and 8 cm from the left of the page:
rsvg-convert--format=pdf--page-width=297mm--page-height=210mm--width=10cm--height=10cm--keep-aspect-ratio--top=5cm--left=8cminput.svg>output.pdfSPECIFYINGASCALEFACTORINSTEADOFARENDEREDSIZE
The --zoom option lets you scale the natural size of an SVG document. For example, if input.svg is a
document with a declared size of 100*200 pixels, then the following command will render it at 250*500
pixels (zoom 2.5):
rsvg-convert--zoom=2.5input.svg>output.png
You can limit the maximum scaled size by specifying the --width and --height options together with
--zoom. Here, the image will be scaled 10x, but limited to 1000*1000 pixels at the most:
rsvg-convert--zoom=10--width=1000--height=1000input.svg>output.png
If you need different scale factors for the horizontal and vertical dimensions, use the --x-zoom and
--y-zoom options instead of --zoom.
CREATINGAMULTI-PAGEDOCUMENT
The "pdf", "ps", and "eps" output formats support multiple pages. These can be created by combining
multiple input SVG files. For example, this PDF file will have three pages:
rsvg-convert--format=pdfpage1.svgpage2.svgpage3.svg>out.pdf
The size of each page will be computed, separately, as described in the DEFAULTOUTPUTSIZE section. This
may result in a PDF being produced with differently-sized pages. If you need to produce a PDF with all
pages set to exactly the same size, use the --page-width and --page-height options.
For example, the following command creates a three-page PDF out of three SVG documents. All the pages are
portrait US Letter, and each SVG is scaled to fit so that there is a 1in margin around each page (hence
the width of 6.5in and height of 9in for the rendered size).
rsvg-convert--format=pdf--page-width=8.5in--page-height=11in--width=6.5in--height=9in--keep-aspect-ratio--top=1in--left=1inpg1.svgpg2.svgpg3.svg>out.pdfCONVERSIONOFPIXELSBASEDONTHEDOTS-PER-INCHrsvg-convert uses the --dpi-x and --dpi-y options to configure the dots-per-inch (DPI) by which pixels
will be converted to/from physical units like inches or centimeters. The default for both options is 96
DPI.
Consider this example SVG, which is nominally declared to be 2*3 inches in size:
<svg xmlns="http://www.w3.org/2000/svg" width="2in" height="3in">
<!-- graphical objects here -->
</svg>
The following commands create PNGs of different sizes for the example SVG above:
rsvg-converttwo-by-three.svg>output.png #### creates a 192*288 pixel PNG
rsvg-convert--dpi-x=300--dpi-y=300two-by-three.svg>output.png #### creates a 600*900 pixel PNG
Note that the final pixel dimensions are rounded up to the nearest pixel, to avoid clipping off the
right/bottom edges. In the following example, rsvg-convert will generate a PNG 300x300 pixels in size:
rsvg-convert--width=299.5--height=299.4input.svg>output.png #### outputs 300x300 pixel PNG with a
fractionally-scaled image
If you specify dimensions in physical units, they will be multiplied by the dots-per-inch (DPI) value to
obtain dimensions in pixels. For example, this will generate a 96x96 pixel PNG, since it is 1x1 inch at
the default 96 DPI:
rsvg-convert--width=1in--height=1ininput.svg>output.png #### outputs 96x96 pixel PNG
Correspondingly, this will generate a 300x300 pixel PNG, since it is 1x1 inch at 300 DPI:
rsvg-convert--width=1in--height=1in--dpi-x=300--dpi-y=300input.svg>output.png #### outputs
300x300 pixel PNG
DEFAULTOUTPUTSIZE
If you do not specify --width or --height options for the output size, rsvg-convert will figure out a
"natural size" for the SVG as follows:
• SVGwithwidthandheightinpixelunits(px):<svgwidth="96px"height="192px"> For PNG output, those
same dimensions in pixels are used. For PDF/PS/EPS, that pixel size is converted to physical units
based on the DPI value (see the --dpi-x and --dpi-y options),
• SVGwithwidthandheightinphysicalunits:<svgwidth="1in"height="2in"> For PNG output, the width
and height attributes get converted to pixels, based on the DPI value (see the --dpi-x and --dpi-y
options). For PDF/PS/EPS output, the width/height in physical units define the size of the PDF unless
you specify options for the page size; see SPECIFYINGAPAGESIZE above.
• SVGwithviewBoxonly:<svgviewBox="002030"> The size of the viewBox attribute gets used for the
pixel size of the image as in the first case above.
• SVGwithwidthandheightinpercentages:<svgwidth="100%"height="100%"viewBox="002030">
Percentages are meaningless unless you specify a viewport size with the --width and --height options.
In their absence, rsvg-convert will just use the size of the viewBox for the pixel size, as described
above.
• SVGwithnowidth,height,orviewBox:rsvg-convert will measure the extents of all graphical objects
in the SVG document and render them at 1:1 scale (1 pixel for each CSS px unit). It is strongly
recommended that you give SVG documents an explicit size with the width, height, or viewBox attributes.
BACKGROUNDCOLOR
You can use the --background-color option (-b for short) to specify the background color that will appear
in parts of the image that would otherwise be transparent. This option accepts the same syntax as the CSS
color property, so you can use #rrggbb syntax, or CSS named colors like white, or rgba().
rsvg-convert--background-color=whiteinput.svg>output.png #### opaque white
rsvg-convert-b'#ff000080'input.svg>output.png #### translucent red - use shell quotes so the # is
not interpreted as a comment
SELECTINGALANGUAGEFORMULTI-LANGUAGESVG
An SVG document can use the <switch> element and children with the systemLanguage attribute to provide
different content depending on the user's language. For example:
<svg xmlns="http://www.w3.org/2000/svg" width="200" height="100">
<rect width="200" height="100" fill="white"/>
<g transform="translate(30, 30)" font-size="20">
<switch allowReorder="yes">
<text systemLanguage="es">Español</text>
<text systemLanguage="de">Deutsch</text>
<text systemLanguage="fr">Français</text>
<text>English fallback</text>
</switch>
</g>
</svg>
You can use the --accept-language option to select which language to use when rendering. This option
accepts strings formatted like an HTTP Accept-Language header, which is a comma-separated list of BCP47
language tags: <https://www.rfc-editor.org/info/bcp47>
rsvg-convert--accept-language=es-MXinput.svg>output.png #### selects Mexican Spanish; renders
"Español".
USERSTYLESHEET
You can include an extra CSS stylesheet to be used when rendering an SVG document with the --stylesheet
option. The stylesheet will have the CSS userorigin, while styles declared in the SVG document will have
the CSS authororigin.
rsvg-convert--stylesheet=extra-styles.cssinput.svg>output.png
Please note that per the cascading rules of CSS, a user stylesheet does not necessarily override the
styles defined in an SVG document. To override them reliably, you need to set your extra styles to
!important.
According to the CSS Cascading specification (https://www.w3.org/TR/css-cascade-4/#cascade-sort), style
declarations have the following precedence. Declarations from origins later in the list win over
declarations from earlier origins:
• Normal user agent declarations (librsvg's own stylesheets).
• Normal user declarations (from your user stylesheet).
• Normal author declarations (from the SVG document).
• !important author declarations (from the SVG document).
• !important user declarations (from your user stylesheet).
• !important user agent declarations (librsvg's own stylesheets).
After that, the CSS specificity and order of appearance of declarations get taken into account.
Consider the following input.svg; notice how the rectangle has fill="red" as a presentation attribute,
and a recolorable class:
<svg xmlns="http://www.w3.org/2000/svg" width="100" height="100">
<rect width="200" height="100" fill="white"/>
<rect class="recolorable" x="10" y="10" width="50" height="50" fill="red"/>
<text x="10" y="80" font-size="20" fill="red">Hello</text>
</svg>
And this is extra-styles.css:
.recolorable { fill: blue !important; }
text { fill: green !important; }
Then the PNG created by the command above will have these elements:
• A blue square instead of a red one, because of the selector for the the recolorable class. The fill:blue!important; declaration takes precendence over the fill="red" presentation attribute.
• Text in green, since its fill="red" gets overriden with fill:green!important.