Generate animated GIF/WebP for sharp base on gifenc.
npm install sharp-gif2
const fs = require("fs");
const sharp = require("sharp");
const GIF = require("sharp-gif2");
(async () => {
// Simple use case
const image = await GIF
.createGif()
.addFrame([
sharp("./frames/0000.png"),
sharp("./frames/0001.png"),
sharp("./frames/0002.png"),
])
.toSharp();
image.toFile("./frames.gif");
// Can also generate an animated WebP
image.toFile("./frames.webp");
// Options
const gif = GIF.createGif({
// Sharp constructor options
sharpOptions: {},
// Custom size
width: 300,
height: 200,
// Delay(s) between animation frames
delay: 200,
// Number of animation iterations
repeat: 0,
// Enable 1-bit transparency for the GIF
transparent: false,
// Palette max colors
maxColors: 256,
// Color format
format: "rgb565",
// Resize all frame to `largest` or `smallest`
resizeTo: "largest",
// Resize by `zoom` or `crop`
resizeType: "zoom",
// Options for sharp.resize()
resizeOptions: {},
// Background option for sharp.extend()
extendBackground: { r: 0, g: 0, b: 0, alpha: 0 },
// gifenc GIFEncoder() options
gifEncoderOptions: {},
// gifenc quantize() options
gifEncoderQuantizeOptions: {},
// gifenc gif.writeFrame() options
gifEncoderFrameOptions: {},
});
gif.addFrame(sharp("./1.png"));
gif.addFrame(sharp("./2.png"));
const image = await gif.toSharp();
image.toFile("./frames.gif");
// Trace encoding progress
const image = await GIF
.createGif()
.addFrame(
fs.readdirSync("./frames")
.map((file) => sharp(`./frames/${file}`))
)
.toSharp(({ total, encoded }) => {
console.log(`${encoded}/${total}`);
});
image.toFile("./frames.gif");
// You can even concat animated GIFs
const image = await GIF
.createGif({
transparent: true,
format: "rgb444",
maxColors: 32,
})
.addFrame([
sharp("./1.gif", { animated: true }),
sharp("./2.gif", { animated: true }),
])
.toSharp();
image.toFile("./concat.gif");
})();
const sharp = require("sharp");
const GIF = require("sharp-gif2");
(async () => {
const reader = GIF.readGif(sharp("./2.gif", { animated: true }));
const frames = await reader.toFrames();
frames.forEach((frame, index) => {
// You can process each frame here
// Or just simple output frame
frame.toFile(`./output/${("000" + index).substr(-4)}.png`);
});
const gif = await reader.toGif({ transparent: true, });
const image = await gif.toSharp();
image.toFile("./output/remake.gif");
})();
options
Object (optional)sharpOptions
Object (optional) - Sharp constructor options.width
Number (optional) - Width, in pixels, of the GIF to output.height
Number (optional) - Height, in pixels, of the GIF to output.delay
(Number | Number[]) (optional) - Delay(s) between animation frames (in milliseconds).repeat
Number (optional) - Number of animation iterations, use0
for infinite animation. Default by0
.transparent
Boolean (optional) - Enable 1-bit transparency for the GIF. Default byfalse
.maxColors
Number (optional) - Quantize the total number of colors down to a reduced palette no greater than maxColors. Default by256
.format
("rgb565" | "rgb444" | "rgba4444") (optional) - Color format. Default byrgb565
.rgb565
means 5 bits red, 6 bits green, 5 bits blue (better quality, slower)rgb444
is 4 bits per channel (lower quality, faster)rgba4444
is the same as above but with alpha support
resizeTo
("largest" | "smallest") (optional) - Resize all frame to thelargest
frame orsmallest
frame size. Default bylargest
.resizeType
("zoom" | "crop") (optional) -zoom
use sharp.resize(),crop
use sharp.extend() and sharp.extract(). Default byzoom
.resizeOptions
sharp.ResizeOptions (optional) - Options for sharp.resize().extendBackground
sharp.Color (optional) - Background option for sharp.extend().gifEncoderOptions
Object (optional) - gifenc GIFEncoder() options.gifEncoderQuantizeOptions
Object (optional) - gifenc quantize() options.gifEncoderFrameOptions
Object (optional) - gifenc gif.writeFrame() options.
Returns Gif
- Return a instance of Gif Contains the following methods:
frame
(Sharp | Sharp[]) - An instance of Sharp, or an array of instance of Sharp.
Returns Gif
- Return the Gif instance for chaining.
Encode all frames and resolve with an animated Sharp instance.
progress
(info: Object) => void (optional) - Frames encoding progress.info
Objecttotal
Number - Total frames count.encoded
Number - Encoded frames count.
encoder
GIFEncoder (optional) - Custom GIFEncoder.
Returns Promise<Sharp>
- Resolve with an instance of Sharp.
Encode all frames and resolve with an animated GIF buffer.
options
Object (optional) - gifenc GIFEncoder() options.
Return a GIFEncoder.
image
Sharp - An instance of Sharp
Returns GifReader
- Return a instance of GifReader Contains the following methods:
Cut GIF frames.
progress
(info: Object) => void (optional) - Frames cutting progress.info
Objectcutted
Number - cutted frames count.total
Number - Total frames count.
Returns Promise<Sharp[]>
- Resolve with cutted frames (an array of instance of Sharp).
Create Gif from cutted frames.
options
Object (optional) - Options for createGif(). See createGif.
Returns Promise<Gif>
- Resolve with an instance of Gif.
A shortcut to create a Gif with the cutted frames, equal to:
GIF.createGif(options).addFrame(reader.frames || (await reader.toFrames()));
- Feature:
reader.toFrames(progress)
adds progress option.