zatsugami/imgen

Flexible inline image manipulation tool

dev-master 2013-08-31 15:26 UTC

This package is not auto-updated.

Last update: 2024-05-07 02:47:58 UTC


README

Imgen is a utility library, that let you create and serve images in different size variations on the fly, while being SEO friendly.

  • Search for images in any path and save them anywhere
  • Save images with SEO friendly file names
  • Resize images on the fly

Why Imgen and where it can help you?

Imgen is an outcome of my frustration when I was working on a project for a SEO Expert client. It was a portfolio website which served a lot of images in different size variations. You could upload an image and required size variations were created. Everything fine so far, until I had to change size variations of every image already uploaded along with the file name... multiple times. Ouch!

If you are in a familiar situation like me, your requirements change dynamically or you just want to be agile when it comes to images, Imgen is here to help you out.

Imgen is easy!

How easy?

<?= image('yellow-tshirt.jpg', 'Cool Yellow T-Shirt')->crop(300, 450) ?>

Based on configuration may output the following:

<img src="/images/products/yellow-tshirt-c300x450.jpg" alt="Cool Yellow T-Shirt" />
<!-- or -->
<img src="/images/products/300x450/yellow-tshirt.jpg" alt="Cool Yellow T-Shirt" />
<!-- or -->
<img src="/images/300/yellow-tshirt.jpg" alt="Cool Yellow T-Shirt" />
<!-- or anything else! -->

Imgen is flexible!

Imgen is really flexible and let you configure important aspects of handling your images. Let's take a look at example configuration below.

# Composer autoloader
require 'vendor/autoload.php';

use \Zatsugami\Imgen\Imgen;

# Default image processor Imgen is shipped with
use \Zatsugami\Imgen\Processors\Intervention;

# You can use global instance as your delivery mechanism of Imgen object.
# You can also just invoke new Imgen(), so you can do the setup in your base controller
# or anywhere you want.
Imgen::instance()
# Configure image groups
->setGroups([
    # Default group MUST be defined
    'default' => [
        # Paths are relative to webRoot config, this option does not need to be an array
        'look_in' => ['uploads/images'],
        # {~} are placeholders for processing params, you can read about them later,
        # but they should be intuitive
        'save_to' => 'images/{m}{w}x{h}/{f}.{e}',
    ],
])
# You need to set the webRoot directory
->setWebRoot(__DIR__)
# This alows you to use any image processing library you want as long as you provide adapter class!
->setImageProcessor(new Intervention);

However, there is still one thing you want to do. It's recommended that you define a global function to serve you as a helper.

# It's best to setup a global helper function
if ( ! function_exists('image') )
{
    function image($filename, $alt, $group = 'default')
    {
        return Imgen::instance()->image($filename, $alt, $group);
    }
}

Docs

Image groups

Image group is a set of rules/configuration for realted images. By defining groups you gain better controll. It can help you to change all images without even touching the code.

# Let's define a group for images on products catalog page
['catalog' => [
    'look_in' => 'uploads/images/products',
    'save_to' => 'products/{m}{w}x{h}/{f}.{e}',
]];

You could call for those images like this

<?= image('superb-product.jpg', 'catalog')->size(300, 300) ?>

Cool, but we can do better. Now, if client decide that he want catalog images to be cropped, we would need to change the code that display the img tag.

<?= image('superb-product.jpg', 'So cool, wow!','catalog')->crop(300, 300) ?>

By defining a better group config we can improve here.

['catalog' => [
    'look_in' => 'uploads/images/products',
    'save_to' => 'products/{m}{w}x{h}/{f}.{e}',
    'mode' => 'c', # Default resize mode
    'width' => 300, 'height' => 300, # Default size
]];

Our image call would look like this in this case:

<?= image('superb-product.jpg', 'Even better!', 'catalog') ?>

Group options

look_in

It can be string or array. Path relative to webRoot configuration. Imgen will look for images in this path(s)

save_to

Path relative to webRoot configuration. Imgen will save processed images in this path. The path can contain placeholders which will be replaced with processing parameters. Those placeholders are:

  • {m} - resize mode flag. Read more about modes here,
  • {w} - requested width,
  • {h} - requested height,
  • {f} - file name without extension,
  • {e} - file extension
mode

Resize mode flag which says in which maner image should be resized. There are few flags available.

  • n - none, resize to the given size, ignoring aspect ratio
  • a - auto or fit, resize the image so that it fits into specified box, keeping aspect ratio,
  • i - inverse or fill, image will fill the box, but the overflowing part won't be cut, keeps aspect ratio,
  • c - crop, same as i, fill, except overflowing part will be cut,
  • w - width, resize to match the width, keeping aspect ratio,
  • h - height, resize to match the height, keeping aspect ratio,
width

The default width

height

The default height

Image methods

The Image class returned by Imgen::instance()->image() have few methods that change the default resize options and some more.

  • width($width) - sets $width and mode to width,
  • height($height) - sets $height mode to height,
  • size($width, $height) - sets $width and $height, do not set any mode,
  • fill($width, $height) - sets $width and $height and mode to fill,
  • fit($width, $height) - sets $width and $height and mode to fit,
  • crop($width, $height) - sets $width and $height and mode to crop,
  • mode($mode) - sets mode to $mode,
  • attrs($attrs) - set custom attributes on the <img /> tag
  • url() - by calling this method, only URL will be returned instead of <img /> tag,

You can read more in the source code.

Using custom image processing library

With Imgen you can use any image processing library you want. All you need to do is to provide an adapter class. Your adapter has to implement Zatsugami\Imgen\ImageProcessorInterface, but you can also just extend the Zatsugami\Imgen\ImageProcessor abstract class.