images.Process
Syntax
Returns
Returns an image filter that processes an image according to the given processing specification. This versatile filter supports the full range of image transformations, including resizing, cropping, rotation, and format conversion, all within a single specification string. Use this as an argument to the Filter method or the images.Filter function.
{{ with resources.Get "images/original.jpg" }}
{{ $filter := images.Process "crop 200x200 TopRight webp q50" }}
{{ with .Filter $filter }}
<img src="{{ .RelPermalink }}" width="{{ .Width }}" height="{{ .Height }}" alt="">
{{ end }}
{{ end }}In the example above, "crop 200x200 TopRight webp q50" is the processing specification.
Processing specification
The processing specification is a space-delimited, case-insensitive list containing one or more of the following options in any sequence:
- action
- Specify one of
crop,fill,fit, orresize. This is applicable to theProcessmethod and theimages.Processfilter. If you specify an action, you must also provide dimensions. - anchor
- The focal point of the crop box when cropping or filling an image. Valid options include
TopLeft,Top,TopRight,Left,Center,Right,BottomLeft,Bottom,BottomRight, orSmart. This defaults to theanchorparameter in your site configuration. TheSmartoption identifies the most interesting area of the image based on the smart cropping algorithm implemented in thesmartcrop.jslibrary. - background color
- The background color of the resulting image. This applies when converting an image with transparency to a format that does not support it, such as when converting from PNG to JPEG, or when rotating an image by a non-orthogonal angle into a non-transparent format. In these cases, this color fills the empty space created as the image extents increase to fit the rotated corners. The value must be an RGB hexadecimal color, defaulting to the
bgColorparameter in your site configuration. - compression
- New in v0.153.5
- The compression method used when encoding an image. Valid options include
losslessorlossy. Thelosslessmethod is only applicable to WebP images. This defaults to thecompressionparameter in your site configuration. - dimensions
- The dimensions of the resulting image, in pixels. The format is
WIDTHxHEIGHTwhereWIDTHandHEIGHTare whole numbers. When resizing an image, you may specify only the width (such as600x) or only the height (such asx400) for proportional scaling. Specifying both width and height when resizing an image may result in non-proportional scaling. When cropping, fitting, or filling, you must provide both width and height such as600x400. - format
- The format of the resulting image. Valid options include
bmp,gif,jpeg,png,tiff, orwebp. This defaults to the format of the source image. - hint
- The encoding preset used when processing WebP images, equivalent to the
-presetflag for thecwebpencoder. Valid options includedrawing,icon,photo,picture, ortext. This defaults to thehintparameter in your site configuration.Value Example drawingHand or line drawing with high-contrast details iconSmall colorful image photoOutdoor photograph with natural lighting pictureIndoor photograph such as a portrait textImage that is primarily text - quality
- The quality of the resulting image, applicable to JPEG and WebP images when using lossy compression. The format is
qQUALITYwhereQUALITYis a whole number between1and100, inclusive. This defaults to thequalityparameter in your site configuration. - resampling filter
- The filter used to calculate new pixels when resizing, fitting, or filling an image. Common options include
box,lanczos,catmullRom,mitchellNetravali,linear, ornearestNeighbor. This defaults to theresampleFilterparameter in your site configuration.Filter Description boxSimple and fast averaging filter appropriate for downscaling lanczosHigh-quality resampling filter for photographic images yielding sharp results catmullRomSharp cubic filter that is faster than the Lanczos filter while providing similar results mitchellNetravaliCubic filter that produces smoother results with less ringing artifacts than CatmullRom linearBilinear resampling filter, produces smooth output, faster than cubic filters nearestNeighborFastest resampling filter, no antialiasing Refer to the source documentation for a complete list of available resampling filters. If you wish to improve image quality at the expense of performance, you may wish to experiment with the alternative filters.
- rotation
- The number of whole degrees to rotate an image counter-clockwise. The format is
rDEGREESwhereDEGREESis a whole number. Hugo performs rotation before any other transformations, so your target dimensions and any anchor point should refer to the image orientation after rotation. User90,r180, orr270for orthogonal rotations, or arbitrary angles such asr45. To rotate clockwise, use a negative number such asr-45. To automatically rotate an image based on its EXIF orientation tag, use theimages.AutoOrientfilter instead of manual rotation.Rotating by non-orthogonal values increases the image extents to fit the rotated corners; the resulting empty space is transparent for formats supporting alpha channels, or filled with a background color. This background color defaults to the
bgColorparameter in your site configuration unless you include a background color
Usage
Create a filter:
{{ $filter := images.Process "crop 200x200 TopRight webp q50" }}Apply the filter using the images.Filter function:
{{ with resources.Get "images/original.jpg" }}
{{ with . | images.Filter $filter }}
<img src="{{ .RelPermalink }}" width="{{ .Width }}" height="{{ .Height }}" alt="">
{{ end }}
{{ end }}You can also apply the filter using the Filter method on a Resource object:
{{ with resources.Get "images/original.jpg" }}
{{ with .Filter $filter }}
<img src="{{ .RelPermalink }}" width="{{ .Width }}" height="{{ .Height }}" alt="">
{{ end }}
{{ end }}Example
Original

Processed

