egroupware/phpgwapi/js/htmlarea/plugins/UploadImage/popups/ImageEditor/NetPBM.php
2004-04-21 20:43:23 +00:00

255 lines
8.0 KiB
PHP
Executable File

<?php
/***********************************************************************
** Title.........: NetPBM Driver
** Version.......: 1.0
** Author........: Xiang Wei ZHUO <wei@zhuo.org>
** Filename......: NetPBM.php
** Last changed..: 30 Aug 2003
** Notes.........: Orginal is from PEAR
**/
// +----------------------------------------------------------------------+
// | PHP Version 4 |
// +----------------------------------------------------------------------+
// | Copyright (c) 1997-2002 The PHP Group |
// +----------------------------------------------------------------------+
// | This source file is subject to version 2.02 of the PHP license, |
// | that is bundled with this package in the file LICENSE, and is |
// | available at through the world-wide-web at |
// | http://www.php.net/license/2_02.txt. |
// | If you did not receive a copy of the PHP license and are unable to |
// | obtain it through the world-wide-web, please send a note to |
// | license@php.net so we can mail you a copy immediately. |
// +----------------------------------------------------------------------+
// | Authors: Peter Bowyer <peter@mapledesign.co.uk> |
// +----------------------------------------------------------------------+
//
// $Id$
//
// Image Transformation interface using command line NetPBM
require_once "Transform.php";
Class Image_Transform_Driver_NetPBM extends Image_Transform
{
/**
* associative array commands to be executed
* @var array
*/
var $command = array();
/**
* Class Constructor
*/
function Image_Transform_Driver_NetPBM()
{
$this->uid = md5($_SERVER['REMOTE_ADDR']);
return true;
} // End function Image_NetPBM
/**
* Load image
*
* @param string filename
*
* @return mixed none or a PEAR error object on error
* @see PEAR::isError()
*/
function load($image)
{
//echo $image;
$this->image = $image;
$this->_get_image_details($image);
} // End load
/**
* Resizes the image
*
* @return none
* @see PEAR::isError()
*/
function _resize($new_x, $new_y)
{
// there's no technical reason why resize can't be called multiple
// times...it's just silly to do so
$this->command[] = IMAGE_TRANSFORM_LIB_PATH .
"pnmscale -width $new_x -height $new_y";
$this->_set_new_x($new_x);
$this->_set_new_y($new_y);
} // End resize
/**
* Crop the image
*
* @param int $crop_x left column of the image
* @param int $crop_y top row of the image
* @param int $crop_width new cropped image width
* @param int $crop_height new cropped image height
*/
function crop($crop_x, $crop_y, $crop_width, $crop_height)
{
$this->command[] = IMAGE_TRANSFORM_LIB_PATH .
"pnmcut -left $crop_x -top $crop_y -width $crop_width -height $crop_height";
}
/**
* Rotates the image
*
* @param int $angle The angle to rotate the image through
*/
function rotate($angle)
{
$angle = -1*floatval($angle);
if($angle > 90)
{
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "pnmrotate -noantialias 90";
$this->rotate(-1*($angle-90));
}
else if ($angle < -90)
{
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "pnmrotate -noantialias -90";
$this->rotate(-1*($angle+90));
}
else
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "pnmrotate -noantialias $angle";
} // End rotate
/**
* Flip the image horizontally or vertically
*
* @param boolean $horizontal true if horizontal flip, vertical otherwise
*/
function flip($horizontal)
{
if($horizontal)
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "pnmflip -lr";
else
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "pnmflip -tb";
}
/**
* Adjust the image gamma
*
* @param float $outputgamma
*
* @return none
*/
function gamma($outputgamma = 1.0) {
$this->command[13] = IMAGE_TRANSFORM_LIB_PATH . "pnmgamma $outputgamma";
}
/**
* adds text to an image
*
* @param array options Array contains options
* array(
* 'text' // The string to draw
* 'x' // Horizontal position
* 'y' // Vertical Position
* 'Color' // Font color
* 'font' // Font to be used
* 'size' // Size of the fonts in pixel
* 'resize_first' // Tell if the image has to be resized
* // before drawing the text
* )
*
* @return none
*/
function addText($params)
{
$default_params = array('text' => 'This is Text',
'x' => 10,
'y' => 20,
'color' => 'red',
'font' => 'Arial.ttf',
'size' => '12',
'angle' => 0,
'resize_first' => false);
// we ignore 'resize_first' since the more logical approach would be
// for the user to just call $this->_resize() _first_ ;)
extract(array_merge($default_params, $params));
$this->command[] = "ppmlabel -angle $angle -colour $color -size "
."$size -x $x -y ".$y+$size." -text \"$text\"";
} // End addText
function _postProcess($type, $quality, $save_type)
{
$type = is_null($type) || $type==''? $this->type : $type;
$save_type = is_null($save_type) || $save_type==''? $this->type : $save_type;
//echo "TYPE:". $this->type;
array_unshift($this->command, IMAGE_TRANSFORM_LIB_PATH
. $type.'topnm '. $this->image);
$arg = '';
switch(strtolower($save_type)){
case 'gif':
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "ppmquant 256";
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "ppmto$save_type";
break;
case 'jpg':
case 'jpeg':
$arg = "--quality=$quality";
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "ppmto$save_type $arg";
break;
default:
$this->command[] = IMAGE_TRANSFORM_LIB_PATH . "pnmto$save_type $arg";
break;
} // switch
return implode('|', $this->command);
}
/**
* Save the image file
*
* @param $filename string the name of the file to write to
* @param string $type (jpeg,png...);
* @param int $quality 75
* @return none
*/
function save($filename, $type=null, $quality = 85)
{
$cmd = $this->_postProcess('', $quality, $type) . ">$filename";
//If you are using windows, you need the following line.
//$cmd = ereg_replace('/','\\',$cmd);
//echo $cmd."##";
system($cmd);
$this->command = array();
} // End save
/**
* Display image without saving and lose changes
*
* @param string $type (jpeg,png...);
* @param int $quality 75
* @return none
*/
function display($type = null, $quality = 75)
{
header('Content-type: image/' . $type);
$cmd = $this->_postProcess($type, $quality);
passthru($cmd);
$this->command = array();
}
/**
* Destroy image handle
*
* @return none
*/
function free()
{
// there is no image handle here
return true;
}
} // End class ImageIM
?>