149 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php defined('SYSPATH') OR die('No direct access allowed.');
 | |
| /**
 | |
|  * Image API driver.
 | |
|  *
 | |
|  * $Id: Image.php 3769 2008-12-15 00:48:56Z zombor $
 | |
|  *
 | |
|  * @package    Image
 | |
|  * @author     Kohana Team
 | |
|  * @copyright  (c) 2007-2008 Kohana Team
 | |
|  * @license    http://kohanaphp.com/license.html
 | |
|  */
 | |
| abstract class Image_Driver {
 | |
| 
 | |
| 	// Reference to the current image
 | |
| 	protected $image;
 | |
| 
 | |
| 	// Reference to the temporary processing image
 | |
| 	protected $tmp_image;
 | |
| 
 | |
| 	// Processing errors
 | |
| 	protected $errors = array();
 | |
| 
 | |
| 	/**
 | |
| 	 * Executes a set of actions, defined in pairs.
 | |
| 	 *
 | |
| 	 * @param   array    actions
 | |
| 	 * @return  boolean
 | |
| 	 */
 | |
| 	public function execute($actions)
 | |
| 	{
 | |
| 		foreach ($actions as $func => $args)
 | |
| 		{
 | |
| 			if ( ! $this->$func($args))
 | |
| 				return FALSE;
 | |
| 		}
 | |
| 
 | |
| 		return TRUE;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Sanitize and normalize a geometry array based on the temporary image
 | |
| 	 * width and height. Valid properties are: width, height, top, left.
 | |
| 	 *
 | |
| 	 * @param   array  geometry properties
 | |
| 	 * @return  void
 | |
| 	 */
 | |
| 	protected function sanitize_geometry( & $geometry)
 | |
| 	{
 | |
| 		list($width, $height) = $this->properties();
 | |
| 
 | |
| 		// Turn off error reporting
 | |
| 		$reporting = error_reporting(0);
 | |
| 
 | |
| 		// Width and height cannot exceed current image size
 | |
| 		$geometry['width']  = min($geometry['width'], $width);
 | |
| 		$geometry['height'] = min($geometry['height'], $height);
 | |
| 
 | |
| 		// Set standard coordinates if given, otherwise use pixel values
 | |
| 		if ($geometry['top'] === 'center')
 | |
| 		{
 | |
| 			$geometry['top'] = floor(($height / 2) - ($geometry['height'] / 2));
 | |
| 		}
 | |
| 		elseif ($geometry['top'] === 'top')
 | |
| 		{
 | |
| 			$geometry['top'] = 0;
 | |
| 		}
 | |
| 		elseif ($geometry['top'] === 'bottom')
 | |
| 		{
 | |
| 			$geometry['top'] = $height - $geometry['height'];
 | |
| 		}
 | |
| 
 | |
| 		// Set standard coordinates if given, otherwise use pixel values
 | |
| 		if ($geometry['left'] === 'center')
 | |
| 		{
 | |
| 			$geometry['left'] = floor(($width / 2) - ($geometry['width'] / 2));
 | |
| 		}
 | |
| 		elseif ($geometry['left'] === 'left')
 | |
| 		{
 | |
| 			$geometry['left'] = 0;
 | |
| 		}
 | |
| 		elseif ($geometry['left'] === 'right')
 | |
| 		{
 | |
| 			$geometry['left'] = $width - $geometry['height'];
 | |
| 		}
 | |
| 
 | |
| 		// Restore error reporting
 | |
| 		error_reporting($reporting);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Return the current width and height of the temporary image. This is mainly
 | |
| 	 * needed for sanitizing the geometry.
 | |
| 	 *
 | |
| 	 * @return  array  width, height
 | |
| 	 */
 | |
| 	abstract protected function properties();
 | |
| 
 | |
| 	/**
 | |
| 	 * Process an image with a set of actions.
 | |
| 	 *
 | |
| 	 * @param   string   image filename
 | |
| 	 * @param   array    actions to execute
 | |
| 	 * @param   string   destination directory path
 | |
| 	 * @param   string   destination filename
 | |
| 	 * @return  boolean
 | |
| 	 */
 | |
| 	abstract public function process($image, $actions, $dir, $file);
 | |
| 
 | |
| 	/**
 | |
| 	 * Flip an image. Valid directions are horizontal and vertical.
 | |
| 	 *
 | |
| 	 * @param   integer   direction to flip
 | |
| 	 * @return  boolean
 | |
| 	 */
 | |
| 	abstract function flip($direction);
 | |
| 
 | |
| 	/**
 | |
| 	 * Crop an image. Valid properties are: width, height, top, left.
 | |
| 	 *
 | |
| 	 * @param   array     new properties
 | |
| 	 * @return  boolean
 | |
| 	 */
 | |
| 	abstract function crop($properties);
 | |
| 
 | |
| 	/**
 | |
| 	 * Resize an image. Valid properties are: width, height, and master.
 | |
| 	 *
 | |
| 	 * @param   array     new properties
 | |
| 	 * @return  boolean
 | |
| 	 */
 | |
| 	abstract public function resize($properties);
 | |
| 
 | |
| 	/**
 | |
| 	 * Rotate an image. Valid amounts are -180 to 180.
 | |
| 	 *
 | |
| 	 * @param   integer   amount to rotate
 | |
| 	 * @return  boolean
 | |
| 	 */
 | |
| 	abstract public function rotate($amount);
 | |
| 
 | |
| 	/**
 | |
| 	 * Sharpen and image. Valid amounts are 1 to 100.
 | |
| 	 *
 | |
| 	 * @param   integer  amount to sharpen
 | |
| 	 * @return  boolean
 | |
| 	 */
 | |
| 	abstract public function sharpen($amount);
 | |
| 
 | |
| } // End Image Driver
 |