Just In Time Image manipulation: Library for HTTP based image manipulation.
> composer composer require thapp/jmg
> composer install
> vendor/bin/phpunit -c phpunit.xml.dist
Using the ImageResolver
class, it is easy to resolve images from parameter strings.
<?php
use Thapp\Jmg\ParamGroup;
use Thapp\Jmg\Image\Processor;
use Thapp\Jmg\Resolver\PathResolver;
use Thapp\Jmg\Resolver\LoaderReslover;
use Thapp\Jmg\Resolver\ImageResolver;
$processor = new Thapp\Jmg\Image\Processor(
new Thapp\Image\Driver\Gd\Source
);
$images = new ImageResolver($source, $pathResolver, $loaderResolver);
if ($resource = $res->resolve('images/source.jpg', ParamGroup::fromString('2/400/400/5'))) {
header('Content-Type: image/jpeg');
echo $resource->getContents();
}
Jmg supports loading images from a variety of sources. In the example below, lets assume we have a local filesystem that hosts our images.
<?php
use Thapp\Jmg\Loader\FilesystemLoader;
use Thapp\Jmg\Resolver\LoaderReslover;
use Thapp\Jmg\Resolver\PathResolver;
$loaderResolver = new LoaderResolver;
$pathResolver = new PathResolver;
$pathResolver->add('local', __DIR__.'public/images');
$loaderResolver->add('local', new FilesystemLoader);
// tries to resolve a given prefix path;
if (!$loader === $loaderResolver->resolve('local')) // returns the FilesystemLoader {
//then error
}
if (null === $path = $pathResolver->resolve('local')) {
//then error
}
$src = $loader->load($path . '/image.jpg');
You may create your own loaders, e.g. for loading images from a remote source like an Amazon s3 storage or an ftp server.
Your custom loader must implement the Thapp\Jmg\Loader\LoaderInterface
or simply extend from Thapp\Jmg\Loader\AbstractLoader
.
<?php
namespace Acme\Loaders;
use Thapp\Jmg\Loader\AbstractLoader
class AWSLoader extends AbstractLoader
{
/**
* @throws Thapp\Jmg\Exception\SourceLoaderException
* @return Thapp\Jmg\Resource\FileResourceInterface
*/
public function load($file)
{
//…
}
/**
* @return bool
*/
public function supports($path)
{
//…
}
}