2012-10-24 15:28:39 -07:00
|
|
|
<?php
|
2015-09-15 14:52:02 +12:00
|
|
|
|
|
|
|
use SilverStripe\Filesystem\Storage\AssetContainer;
|
|
|
|
use SilverStripe\Filesystem\Storage\AssetStore;
|
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
|
|
|
* Image_Backend
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2012-10-24 15:28:39 -07:00
|
|
|
* A backend for manipulation of images via the Image class
|
|
|
|
*
|
|
|
|
* @package framework
|
|
|
|
* @subpackage filesystem
|
|
|
|
*/
|
|
|
|
interface Image_Backend {
|
|
|
|
|
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Represents a square orientation
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
2015-09-15 14:52:02 +12:00
|
|
|
const ORIENTATION_SQUARE = 0;
|
2012-10-24 15:28:39 -07:00
|
|
|
|
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Represents a portrait orientation
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
2015-09-15 14:52:02 +12:00
|
|
|
const ORIENTATION_PORTRAIT = 1;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Represents a landscape orientation
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
2015-09-15 14:52:02 +12:00
|
|
|
const ORIENTATION_LANDSCAPE = 2;
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Create a new backend with the given object
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2015-09-15 14:52:02 +12:00
|
|
|
* @param AssetContainer $assetContainer Object to load from
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
2015-09-15 14:52:02 +12:00
|
|
|
public function __construct(AssetContainer $assetContainer = null);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Populate the backend with a given object
|
2014-08-15 18:53:05 +12:00
|
|
|
*
|
2015-09-15 14:52:02 +12:00
|
|
|
* @param AssetContainer $assetContainer Object to load from
|
|
|
|
*/
|
|
|
|
public function loadFromContainer(AssetContainer $assetContainer);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Populate the backend from a local path
|
2012-10-24 15:28:39 -07:00
|
|
|
*
|
2015-09-15 14:52:02 +12:00
|
|
|
* @param string $path
|
|
|
|
*/
|
|
|
|
public function loadFrom($path);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Write to the given asset store
|
|
|
|
*
|
|
|
|
* @param AssetStore $assetStore
|
|
|
|
* @param string $filename Name for the resulting file
|
|
|
|
* @param string $hash Hash of original file, if storing a variant.
|
|
|
|
* @param string $variant Name of variant, if storing a variant.
|
|
|
|
* @param string $conflictResolution {@see AssetStore}. Will default to one chosen by the backend
|
|
|
|
* @return array Tuple associative array (Filename, Hash, Variant) Unless storing a variant, the hash
|
|
|
|
* will be calculated from the given data.
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
2015-09-15 14:52:02 +12:00
|
|
|
public function writeToStore(AssetStore $assetStore, $filename, $hash = null, $variant = null, $conflictResolution = null);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Write the backend to a local path
|
|
|
|
*
|
|
|
|
* @param string $path
|
|
|
|
*/
|
|
|
|
public function writeTo($path);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the quality to a value between 0 and 100
|
2012-10-24 15:28:39 -07:00
|
|
|
*
|
2015-09-15 14:52:02 +12:00
|
|
|
* @param int $quality
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
2015-09-15 14:52:02 +12:00
|
|
|
public function setQuality($quality);
|
2012-10-24 15:28:39 -07:00
|
|
|
|
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Resize an image, skewing it as necessary.
|
2012-10-24 15:28:39 -07:00
|
|
|
*
|
|
|
|
* @param int $width
|
|
|
|
* @param int $height
|
2015-09-15 14:52:02 +12:00
|
|
|
* @return static
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
|
|
|
public function resize($width, $height);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Resize the image by preserving aspect ratio. By default, it will keep the image inside the maxWidth
|
|
|
|
* and maxHeight. Passing useAsMinimum will make the smaller dimension equal to the maximum corresponding dimension
|
2012-10-24 15:28:39 -07:00
|
|
|
*
|
|
|
|
* @param int $width
|
|
|
|
* @param int $height
|
2015-09-15 14:52:02 +12:00
|
|
|
* @param bool $useAsMinimum If true, image will be sized outside of these dimensions.
|
|
|
|
* If false (default) image will be sized inside these dimensions.
|
|
|
|
* @return static
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
2015-09-15 14:52:02 +12:00
|
|
|
public function resizeRatio($width, $height, $useAsMinimum = false);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Resize an image by width. Preserves aspect ratio.
|
2012-10-24 15:28:39 -07:00
|
|
|
*
|
|
|
|
* @param int $width
|
2015-09-15 14:52:02 +12:00
|
|
|
* @return static
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
|
|
|
public function resizeByWidth($width);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Resize an image by height. Preserves aspect ratio.
|
2012-10-24 15:28:39 -07:00
|
|
|
*
|
|
|
|
* @param int $height
|
2015-09-15 14:52:02 +12:00
|
|
|
* @return static
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
|
|
|
public function resizeByHeight($height);
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Return a clone of this image resized, with space filled in with the given colour
|
2012-10-24 15:28:39 -07:00
|
|
|
*
|
|
|
|
* @param int $width
|
|
|
|
* @param int $height
|
2015-09-15 14:52:02 +12:00
|
|
|
* @return static
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
|
|
|
public function paddedResize($width, $height, $backgroundColor = "FFFFFF");
|
2014-08-15 18:53:05 +12:00
|
|
|
|
2012-10-24 15:28:39 -07:00
|
|
|
/**
|
2015-09-15 14:52:02 +12:00
|
|
|
* Resize an image to cover the given width/height completely, and crop off any overhanging edges.
|
2012-10-24 15:28:39 -07:00
|
|
|
*
|
|
|
|
* @param int $width
|
|
|
|
* @param int $height
|
2015-09-15 14:52:02 +12:00
|
|
|
* @return static
|
2012-10-24 15:28:39 -07:00
|
|
|
*/
|
|
|
|
public function croppedResize($width, $height);
|
|
|
|
}
|