What is imagemin-optipng?
The imagemin-optipng package is a plugin for Imagemin that uses the OptiPNG optimizer to compress PNG images. It helps in reducing the file size of PNG images without losing quality, making it ideal for web developers looking to optimize their images for faster loading times.
What are imagemin-optipng's main functionalities?
Basic PNG Optimization
This code demonstrates how to use imagemin-optipng to optimize PNG images in the 'images' directory and save the optimized images to the 'build/images' directory.
const imagemin = require('imagemin');
const imageminOptipng = require('imagemin-optipng');
(async () => {
await imagemin(['images/*.png'], {
destination: 'build/images',
plugins: [
imageminOptipng()
]
});
console.log('Images optimized');
})();
Custom Optimization Level
This code shows how to set a custom optimization level for the PNG images. The optimizationLevel option can be set from 0 to 7, where higher values provide better compression but take more time.
const imagemin = require('imagemin');
const imageminOptipng = require('imagemin-optipng');
(async () => {
await imagemin(['images/*.png'], {
destination: 'build/images',
plugins: [
imageminOptipng({ optimizationLevel: 3 })
]
});
console.log('Images optimized with custom optimization level');
})();
Other packages similar to imagemin-optipng
imagemin-pngquant
imagemin-pngquant is another Imagemin plugin that uses the pngquant library to compress PNG images. It is known for providing lossy compression, which can result in smaller file sizes compared to imagemin-optipng, but with a potential loss in image quality.
imagemin-zopfli
imagemin-zopfli is an Imagemin plugin that uses the Zopfli compression algorithm to optimize PNG images. It provides high compression ratios, often better than imagemin-optipng, but at the cost of longer compression times.
imagemin-pngcrush
imagemin-pngcrush is an Imagemin plugin that uses the PNGCrush optimizer to reduce the file size of PNG images. It offers various optimization strategies and can be a good alternative to imagemin-optipng for certain use cases.
imagemin-optipng
optipng image-min plugin
Install
$ npm install --save imagemin-optipng
Usage
var Imagemin = require('imagemin');
var optipng = require('imagemin-optipng');
var imagemin = new Imagemin()
.src('images/*.png')
.dest('build/images')
.use(optipng({ optimizationLevel: 3 }));
imagemin.run(function (err, files) {
if (err) {
throw err;
}
console.log('Files optimized successfully!');
});
You can also use this plugin with gulp:
var gulp = require('gulp');
var optipng = require('imagemin-optipng');
gulp.task('default', function () {
return gulp.src('images/*.png')
.pipe(optipng({ optimizationLevel: 3 })())
.pipe(gulp.dest('build/images'));
});
Options
optimizationLevel
Type: Number
Default: 3
Select an optimization level between 0
and 7
.
The optimization level 0 enables a set of optimization operations that require minimal effort. There will be no changes to image attributes like bit depth or color type, and no recompression of existing IDAT datastreams. The optimization level 1 enables a single IDAT compression trial. The trial chosen is what. OptiPNG thinks it’s probably the most effective. The optimization levels 2 and higher enable multiple IDAT compression trials; the higher the level, the more trials.
Level and trials:
- 1 trial
- 8 trials
- 16 trials
- 24 trials
- 48 trials
- 120 trials
- 240 trials
License
MIT © imagemin