Imagick
Image manipulation using Imagick
Options See on deno.land
- extensions string[]
The list extensions this plugin applies to
Default:[ ".jpg", ".jpeg", ".png" ]- name string
The key name for the transformations definitions
Default:"imagick"- cache string boolean
The cache folder
Default:true- functions record
Custom transform functions
Description
Use the imagick plugin to process image files using the magick-wasm library, a powerful image manipulation library with support for over 100 major file formats. 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 imagick key) to know how to transform the image.
Installation
Import this plugin in your _config.ts file to use it:
import lume from "lume/mod.ts";
import imagick from "lume/plugins/imagick.ts";
const site = lume();
site.use(imagick(/* 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:
imagick:
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.
The format value can be an array of values, in order to output the same file configuration to different formats:
imagick:
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:
imagick:
- 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.
imagick:
- 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
widthandheightor one number that will be used forwithandheight. - crop: Accepts two numbers for
widthandheightor one number that will be used forwithandheight. - blur: Accepts two numbers for
radiusandsigma. - sharpen: Accepts two numbers for
radiusandsigma. - rotate: Accepts one number for
degrees. - autoOrient: No argument is needed.
You can add more custom functions in the _config file. For example:
import lume from "lume/mod.ts";
import imagick from "lume/plugins/imagick.ts";
const site = lume();
site.use(imagick({
functions: {
resizeBlur(img, size) {
img.resize(size, size);
img.blur(10, 5);
},
},
}));
export default site;
Now you can use this function in your _data files:
imagick:
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 imagick from "lume/plugins/imagick.ts";
const site = lume();
site.use(imagick({
cache: false, // Disable cache
}));
export default site;
This option allows customizing the cache folder. For example: cache: "_imagick-cache".