thegrommet / image-resizer
A PHP library for resizing images
v1.2.0
2022-03-02 18:50 UTC
Requires
- php: ^7.4 || ^8.0
- ext-gd: ^7.4 || ^8.0
- gumlet/php-image-resize: ^1.9
- kraken-io/kraken-php: ^1.6
Requires (Dev)
- phpunit/phpunit: ^8.2
- squizlabs/php_codesniffer: ^3.4
This package is auto-updated.
Last update: 2024-12-13 21:00:03 UTC
README
A PHP library for resizing images
Build status
Usage
Resizing
$resizer = new \Grommet\ImageResizer\Resizer('/path/to/images', '/path/to/save'); $newPath = $resizer->resize('in.jpg', 'out.jpg', ['strategy' => 'fit', 'width' => 100]); // $newPath = '/path/to/save/out.jpg'
Generating URLs to assets
$urlGen = new \Grommet\ImageResizer\UrlGenerator('https://cdn.site.com/media'); $url = $urlGen->imageUrl('i/image.jpg', ['strategy' => 'fit', 'width' => 100]); // $url = 'https://cdn.site.com/media/fit_w-100/i/image.jpg'
Resize presets
$presets = [ 'small' => [ 'width' => 293, 'height' => 219 ], 'large' => [ 'strategy' = 'crop', 'width' => 500, 'height' => 500 ] ]; /* urls */ $urlGen = new \Grommet\ImageResizer\UrlGenerator('https://cdn.site.com/media', $presets); $url = $urlGen->imageUrl('i/image.jpg', ['size' => 'small']); // $url = 'https://cdn.site.com/media/fit_w-293_h-219/i/image.jpg' /* files */ $resizer = new \Grommet\ImageResizer\PresetResizer( '/path/to/images', '/path/to/save', $presets ); $newPath = $resizer->resize('image.jpg', 'large'); // $newPath = '/path/to/save/crop_w-500_h-500_m-c/image.jpg'
Resizing service
$urlResizer = new \Grommet\ImageResizer\UrlResizer( '/path/to/images', '/path/to/save', 'https://cdn.site.com/media' ); // incoming request for a resized image $url = 'https://cdn.site.com/media/fit_w-100/i/image.jpg'; $newPath = $urlResizer->resize($url); // $newPath = '/path/to/save/fit_w-100/i/image.jpg' header('Content-Type: image/jpeg'); $resource = imagecreatefromjpeg($newPath); imagejpeg($resource); // output to browser imagedestroy($resource);
Resize Strategies
Resize Adapters
By default, the resizer will use PHP's GD2 functions to resize the images. You may specify a different image resize adapter to and offload that work to a 3rd party.
Kraken.io
Use Kraken's image resizing service once you have an account and API access:
$resizer = new \Grommet\ImageResizer\Resizer( '/path/to/images', '/path/to/save', 'kraken', ['api-key', 'api-secret'] ); $newPath = $resizer->resize('in.jpg', 'out.jpg', ['strategy' => 'fit', 'w' => 100, 'h' => 50]); // $newPath = '/path/to/save/out.jpg'
Running tests
composer test
Code style & fix
# sniff src folder composer fmt-check # fix src folder composer fmt