Skip to content

A CakePHP plugin for creating thumbnails and image variants on the fly

License

Notifications You must be signed in to change notification settings

xavier83ar/image-presenter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ImagePresenter plugin for CakePHP

Installation

You can install this plugin into your CakePHP application using composer.

The recommended way to install composer packages is:

composer require xavier83ar/image-presenter

Usage

Load the plugin

Plugin::load('ImagePresenter', ['routes' => true]);

Configure your variants...

'ImagePresenter' => [
    'variants' => [
        'thumbnail' => [
            'size' => [350, 250],
            'mode' => ImageInterface::THUMBNAIL_OUTBOUND,
            'filter' => ImageInterface::FILTER_LANCZOS
        ],
        'mini' => [
            'operation' => 'thumbnail',
            'size' => [120, 120],
            'mode' => ImageInterface::THUMBNAIL_INSET,
        ],
        'other' => [
            'operation' => function (ImageInterface $imagine) {
                return $imagine->resize(new Box(400, 300))->rotate(90);
            }
        ],
        'amazing' => [
            'operation' => function (ImageInterface $imagine) {
                return $imagine
                    ->resize(new Box(600, 320))
                    ->effects()->grayscale()->blur(5);
            }
        ],
    ],
]

Any variant which its name starts with "thumbnail" will use thumbnail operation mode. Right now there two operation modes: thumbnail, which sets up a ImageInterface::thumbnail() operation, and closure mode, which allows you to pass a closure which receive an ImageInterface to play with.

This helpers uses imagine/imagine package for image manipulation operations, see https://imagine.readthedocs.org/en/latest/ for more information.

Showing up images

Finally load and use ImageHelper

class AppView extends View
{
    public function initialize()
    {
        $this->loadHelper('ImagePresenter.Image');
    }
}

On your templates

<img src="<?= $this->Image->variant($img, 'thumbnail') ?>" alt="">

ImagePresenter\View\Helper\ImageHelper::variant() method will only check if exists a file for that variant, if it does, then it will return the path to that file relative to webroot, if not, it will return the path to the PresenterController which takes care of generate that variant and serve the file.

This way variants are created only when needed, and only once.