1
0
mirror of https://github.com/imgproxy/imgproxy.git synced 2025-01-23 11:14:48 +02:00
imgproxy/docs/image_formats_support.md

75 lines
3.7 KiB
Markdown
Raw Normal View History

2018-11-08 16:34:21 +06:00
# Image formats support
2019-09-30 15:53:13 +06:00
At the moment, imgproxy supports only the most popular image formats:
2018-11-08 16:34:21 +06:00
2020-09-01 19:57:44 +06:00
| Format | Extension | Source | Result |
| -------|-----------|--------|--------|
| PNG | `png` | Yes | Yes |
| JPEG | `jpg` | Yes | Yes |
| WebP | `webp` | Yes | Yes |
| AVIF | `avif` | Yes | Yes |
2020-09-01 19:57:44 +06:00
| GIF | `gif` | Yes | Yes |
| ICO | `ico` | Yes | Yes |
| SVG | `svg` | Yes | [See notes](#svg-support) |
| HEIC | `heic` | Yes | No |
| BMP | `bmp` | Yes | Yes |
| TIFF | `tiff` | Yes | Yes |
2020-09-01 20:15:24 +06:00
| PDF <img class='pro-badge' src='assets/pro.svg' alt='pro' /> | `pdf` | Yes | No |
| MP4 (h264) <img class='pro-badge' src='assets/pro.svg' alt='pro' /> | `mp4` | [See notes](#video-thumbnails) | Yes |
| Other video formats <img class='pro-badge' src='assets/pro.svg' alt='pro' /> | | [See notes](#video-thumbnails) | No |
2018-11-08 16:34:21 +06:00
## GIF support
imgproxy supports GIF output only when using libvips 8.7.0+ compiled with ImageMagick support. Official imgproxy Docker image supports GIF out of the box.
2018-11-15 20:04:12 +06:00
2019-06-13 14:20:11 +06:00
## ICO support
2018-11-15 20:04:12 +06:00
2019-09-30 16:03:07 +06:00
imgproxy supports ICO only when using libvips 8.7.0+ compiled with ImageMagick support. Official imgproxy Docker image supports ICO out of the box.
2018-11-15 20:04:12 +06:00
2019-10-11 19:33:34 +06:00
## SVG support
imgproxy supports SVG sources without limitations, but SVG results are not supported when the source image is not SVG.
When the source image is SVG and the SVG result is requested, imgproxy returns source image without modifications.
2020-02-11 19:28:13 +06:00
imgproxy reads some amount of bytes to check if the source image is SVG. By default it reads maximum of 32KB, but you can change this:
* `IMGPROXY_MAX_SVG_CHECK_BYTES`: the maximum number of bytes imgproxy will read to recognize SVG. If imgproxy can't recognize your SVG, try to increase this number. Default: `32768` (32KB)
2019-06-25 15:28:34 +06:00
## HEIC support
imgproxy supports HEIC only when using libvips 8.8.0+. Official imgproxy Docker image supports HEIC out of the box.
## AVIF support
imgproxy supports AVIF only when using libvips 8.9.0+ with compiled support for libheif + its supported encoder (rav1e, aom). Official imgproxy Docker image supports AVIF out of the box.
## BMP support
2019-09-30 17:36:38 +06:00
imgproxy supports BMP only when using libvips 8.7.0+ compiled with ImageMagick support. Official imgproxy Docker image supports ICO out of the box.
By default, imgproxy saves BMP images as JPEG. You need to explicitly specify the `format` option to get BMP output.
2019-06-13 14:20:11 +06:00
## Animated images support
2018-12-02 19:02:19 +06:00
2019-06-13 14:20:11 +06:00
Since processing of animated images is pretty heavy, only one frame is processed by default. You can increase the maximum of animation frames to process with the following variable:
2018-12-02 19:02:19 +06:00
2019-06-13 14:20:11 +06:00
* `IMGPROXY_MAX_ANIMATION_FRAMES`: the maximum of animated image frames to being processed. Default: `1`.
**📝Note:** imgproxy summarizes all frames resolutions while checking source image resolution.
2019-10-11 19:20:28 +06:00
2020-09-01 20:15:24 +06:00
## Converting animated images to MP4<img class='pro-badge' src='assets/pro.svg' alt='pro' />
2019-10-11 19:20:28 +06:00
Animated images results can be converted to MP4 by specifying `mp4` extension.
Since MP4 requires usage of a `<video>` tag instead of `<img>`, automatic conversion to MP4 is not provided.
2020-09-01 20:15:24 +06:00
## Video thumbnails<img class='pro-badge' src='assets/pro.svg' alt='pro' />
If you provide a video as a source, imgproxy takes its specific frame to create a thumbnail. Doing this imgproxy downloads only the amount of data required to reach the needed frame.
Since this still requires more data to be downloaded, video thumbnails generation is disabled by default and should be enabled with `IMGPROXY_ENABLE_VIDEO_THUMBNAILS` config option.
2020-04-17 22:12:15 +06:00
* `IMGPROXY_ENABLE_VIDEO_THUMBNAILS`: when true, enables video thumbnails generation. Default: false;
* `IMGPROXY_VIDEO_THUMBNAIL_SECOND`: the timestamp of the frame in seconds that will be used for a thumbnail. Default: 1.