intervention / image-driver-vips
libvips driver for Intervention Image
Fund package maintenance!
Intervention
Ko Fi
paypal.me/interventionio
Requires
- php: ^8.1
- intervention/image: ^3.11.0
- jcupitt/vips: ^2.4
Requires (Dev)
- ext-fileinfo: *
- mockery/mockery: ^1.6
- phpstan/phpstan: ^2
- phpunit/phpunit: ^10.0 || ^11.0
- slevomat/coding-standard: ~8.0
- squizlabs/php_codesniffer: ^3.8
This package is auto-updated.
Last update: 2025-01-20 21:38:47 UTC
README
Intervention Image's official driver to use Intervention Image with libvips. libvips is a fast, low-memory image processing library that outperforms the standard PHP image extensions GD and Imagick. This package makes it easy to utilize the power of libvips in your project while taking advantage of Intervention Image's user-friendly and easy-to-use API.
Installation
You can easily install this library using Composer. Simply request the package with the following command:
composer require intervention/image-driver-vips
Getting Started
The public API of Intervention Image can be
used unchanged. The only configuration that needs to be done is to ensure that
Intervention\Image\Drivers\Vips\Driver
by this library is used by Intervention\Image\ImageManager
.
Code Examples
use Intervention\Image\ImageManager; use Intervention\Image\Drivers\Vips\Driver as VipsDriver; // create image manager with vips driver $manager = ImageManager::withDriver(VipsDriver::class); // open an image file $image = $manager->read('images/example.gif'); // resize image instance $image->resize(height: 300); // insert a watermark $image->place('images/watermark.png'); // encode edited image $encoded = $image->toJpg(); // save encoded image $encoded->save('images/example.jpg');
Requirements
- PHP >= 8.1
Caveats
-
Due to the technical characteristics of libvips, it is currently not possible to implement color quantization via
ImageInterface::reduceColors()
as intended. However, there is a pull request in libvips that enables this feature and it may be integrated here the future as well. -
With PHP on macOS, font files are not recognized in the
ImageInterface::text()
call by default because Quartz as a rendering engine does not allow font files to be loaded at runtime via the fontconfig API. However, setting the environment variablePANGOCAIRO_BACKEND
tofontconfig
helps here.
Authors
This library was developed by Oliver Vogel and Thomas Picquet.
License
Intervention Image Driver Vips is licensed under the MIT License.