likely starting points stubbed out
This commit is contained in:
parent
3870cb25e1
commit
e95b1d7413
13 changed files with 256 additions and 3 deletions
10
README.md
10
README.md
|
@ -17,7 +17,7 @@ A 1.0 release will not be made until the following drivers are available and sol
|
||||||
|
|
||||||
### Transforms
|
### Transforms
|
||||||
|
|
||||||
A 1.0 release will be made available once the following transforms are available and solidly tested across all drivers:
|
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.
|
||||||
|
|
||||||
* rotate (in 90 degree increments)
|
* rotate (in 90 degree increments)
|
||||||
* mirror-h
|
* mirror-h
|
||||||
|
@ -25,8 +25,8 @@ A 1.0 release will be made available once the following transforms are available
|
||||||
* max-width
|
* max-width
|
||||||
* max-height
|
* max-height
|
||||||
* fit (basically an alias for max-width and max-height)
|
* fit (basically an alias for max-width and max-height)
|
||||||
* cover
|
* cover (scale to cover a box, then crop excess)
|
||||||
* crop
|
* crop (crop toward the center to a given size)
|
||||||
* cover-crop (convenience transform, combining cover and crop, useful for thumbnails)
|
* cover-crop (convenience transform, combining cover and crop, useful for thumbnails)
|
||||||
|
|
||||||
The following transforms are also on my mind as possibilities, but may or may not make it into 1.0:
|
The following transforms are also on my mind as possibilities, but may or may not make it into 1.0:
|
||||||
|
@ -34,3 +34,7 @@ The following transforms are also on my mind as possibilities, but may or may no
|
||||||
* grayscale
|
* grayscale
|
||||||
* colorize (needs to function consistently though)
|
* colorize (needs to function consistently though)
|
||||||
* overlay (i.e. for watermarking)
|
* overlay (i.e. for watermarking)
|
||||||
|
* blur
|
||||||
|
* hue
|
||||||
|
* saturation
|
||||||
|
* brightness
|
||||||
|
|
25
composer.json
Normal file
25
composer.json
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
{
|
||||||
|
"name": "jobyone/image-transform",
|
||||||
|
"description": "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.",
|
||||||
|
"type": "library",
|
||||||
|
"license": "MIT",
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Joby Elliott",
|
||||||
|
"email": "joby@byjoby.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"ByJoby\\ImageTransform\\": "src/"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"suggest": {
|
||||||
|
"ext-imagick": "to use the Imagick implementation",
|
||||||
|
"ext-gmagick": "to use the Gmagick implementation"
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": ">=7.1",
|
||||||
|
"ext-gd": "*"
|
||||||
|
}
|
||||||
|
}
|
20
composer.lock
generated
Normal file
20
composer.lock
generated
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
{
|
||||||
|
"_readme": [
|
||||||
|
"This file locks the dependencies of your project to a known state",
|
||||||
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies",
|
||||||
|
"This file is @generated automatically"
|
||||||
|
],
|
||||||
|
"content-hash": "6eb3038135c5de665d7b86ae7ecb3427",
|
||||||
|
"packages": [],
|
||||||
|
"packages-dev": [],
|
||||||
|
"aliases": [],
|
||||||
|
"minimum-stability": "stable",
|
||||||
|
"stability-flags": [],
|
||||||
|
"prefer-stable": false,
|
||||||
|
"prefer-lowest": false,
|
||||||
|
"platform": {
|
||||||
|
"ext-gd": "*"
|
||||||
|
},
|
||||||
|
"platform-dev": [],
|
||||||
|
"plugin-api-version": "1.1.0"
|
||||||
|
}
|
10
src/DriverInterface.php
Normal file
10
src/DriverInterface.php
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform;
|
||||||
|
|
||||||
|
interface DriverInterface
|
||||||
|
{
|
||||||
|
public function source(string $source);
|
||||||
|
public function originalWidth(): int;
|
||||||
|
public function originalHeight(): int;
|
||||||
|
}
|
25
src/Drivers/AbstractDriver.php
Normal file
25
src/Drivers/AbstractDriver.php
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform\Drivers;
|
||||||
|
|
||||||
|
use ByJoby\ImageTransform\DriverInterface;
|
||||||
|
|
||||||
|
abstract class AbstractDriver implements DriverInterface
|
||||||
|
{
|
||||||
|
protected $source;
|
||||||
|
|
||||||
|
public function source(string $source)
|
||||||
|
{
|
||||||
|
// set source
|
||||||
|
$this->source = $source;
|
||||||
|
// validate file
|
||||||
|
if (!is_file($this->source)) {
|
||||||
|
throw new \Exception("Image file doesn't exist: " . htmlentities($this->source));
|
||||||
|
}
|
||||||
|
if (!exif_imagetype($this->source)) {
|
||||||
|
throw new \Exception("Invalid image file: " . htmlentities($this->source));
|
||||||
|
}
|
||||||
|
// get height/width
|
||||||
|
list($this->originalWidth, $this->originalHeight) = getimagesize($this->source);
|
||||||
|
}
|
||||||
|
}
|
10
src/Drivers/GDDriver.php
Normal file
10
src/Drivers/GDDriver.php
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform\Drivers;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This driver uses PHP's built-in GD libary. This is by far the slowest
|
||||||
|
* driver, but support is basically universal.
|
||||||
|
*/
|
||||||
|
class GDDriver extends AbstractDriver
|
||||||
|
{}
|
9
src/Drivers/GmagickDriver.php
Normal file
9
src/Drivers/GmagickDriver.php
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform\Drivers;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This driver uses the Gmagick extension
|
||||||
|
*/
|
||||||
|
class GmagickDriver extends AbstractDriver
|
||||||
|
{}
|
13
src/Drivers/ImagickCLIDriver.php
Normal file
13
src/Drivers/ImagickCLIDriver.php
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform\Drivers;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This driver is designed to use exec() and your OS's binary Imagick
|
||||||
|
* installation to do all of its image transforms. This will likely be
|
||||||
|
* the highest-performance driver of all in most situations, but does
|
||||||
|
* require that you have CLI Imagick installed, and that your server allows
|
||||||
|
* PHP's exec() function to use it.
|
||||||
|
*/
|
||||||
|
class ImagickCLIDriver extends AbstractDriver
|
||||||
|
{}
|
9
src/Drivers/ImagickDriver.php
Normal file
9
src/Drivers/ImagickDriver.php
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform\Drivers;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class uses the ImageMagick extension
|
||||||
|
*/
|
||||||
|
class ImagickDriver extends AbstractDriver
|
||||||
|
{}
|
31
src/Image.php
Normal file
31
src/Image.php
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform;
|
||||||
|
|
||||||
|
class Image
|
||||||
|
{
|
||||||
|
protected $src, $driver;
|
||||||
|
protected $transforms = [];
|
||||||
|
|
||||||
|
public function __construct(string $src, DriverInterface $driver)
|
||||||
|
{
|
||||||
|
$this->src = $src;
|
||||||
|
$this->driver = clone $driver;
|
||||||
|
$this->driver->source($src);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function transform(TransformInterface $transform)
|
||||||
|
{
|
||||||
|
$this->transforms[] = $transform;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function originalWidth(): int
|
||||||
|
{
|
||||||
|
return $this->driver->originalWidth();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function originalHeight(): int
|
||||||
|
{
|
||||||
|
return $this->driver->originalHeight();
|
||||||
|
}
|
||||||
|
}
|
52
src/TransformInterface.php
Normal file
52
src/TransformInterface.php
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform;
|
||||||
|
|
||||||
|
interface TransformInterface
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Whether this transformer changes the contents of the image. Used when
|
||||||
|
* optimizing transformation order.
|
||||||
|
*/
|
||||||
|
const CHANGES_CONTENT = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Whether this transformer changes the size of the image. Used when
|
||||||
|
* optimizing transformation order.
|
||||||
|
*/
|
||||||
|
const CHANGES_SIZE = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Whether this transformer changes the colors of the image. Used when
|
||||||
|
* optimizing transformation order.
|
||||||
|
*/
|
||||||
|
const CHANGES_COLOR = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Whether or not applying this transform multiple times will always
|
||||||
|
* produce the same result. Used with optimizing transformation order.
|
||||||
|
*/
|
||||||
|
const TRANSFORM_STABLE = true;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Optionally return an array of other transforms that perform the
|
||||||
|
* operations necessary to perform this single transform.
|
||||||
|
*
|
||||||
|
* If this method returns anything, the Image object will add the
|
||||||
|
* Transformers returned here, and this object will be discarded.
|
||||||
|
*
|
||||||
|
* This allows new Transformers to be constructed by composing
|
||||||
|
* existing ones.
|
||||||
|
*
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function chain(): array;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return whether or not this transformation will impact the given
|
||||||
|
* Image. Should return true if it's possible, as it will be
|
||||||
|
* skipped if it returns false.
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function willTransform(Image $image): bool;
|
||||||
|
}
|
19
src/Transforms/AbstractTransform.php
Normal file
19
src/Transforms/AbstractTransform.php
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform\Drivers;
|
||||||
|
|
||||||
|
use ByJoby\ImageTransform\Image;
|
||||||
|
use ByJoby\ImageTransform\TransformInterface;
|
||||||
|
|
||||||
|
abstract class AbstractTransform implements TransformInterface
|
||||||
|
{
|
||||||
|
public function chain(): array
|
||||||
|
{
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
public function willTransform(Image $image): bool
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
26
src/Transforms/MaxWidth.php
Normal file
26
src/Transforms/MaxWidth.php
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
<?php
|
||||||
|
/* image-transform | https://github.com/jobyone/image-transform | MIT License */
|
||||||
|
namespace ByJoby\ImageTransform\Drivers;
|
||||||
|
|
||||||
|
use ByJoby\ImageTransform\Image;
|
||||||
|
|
||||||
|
class MaxWidth extends AbstractTransform
|
||||||
|
{
|
||||||
|
const CHANGES_SIZE = true;
|
||||||
|
|
||||||
|
protected $size;
|
||||||
|
|
||||||
|
public function __construct(int $size)
|
||||||
|
{
|
||||||
|
$this->size = $size;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function willTransform(Image $image): bool
|
||||||
|
{
|
||||||
|
if ($image->originalWidth() <= $this->size) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue