image-transform/README.md

66 lines
2.6 KiB
Markdown
Raw Permalink Normal View History

2020-09-30 18:11:50 +00:00
# image-transform
2020-09-30 18:21:05 +00:00
[![Build Status](https://travis-ci.org/jobyone/image-transform.svg?branch=main)](https://travis-ci.org/jobyone/image-transform)
[![Coverage Status](https://coveralls.io/repos/github/jobyone/image-transform/badge.svg?branch=main)](https://coveralls.io/github/jobyone/image-transform?branch=main)
2020-09-30 18:11:50 +00:00
A tightly-focused library for performing a very limited set of simple image transformations. This library's purpose is to eschew the standard kitchen sink approach to PHP image libraries in favor of high performance, wide driver support, and a dead simple API.
2020-09-30 18:21:05 +00:00
2020-10-01 22:07:33 +00:00
## Current state
2020-09-30 18:21:05 +00:00
This library is under active development, and until a 1.0 release is made you should expect it to potentially be broken, and unexpectedly and dramatically change its API and functionality. That said, I *do* have use of this thing for work, so I'm probably going to be working pretty dang hard on it, and hope to have a stable release by about November of 2020.
2020-09-30 18:21:05 +00:00
2020-10-01 22:07:33 +00:00
### Current progress
| Driver | Rotate | Mirror | Resize | Crop | Overlay | Grayscale | Colorize |
| :--------- | :----: | :----: | :----: | :--: | :-----: | :-------: | :------: |
| GD | X | X | X | X | | | |
| Imagick | | | | | | | |
| Gmagick | | | | | | | |
| ImagickCLI | X | X | X | X | | | |
## Roadmap
2020-09-30 18:21:05 +00:00
### Drivers
A 1.0 release will not be made until the following drivers are available and solidly tested:
* GD
* Imagick
* Gmagick
* GmagickCLI
### Transforms
2020-10-01 01:21:22 +00:00
A 1.0 release will be made available once the following transforms are available and solidly tested across all drivers. These are basically what I see as the bare minimum for such a library to be useful.
2020-09-30 18:21:05 +00:00
* orientation
* rotate (in 90 degree increments)
* mirror-h
* mirror-v
* size
* fit (basically an alias for max-width and max-height)
* cover (scale to cover a box, then crop excess)
* crop (crop toward the center to a given size)
* cover-crop (convenience transform, combining cover and crop, useful for thumbnails)
More complex, and also lesser used effects/stages that may or may not make it into 1.0
* color effects
* grayscale
* colorize
* content effects
* overlay
* blur
* hue
* saturation
* brightness
#### Order of operations
In the name of simplicity and ease of use, the effective order of operations will always be as reflected above:
1. Orientation
2. Resizing and cropping
3. Color effects
4. Content-changing effects