freshleafmedia / autofocus
Automatic image focal point detection
Installs: 1 278
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 1
Forks: 0
Open Issues: 1
Requires
- php: ^8.0
- ext-imagick: *
Requires (Dev)
- pestphp/pest: ^1.22
This package is auto-updated.
Last update: 2025-03-29 01:01:24 UTC
README
Automatic image focal point detection.
Overview
Autofocus is an image analysis library which attempts to determine where the focal point of an image is.
Installation
composer require freshleafmedia/autofocus
Usage
use FreshleafMedia\Autofocus\FocalPointDetector; $focalPointDetector = new FocalPointDetector(); $point = $focalPointDetector->getPoint(new Imagick('/path/to/image')); $point->x; // 283 $point->y; // 157
How it works
The algorithm works by picking the busiest area of the image:
- Detect edges
- Apply a vignette. This pushes the focus towards the centre
- Split the image into segments
- Calculate the average brightness within each segment
- Pick the segment with the highest brightness
Options
The FocalPointDetector
constructor takes a number of options:
new FocalPointDetector( segmentSize: 20, // The size of the Segments in pixels );
Debugging
You can get access to the processed image to see how the focus was determined:
use FreshleafMedia\Autofocus\FocalPointDetector; $focalPointDetector = new FocalPointDetector(); $focalPointDetector ->debug(new Imagick('/path/to/image')) ->drawHeatMap() ->drawGrid() ->getRawImage() ->writeImage(__DIR__ . '/debug.jpg');
Tests
Unit tests can be run via composer test
Credits
This library is essentially a PHP port of https://github.com/sylvainjule/kirby-autofocus.
License
See LICENSE