femtopixel/crop

PHP Component to resize images from a configuration file


Keywords
crop, dimensions, distortion, image, packagist, php, resized-images
License
MIT

Documentation

logo

Crop

Latest Stable Version Minimum PHP Version License PayPal donation Buy me a coffee Become a Patron

DISCLAIMER: As-of 2021, this product does not have a free support team anymore. If you want this product to be maintained, please support on Patreon.

(This product is available under a free and permissive license, but needs financial support to sustain its continued improvements. In addition to maintenance and stability there are many desirable features yet to be added.)

This component will resize images following configuration rules. allows only defined format

Installation

composer require femtopixel/crop

Usage

<?php
$formats = array(
    'mini' => array(
        'width' => 100,
        'height' => 100,
        'full' => 'cropped',
    ),
);
$image = new \FemtoPixel\Crop\Crop('/path/to/file.png', 'mini');
$image->setFormatsFromArray($formats)->render();

You can define as many format that you want!

  • First parameter is path to your file to display
  • Second (optional) is the format you want to display in (default : 'original' (no modification))
  • Third (optional) is path to default image displayed if path in first parameter doesn't exist. This file will be displayed in requested format. (default : 'src/missing.png')

Configuration

Each format given in method setFormatsFromArray must define width, height and optional full index.

full can be configured to 4 values depending on attended rendering :

  • none : No cropping, no resize. Will render image with original file dimensions.
  • cropped : Crop the rendered image to be exactly dimensions defined in configuration.
  • height : Resize the image without distortion to have height to value defined in configuration.
  • width : Resize the image without distortion to have width to value defined in configuration.