xtract.bot
POST /api/svg-to-png

Render an SVG to a PNG at the requested size. Useful for thumbnails, OG images, app icons, anything that needs a bitmap of an SVG.

Renders an SVG document to a PNG bitmap at the requested size. Inputs: - `svg`: the SVG source (text or bytes). - `width` / `height`: target dimensions in pixels. If only one is set, the other is derived from the SVG aspect ratio. - `background` (default transparent): a hex colour to fill the canvas before rendering. Useful when the SVG itself has no background and you want a non-transparent PNG. Use cases: thumbnail generation for icons, OG-image rendering for share-cards, baked-in fallbacks for older browsers.

Inputs

NameTypeDefaultDescription
svg*fileSVG markup (UTF-8 bytes).
widthnumber (1…16384)Output width in pixels. Mutually exclusive with `height` and `scale`.
heightnumber (1…16384)Output height in pixels. Mutually exclusive with `width` and `scale`.
scalenumber (0.05…32)Zoom factor (1 = native size, 2 = double, 0.5 = half). Mutually exclusive with `width` and `height`.
backgroundstringCSS colour for the background (e.g. `#fff`, `rgba(0,0,0,0.5)`). Default transparent — preserves SVG transparency.
dpinumber (1…600)96DPI for physical-unit conversion (mm/pt → px). Default 96 (web-standard). Use 300 for print-quality output.

Response

Modes: binary, base64-json. Cache: yes (24h TTL).

Code samples

Built from the native-size example.

# Download or substitute the example input:
#   curl -O https://xtract.bot/examples/svg-to-png/sample.svg
SVG=$(base64 -w0 < sample.svg)

curl -X POST https://api.xtract.bot/api/svg-to-png \
  -H "Content-Type: application/json" \
  -H "Accept: application/octet-stream" \
  -H "X-Account-Id: $XTRACT_ACCOUNT_ID" \
  -H "X-Api-Key: $XTRACT_API_KEY" \
  -d '{
  "svg": "'"$SVG"'"
}'