freshleafmedia / image-compression-finder
Installs: 1 663
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: ^8.1
- league/glide: ^2.2
- spatie/temporary-directory: ^2.1
- symfony/process: ^6.2
Requires (Dev)
- pestphp/pest: ^1.22
This package is auto-updated.
Last update: 2025-03-18 01:59:52 UTC
README
Automatic detection of maximum compression without visually changing the image.
Overview
This is a library which attempts to determine the maximum amount of compression which can be applied to an image while not introducing any visible changes.
The output is an integer between 0 and 100.
Installation
composer require freshleafmedia/image-compression-finder
DSSIM
A working copy of kornelski/dssim must be installed.
To install the latest, at time of writing, on Ubuntu the following one-liner can be used:
curl -sSL https://github.com/kornelski/dssim/releases/download/3.2.3/dssim_3.2.3_amd64.deb > /tmp/dssim.deb && apt install /tmp/dssim.deb
Imagick/GD
Either of Imagick or GD extensions are required.
Usage
use FreshleafMedia\ImageCompressionFinder\ImageCompressionFinder; $quality = ImageCompressionFinder::make()->run('/path/to/image'); $quality; // 66 (0-100)
How it works
The algorithm uses a binary search to repeatedly compress and test an image until the ideal quality is found
- Compress the image with a quality setting of 60
- Analyse the new image using DSSIM
- If the change is within tolerance the quality is halved, if not it is increased by 50% (aka a binary search)
- Compress the image again with the new quality
- GOTO 2
Options
There are a couple of configuration options:
$quality = ImageCompressionFinder::make() ->maxDifference(0.001) // The highest acceptable visual change. 0-∞ where 0 is no change at all ->startingQuality(60) // Where to start the search ->driver('imagick') // The driver to use to compress images. Eg imagick or gd ->run();
Tests
Unit tests can be run via composer test
License
See LICENSE