charcoal / image
PHP Image manipulation library
Requires
- php: ^7.4 || ^8.0
- charcoal/factory: ^5.0
Requires (Dev)
- php-coveralls/php-coveralls: ^2.2
- phpunit/phpunit: ^9.5
- squizlabs/php_codesniffer: ^3.5
Suggests
- ext-SimpleXML: To parse sprite (SVG) property.
- ext-imagick: To use the imagick driver.
Replaces
- dev-main / 5.x-dev
- v5.0.0
- v4.1.0
- v4.0.8
- v4.0.7
- v4.0.6
- v4.0.5
- v4.0.4
- v4.0.2
- v4.0.1
- v4.0.0
- v3.1.8
- v3.1.7
- v3.1.6
- v3.1.5
- v3.1.4
- v3.1.3
- v3.1.2
- v3.1.1
- v3.1.0
- v2.2.3
- v2.2.2
- v2.2.1
- v2.2.0
- v2.1.2
- v0.4.3.3
- v0.4.3.2
- v0.4.3.1
- v0.4.3
- v0.4.2.1
- v0.4.2
- v0.4.1
- v0.4
- v0.3
- v0.2
- v0.1
- dev-mcaskill-develop
- dev-mcaskill-strip-metadata
This package is auto-updated.
Last update: 2024-12-13 16:40:41 UTC
README
The Image package provides a consistent API for image manipulation and processing
with integrations for GD (coming soon) and ImageMagick (via the PHP extension or via shell commands).
Installation
composer require charcoal/image
Overview
Why another PHP image libary?
Why not?. Charcoal Image has been developped and used in in-house projects for almost 10 years. It has recently been rewritten to a more modern PHP style and released under an open-source license (MIT).
The main differences between existing PHP libraries like Imagine or Intervention are:
- Effect parameters are sent as an array.
- Is it
blur($sigma, $radius)
orblur($radius, $sigma)
? - With charcoal image it's constant:
blur([ 'radius' => $radius, 'sigma' => $sigma ]);
- Is it
- It supports ImageMagick binaries
- It seems to be a pretty common setup where Imagemagick is installed on a server, but the Imagick PHP library is not.
- No external dependencies, except the tiny charcoal/factory.
Usage
Typically, the Image package is used to load an image, perform operations (called effects such as blur, resize, watermark, etc.) and write the modified image.
With setData()
All effects can be added at once in a single array.
$img = new Charcoal\Image\Imagick\ImagickImage(); $img->setData([ 'source' => 'example.png', 'target' => 'example-modified.png', 'effects' => [ [ 'type' => 'resize', 'width' => 600, ], [ 'type' => 'blur', 'mode' => 'gaussian', 'sigma' => 5, ], ], ]); $img->process(); $img->save();
setData()
is perfect for scenario where the effects are from a JSON configuration structure, for example.
With magic methods
All effects can also be used as methods on the image (using __call()
magic).
use Charcoal\Image\Imagick\ImagickImage as Image; $img = new Image(); $img->open('example.png'); $img->resize([ 'width' => 600 ]); $img->blur([ 'mode' => 'gaussian', 'sigma' => 5 ]); $img->save();
Chainable version
Also shown: using the ImageFactory
constructor method:
use Charcoal\Image\ImageFactory; $factory = new ImageFactory(); $img = $factory->create('imagemagick'); $img->open('example.png') ->resize([ 'mode' => 'best_fit', 'width' => 350, 'height' => 350, ]) ->rotate([ 'angle' => 90, ]) ->modulate([ 'luminance' => 50, ]) ->save('modified-target.png');
Available effects and operations are documented in the API Documentation.
Available image drivers
There are currently only 2 available drivers:
imagick
- The imagick driver use the
Imagick
PHP extension, which is build on top of imagemagick.
- The imagick driver use the
imagemagick
- The imagemagick driver uses the imagmagick binaries directly, running the operations in a separate shell process instead of directely within PHP.
- The commands
convert
,mogrify
andidentify
should be installed on the system and reachable from the PHP process.
👉 Comming soon, the
gd
driver to use PHP builtin's image capacity.
How to select a driver
There are two different ways to instantiate an Image object for a specific driver.
Directly:
$img = new Charcoal\Image\Imagick\ImagickImage(); // or $img = new Charcoal\Image\Imagemagick\ImagemagickImage();
With the provided ImageFactory
:
use Charcoal\Image\ImageFactory; $factory = new ImageFactory(); $img = $factory->create('imagick'); // or $img = $factory->create('imagemagick');