0byt3m1n1
Path:
/
data
/
applications
/
aps
/
b2evolution
/
4.0.5-0
/
standard
/
htdocs
/
inc
/
files
/
model
/
[
Home
]
File: _image.funcs.php
<?php /** * This file implements various Image File handling functions. * * This file is part of the evoCore framework - {@link http://evocore.net/} * See also {@link http://sourceforge.net/projects/evocms/}. * * @copyright (c)2003-2010 by Francois PLANQUE - {@link http://fplanque.net/} * * {@internal License choice * - If you have received this file as part of a package, please find the license.txt file in * the same folder or the closest folder above for complete license terms. * - If you have received this file individually (e-g: from http://evocms.cvs.sourceforge.net/) * then you must choose one of the following licenses before using the file: * - GNU General Public License 2 (GPL) - http://www.opensource.org/licenses/gpl-license.php * - Mozilla Public License 1.1 (MPL) - http://www.opensource.org/licenses/mozilla1.1.php * }} * * {@internal Open Source relicensing agreement: * }} * * @package evocore * * {@internal Below is a list of authors who have contributed to design/coding of this file: }} * @author fplanque: Francois PLANQUE. * * @version $Id: _image.funcs.php,v 1.23 2010/04/22 20:43:27 blueyed Exp $ */ if( !defined('EVO_MAIN_INIT') ) die( 'Please, do not access this page directly.' ); /** * @return array 'key'=>'name' */ function get_available_thumb_sizes() { global $thumbnail_sizes; $thumb_size_names = array(); foreach( $thumbnail_sizes as $key=>$dummy ) { $thumb_size_names[$key] = $key; } return $thumb_size_names; } /** * Crop dimensions to fit into a constrained size, while preserving aspect ratio. * * @param integer source width * @param integer source height * @param integer constrained width * @param integer constrained height * @return array ( x, y, width, height ) */ function crop_to_constraint( $src_width, $src_height, $max_width, $max_height ) { $src_ratio = $src_width / $src_height; $max_ratio = $max_width / $max_height; if( $max_ratio <= $src_ratio ) { $y = 0; $x = ($src_width - ($src_width * ($max_ratio/$src_ratio))) / 2; $src_width = $src_width * ($max_ratio/$src_ratio); } else { $x = 0; $y = ($src_height - $src_width/$max_ratio) / 2; $src_height = $src_width/$max_ratio; } return array( $x, $y, $src_width, $src_height ); } /** * Scale dimensions to fit into a constrained size, while preserving aspect ratio. * * @param integer source width * @param integer source height * @param integer constrained width (might be NULL/0 to use source width) * @param integer constrained height (might be NULL/0 to use source height) * @return array (width, height) */ function scale_to_constraint( $src_width, $src_height, $max_width, $max_height ) { if( $max_width == 0 ) $max_width = $src_width; if( $max_height == 0 ) $max_height = $src_height; $src_ratio = $src_width / $src_height; if( $max_width / $max_height <= $src_ratio ) { $width = $max_width; $height = (int)round( $max_width / $src_ratio ); } else { $width = (int)round( $max_height * $src_ratio ); $height = $max_height; } return array( $width, $height ); } /** * Scale dimensions to fit into a constrained size, while preserving aspect ratio. * The scaling only happens if the source is larger than the constraint. * * @param integer source width * @param integer source height * @param integer constrained width * @param integer constrained height */ function fit_into_constraint( $src_width, $src_height, $max_width, $max_height ) { if( $src_width > $max_width || $src_height > $max_height ) { return scale_to_constraint( $src_width, $src_height, $max_width, $max_height ); } return array( $src_width, $src_height ); } /** * Load an image from a file into memory * * @param string pathname of image file * @param string * @return array resource image handle or NULL */ function load_image( $path, $mimetype ) { // yabs> GD library uses shedloads of memory // fp> 256M is way too high to sneak this in here. There should be some checks in the systems page to warn against low memory conditions. Also i'm not sure it makes sense to bump memory just for images. If you allow memory you might as well allow it for anything. Anyways, this is too much to be snuk in. // @ini_set('memory_limit', '256M'); // artificially inflate memory if we can $err = NULL; $imh = NULL; $function = NULL; $image_info = getimagesize($path); if( ! $image_info || $image_info['mime'] != $mimetype ) { $FiletypeCache = get_Cache('FiletypeCache'); $correct_Filetype = $FiletypeCache->get_by_mimetype($image_info['mime']); $correct_extension = array_shift($correct_Filetype->get_extensions()); $path_info = pathinfo($path); $wrong_extension = $path_info['extension']; $err = '!'.$correct_extension.' extension mismatch: use .'.$correct_extension.' instead of .'.$wrong_extension; } else { $mime_function = array( 'image/jpeg' => 'imagecreatefromjpeg', 'image/gif' => 'imagecreatefromgif', 'image/png' => 'imagecreatefrompng', ); if( isset($mime_function[$mimetype]) ) { $function = $mime_function[$mimetype]; } else { // Unrecognized mime type $err = '!Unsupported format '.$mimetype.' (load_image)'; } } //pre_dump( $function ); if( $function ) { // Call GD built-in function to load image // fp> Note: sometimes this GD call will die and there is no real way to recover :/ $imh = $function( $path ); } if( $imh === false ) { trigger_error( 'load_image failed: '.$path.' / '.$mimetype ); // DEBUG // e.g. "imagecreatefromjpeg(): $FILE is not a valid JPEG file" $err = '!load_image failed (no valid image?)'; } if( $err ) { error_log( 'load_image failed: '.substr($err, 1).' ('.$path.' / '.$mimetype.')' ); } return array( $err, $imh ); } /** * Output an image from memory to web client * * @param resource image handle * @param string pathname of image file * @param string * @param integer * @param string permissions * @return string */ function save_image( $imh, $path, $mimetype, $quality = 90, $chmod = NULL ) { $err = NULL; switch( $mimetype ) { case 'image/jpeg': $r = @imagejpeg( $imh, $path, $quality ); break; case 'image/gif': $r = @imagegif( $imh, $path ); break; case 'image/png': $r = @imagepng( $imh, $path ); break; default: // Unrecognized mime type $err = '!Unsupported format '.$mimetype.' (save_image)'; break; } // Catch any errors by image* functions: if( ! $r ) { // TODO: dh> This might become a generic function, since it's useful. Something similar is used in DB, too. if( isset($php_errormsg) ) $err = '!'.$php_errormsg; elseif( function_exists('error_get_last') ) // PHP 5.2 { $err = error_get_last(); $err = '!'.$err['message']; } if( ! isset($err) ) $err = '!Unknown error in save_image().'; } if( empty( $err ) ) { // Make sure the file has the default permissions we want: if( $chmod === NULL ) { global $Settings; $chmod = $Settings->get('fm_default_chmod_file'); } chmod( $path, octdec( $chmod ) ); } return $err; } /** * Output an image from memory to web client * * @param resource image handle * @param string * @return string */ function output_image( $imh, $mimetype ) { $err = NULL; switch( $mimetype ) { case 'image/jpeg': header('Content-type: '.$mimetype ); imagejpeg( $imh ); break; case 'image/gif': header('Content-type: '.$mimetype ); imagegif( $imh ); break; default: // Unrecognized mime type $err = 'Emime'; // Sort error code break; } return $err; } /** * Generate a thumbnail * * @param resource Image resource * @param string Thumbnail type ('crop'|'fit') * @param int Thumbnail width * @param int Thumbnail height * @return array short error code + dest image handler */ function generate_thumb( $src_imh, $thumb_type, $thumb_width, $thumb_height ) { $src_width = imagesx( $src_imh ) ; $src_height = imagesy( $src_imh ); if( $src_width <= $thumb_width && $src_height <= $thumb_height ) { // There is no need to resample, use original! return array( NULL, $src_imh ); } switch( $thumb_type ) { case 'crop': list( $src_x, $src_y, $src_width, $src_height) = crop_to_constraint( $src_width, $src_height, $thumb_width, $thumb_height ); $dest_width = $thumb_width; $dest_height = $thumb_height; break; case 'fit': default: list( $dest_width, $dest_height ) = scale_to_constraint( $src_width, $src_height, $thumb_width, $thumb_height ); $src_x = $src_y = 0; } // pre_dump( $src_x, $src_y, $dest_width, $dest_height, $src_width, $src_height ); // Create a transparent image: $dest_imh = imagecreatetruecolor( $dest_width, $dest_height ); imagealphablending($dest_imh, true); imagefill($dest_imh, 0, 0, imagecolortransparent($dest_imh, imagecolorallocatealpha($dest_imh, 0, 0, 0, 127))); imagesavealpha($dest_imh, true); if( ! imagecopyresampled( $dest_imh, $src_imh, 0, 0, $src_x, $src_y, $dest_width, $dest_height, $src_width, $src_height ) ) { return array( '!GD-library internal error (resample)', $dest_imh ); } // TODO: imageinterlace(); return array( NULL, $dest_imh ); } /* * $Log: _image.funcs.php,v $ */ ?>