Transform Images
Image manipulation plugin using Sharp
Options See on deno.land
Description
Use the transform_images
plugin to process image files using the sharp library. With this plugin, you can resize, rotate, and convert any image to other formats.
The plugin reads the data assigned to the image files (specifically the transformImages
key) to know how to transform the image.
Note
This plugin supports the formats jpeg
, jp2
, png
, webp
, gif
, avif
, heif
and tiff
.
jxl
is not supported at the moment.
Installation
Import this plugin in your _config.ts
file to use it:
import lume from "lume/mod.ts";
import transformImages from "lume/plugins/transform_images.ts";
const site = lume();
site.use(transformImages(/* Options */));
export default site;
Example
Create a /img
folder in your project to store the images and a _data.yml
file inside this folder with the following code:
transformImages:
resize: [200, 200]
format: webp
This file assigns this data to all image pages in this folder and subfolders (see Shared data for more info about _data
files). The plugin will read the data, resize all images to 200x200, and convert them to webp format.
To transform the images to 200px width preserving the aspect ratio, use only one value:
transformImages:
resize: [200] # Set 200px width, calculate the height automatically
format: webp
The format
value can be an array of values, in order to output the same file configuration to different formats:
transformImages:
resize: [200, 200]
format: [webp, jpg]
Multiple outputs
If you need to create multiple versions of the same image file (for responsive design, for example), use an array of transforms. Make sure to include the suffix
key to generate different names for the output files:
transformImages:
- resize: [200, 200]
suffix: -small
format: [webp, jpg]
- resize: [1000, 1000]
format: webp
- resize: [2000, 2000]
suffix: -big
format: webp
This code generates 4 files for every image file (note the first transform with 2 formats). For example, if the input file is background.png
, it will generate the files background.webp
, background.jpg
, background-small.webp
and background-big.webp
.
Matches
The property matches
allows to set a regular expression so the transform is executed only to these files matching the pattern.
In the following example, the images containing -cover
will be resized to 1000x1000, and the images containing -icon
to 100x100.
transformImages:
- resize: [1000, 1000]
matches: -cover
- resize: [100, 100]
matches: -icon
The matches
value must be a RegExp or a valid string that can be used to create a RegExp instance.
Custom functions
By default, the following functions are available:
- resize: Accepts two numbers for
width
andheight
and optionally an object with the resize options. See sharp resize api for more info. - blur: Accepts a number for
sigma
. - rotate: Accepts a number for
degrees
.
You can add more custom functions in the _config
file. For example:
import lume from "lume/mod.ts";
import transformImages from "lume/plugins/transform_images.ts";
const site = lume();
site.use(transformImages({
functions: {
resizeBlur(img, size) {
img.resize(size, size);
img.blur(10);
},
},
}));
export default site;
Now you can use this function in your _data files:
transformImages:
resizeBlur: 20
format: webp
Cache
This plugin saves the transformed images in the _cache
folder to improve the build speed. If you want to disable the cache, set its option to false
.
import lume from "lume/mod.ts";
import transformImages from "lume/plugins/transform_images.ts";
const site = lume();
site.use(transformImages({
cache: false, // Disable cache
}));
export default site;
This option allows customizing the cache folder. For example: cache: "_image-cache"
.