maagi / imagine-focalresizer
Focal point resizing for Imagine
Installs: 9 428
Dependents: 1
Suggesters: 0
Security: 0
Stars: 2
Watchers: 3
Forks: 2
Open Issues: 0
Requires
- imagine/imagine: ~0.2
This package is not auto-updated.
Last update: 2025-01-08 20:17:28 UTC
README
#ImagineFocalResizer
A tool for Imagine Image manipulation library for PHP to resize its image instances using a central "focal point". The image will always be cropped so that the focal point remains within the resized image. This allows to create versions for different screen sizes while maintaining a "responsive crop".
The focal point defined by x and y coordinates ranging from the left top corner (-1,1) to the right bottom corner (1,-1). The center of the image is at (0,0).
Note: The y-axis has been flipped in version 0.2.0 so that the top edge is at 1 and bottom edge at -1.
The idea comes from Jono Menz's jQuery FocusPoint plugin. Its documentation illustrates how the approach works.
##Installation##
Use Composer to install.
$ composer require maagi/imagine-focalresizer
##Usage##
use Imagine\Gd\Imagine; // or Imagick/Gmagick
use Imagine\Image\ImageInterface;
use Imagine\Image\Box;
use Maagi\ImagineFocalResizer\Resizer;
use Maagi\ImagineFocalResizer\FocalPoint;
$imagine = new Imagine();
$image = $imagine->open('dragonfly.jpg');
$resizer = new Resizer();
$resizer->resize(
$image,
// target size
new Box(100, 200),
// crop around the point at 50% to the right and 70% to the top
new FocalPoint(0.5, 0.7),
// Imagine filter for resize (optional)
ImageInterface::FILTER_UNDEFINED
);
// maybe do further processing with the image...
$image->save('dragonfly-resized.jpg');
##How it works##
The cropping strategy used here is very simple. It just compares the width and height ratios of the original and target sizes. The focal point will be on the center of the crop on the axis on which the ratio is greater while the other axis will remain uncropped. If a part of the crop area goes beyond the image's edge it will be moved accordingly.
##Contribution##
I know there are other cropping strategies and some fit certain scenarios better than the others. Please suggest other (better) ways to do this. The logic could then be extracted to several strategy classes and let the user decide which one to use.