Apply EXIF Orientation (JPEG) before any other operation.
namespace
Image
namespace Image
interface ConstructorOptions
- maxPixels?: number
Reject inputs whose
width × heightexceeds this many pixels. The check runs after the header is read but before any pixel buffer is allocated, so a tiny file claiming a huge canvas is refused cheaply.
interface ModulateOptions
interface ResizeOptions
- fit?: 'fill' | 'inside'
"fill"stretches to exactly width×height."inside"preserves aspect ratio so the result fits within width×height.
- type ErrorCode = 'ERR_IMAGE_FORMAT_UNSUPPORTED' | 'ERR_IMAGE_TOO_MANY_PIXELS' | 'ERR_IMAGE_DECODE_FAILED' | 'ERR_IMAGE_ENCODE_FAILED' | 'ERR_IMAGE_UNKNOWN_FORMAT' | 'ERR_INVALID_STATE'
Stable
error.codevalues set on rejections fromBun.Imageterminals. Branch on these instead of parsing the message.ERR_IMAGE_FORMAT_UNSUPPORTED— the requested format isn't available on this machine (HEIC/AVIF without the OS codec, TIFF on Linux). Catch this to fall back to a portable format.ERR_IMAGE_TOO_MANY_PIXELS— header dimensions or resize output exceedmaxPixels, or a path-backed input is over the 256 MiB cap.ERR_IMAGE_DECODE_FAILED/ERR_IMAGE_ENCODE_FAILED— codec error.ERR_IMAGE_UNKNOWN_FORMAT— input bytes didn't match any sniffer.ERR_INVALID_STATE— the input ArrayBuffer was transferred between construction and the terminal call.- File-backed inputs surface the underlying syscall code (
ENOENT,EACCES, …) directly.
- type Filter = 'nearest' | 'box' | 'bilinear' | 'linear' | 'cubic' | 'mitchell' | 'lanczos2' | 'lanczos3' | 'mks2013' | 'mks2021'
- type Format = 'jpeg' | 'png' | 'webp' | 'heic' | 'avif' | 'bmp' | 'tiff' | 'gif'
bmp/tiff/gifare decode-only —metadata().formatmay report them but there are no.bmp()/.tiff()/.gif()encoder methods.tiffdecode rejects witherror.code === "ERR_IMAGE_FORMAT_UNSUPPORTED"on Linux;gifdecodes the first frame everywhere.