Download the PHP package locomotivemtl/charcoal-image without Composer
On this page you can find all versions of the php package locomotivemtl/charcoal-image. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download locomotivemtl/charcoal-image
More information about locomotivemtl/charcoal-image
Files in locomotivemtl/charcoal-image
Package charcoal-image
Short Description PHP Image manipulation library
License MIT
Informations about the package charcoal-image
Charcoal Image
Charcoal Image is a PHP image manipulation and processing library, providing a consistent API across different Image drivers. Currently supported drivers are Imagick
(the PHP extension) and Imagemagick
(using shell commands)
- API Documentation
How to install
The preferred (and only supported) way of installing charcoal-image is with composer:
Dependencies
PHP 5.6+
locomotivemtl/charcoal-factory
ext-imagick
(optional but recommended) ORImageMagick binaries
👉 Although this module was developped for
Charcoal
, there is absolutely no dependencies on any Charcoal modules and can therefore be used in any PHP project.
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. charcoal-image can be used
- No external dependencies, except the tiny
charcoal-factory
.
Usage
Typically, charcoal-image 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.
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).
Chainable version
Also shown: using the ImageFactory
constructor method:
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:
With the provided ImageFactory
:
Development
To install the development environment:
To run the tests:
Coding Style
All Charcoal modules follow the same coding style and charcoal-image
is no exception. For PHP:
- PSR-1
- PSR-2
- PSR-4, autoloading is therefore provided by Composer
- phpDocumentor
- Arrays should be written in short notation (
[]
instead ofarray()
)
Coding styles are enforced with grunt phpcs
(PHP Code Sniffer). The actual ruleset can be found in phpcs.xml
.
👉 To fix minor coding style problems, run
grunt phpcbf
(PHP Code Beautifier and Fixer). This tool uses the same ruleset as phpcs to automatically correct coding standard violations.
The main PHP structure follow the PSR-4 standard. Autoloading is therefore provided by Composer.
To ensure a clean code base, pre-commit git hooks should be installed on all development environments.
Continuous Integration
Unit Tests
Every class, method, and function should be covered by unit tests. PHP code can be tested with PHPUnit.
Authors
- Mathieu Ducharme [email protected]
Changelog
0.3
Released 2016-03-11
- Break BC in every way.
- Convert to camelCase / Full PSR-1 / PSR-2 support.
0.2
Released 2015-09-15
- Add a new "auto-orientation" effect (imagick + imagemagick)
- Add the watermark effect to imagemagick (imagemagick)
- Fixed the "unsharp mask" mode for sharpen effect (imagick)
- Fixed the gravity for the watermark effect (imagick)
- Accept ImageInterface objects as watermark (global)
- Add a dependency on
locomotivemtl/charcoal-factory
and fix factories accordingly. (global)
0.1
Released 2015-08-26
- Initial release
TODOs
- Write a version for PHP's
gd
driver. - Custom Exceptions.
- Change effect signature to be callable (invokable) instead of using the process() method.
- Skip unit tests instead of failing if a driver is not available.