phpimageeditor 修改后自用

6 篇文章 0 订阅
2 篇文章 0 订阅
下载组件phpimageeditor;

$ vim phpimageeditor/lite/shared/classes/phpimageeditor.php
覆盖

<?php

class PHPImageEditor {

var $srcEdit = "";
var $name = "";
var $srcOriginal = "";
var $srcPng = "";
var $srcWorkWith = "";
var $urlWorkWith = "";
var $resourceWorkWith = false;
var $mimeType = "";
var $actionSaveAndClose = "save";
var $actionRotateLeft = "rotate:90";
var $actionRotateRight = "rotate:-90";
var $actionGrayscale = "grayscale";
var $actionContrast = "contrast";
var $actionBrightness = "brightness";
var $actionUndo = "undo";
var $actionUpdate = "update";
var $actionRotateIsSelected = false;
var $actionRotate = "";
var $actionSeparatorSign = "#";
var $fieldNameKeepProportions = "keepproportions";
var $errorMessages = array();
var $formName = "phpimageeditor";
var $inputWidth = -1;
var $inputHeight = -1;
var $inputCropLeft = 0;
var $inputCropRight = 0;
var $inputCropTop = 0;
var $inputCropBottom = 0;
var $inputKeepProportions = true;
var $inputCropKeepProportions = false;
var $inputCropKeepProportionsRatio = 1;
var $inputPanel = PIE_START_PANEL;
var $inputLanguage = PIE_DEFAULT_LANGUAGE;
var $inputContrast = 0;
var $inputBrightness = 0;
var $inputContrastLast = 0;
var $inputBrightnessLast = 0;
var $inputGrayscale = false;
var $httpImageKey = "imagesrc";
var $texts = array();
var $actions = "";
var $isPostBack = false;
var $isAjaxPost = false;
var $finalWidth = -1;
var $finalHeight = -1;
var $widthKeepProportions = -1;
var $heightKeepProportions = -1;
var $userId = "";
var $fonts = array();
var $doSave = false;
var $contrastMax = 100;
var $brightnessMax = 255;
// var $photoInfo = array();


function PHPImageEditor() {
$this->LoadLanguage();

if (version_compare(phpversion(), PIE_PHP_VERSION_MINIMUM, "<")) {
$this->errorMessages[] = phpversion() . " " . $this->texts["OLD PHP VERSION"] . " " . PIE_PHP_VERSION_MINIMUM;
return;
}

$this->isPostBack = isset($_POST["actiontype"]);

$srcEdit = "";

if ($_GET[$this->httpImageKey] != NULL) {
$l = DIRECTORY_SEPARATOR;
$file = dirname(dirname(dirname(dirname(__FILE__)))) . "{$l}tmp{$l}{$_GET[$this->httpImageKey]}";
#$srcEdit = strip_tags($_GET[$this->httpImageKey]);
$srcEdit = strip_tags($file);
}

if ($srcEdit == "") {
$this->errorMessages[] = $this->texts["NO PROVIDED IMAGE"];
return;
}

$this->srcEdit = urldecode($srcEdit);

if (isset($_POST["userid"]))
$this->userId = $_POST["userid"];
else {
$this->userId = "_" . str_replace(".", "_", $_SERVER['REMOTE_ADDR']);

#In my Virtual box in Windows Vista I'll get :: as ip.
#Remove it to avoid errors.
$this->userId = str_replace("_::", "", $this->userId);
}

$this->SetSrcOriginal();
$this->SetSrcPng();
$this->SetSrcWorkWith();

if (!file_exists($this->srcEdit)) {
$this->errorMessages[] = $this->texts["IMAGE DOES NOT EXIST"];
return;
}

$info = getimagesize($this->srcEdit);

if (!$info) {
$this->errorMessages[] = $this->texts["INVALID IMAGE TYPE"];
return;
}

$this->mimeType = image_type_to_mime_type($info[2]);
// echo image_type_to_mime_type($info[2])."===".image_type_to_mime_type(IMAGETYPE_JPEG);exit;
if ($this->mimeType == image_type_to_mime_type(IMAGETYPE_JPEG) || $this->mimeType == image_type_to_mime_type(IMAGETYPE_GIF) || $this->mimeType == image_type_to_mime_type(IMAGETYPE_PNG)) {
if (!$this->isPostBack)
$this->SaveOriginal();

$this->resourceWorkWith = $this->CreateImage($this->srcOriginal);
$this->SavePng();
copy($this->srcPng, $this->srcWorkWith);

$this->resourceWorkWith = $this->CreateImage($this->srcPng);
}
else {
$this->errorMessages[] = $this->texts["INVALID IMAGE TYPE"];
return;
}

$this->finalWidth = $this->GetWidth();
$this->finalHeight = $this->GetHeight();
$this->widthKeepProportions = $this->GetWidth();
$this->heightKeepProportions = $this->GetHeight();
// $this->photoInfo = $this->GetUserData();

if ($this->isPostBack) {
$this->actionRotateIsSelected = (strip_tags($_POST["rotate"]) != "-1");
$this->actionRotate = strip_tags($_POST["rotate"]);
$this->actions = strip_tags($_POST["actions"]);
$this->isAjaxPost = (strip_tags($_POST["isajaxpost"]) == "true");
$this->inputWidth = (int) strip_tags($_POST["width"]);
$this->inputHeight = (int) strip_tags($_POST["height"]);
$this->inputCropLeft = (int) strip_tags($_POST["cropleft"]);
$this->inputCropRight = (int) strip_tags($_POST["cropright"]);
$this->inputCropTop = (int) strip_tags($_POST["croptop"]);
$this->inputCropBottom = (int) strip_tags($_POST["cropbottom"]);
$this->inputPanel = (int) strip_tags($_POST["panel"]);
$this->inputLanguage = strip_tags($_POST["language"]);
$this->inputKeepProportions = (strip_tags($_POST["keepproportionsval"]) == "1");
$this->inputCropKeepProportions = (strip_tags($_POST["cropkeepproportionsval"]) == "1");
$this->inputCropKeepProportionsRatio = (float) strip_tags($_POST["cropkeepproportionsratio"]);
$this->inputGrayscale = (strip_tags($_POST["grayscaleval"]) == "1");
$this->inputBrightness = (int) strip_tags($_POST["brightness"]);
$this->inputContrast = (int) strip_tags($_POST["contrast"]);
$this->inputBrightnessLast = (int) strip_tags($_POST["brightnesslast"]);
$this->inputContrastLast = (int) strip_tags($_POST["contrastlast"]);

$this->Action(strip_tags($_POST["actiontype"]));
}
}

function LoadLanguage() {
$language = "";

if (isset($_POST["language"])) {
$this->inputLanguage = $_POST["language"];
$language = $this->inputLanguage;
} else if (isset($_GET["language"])) {
$this->inputLanguage = $_GET["language"];
$language = $this->inputLanguage;
} else
$language = PIE_DEFAULT_LANGUAGE;

$tryLanguage = "language/" . $language . ".ini";
if (file_exists($tryLanguage))
$this->texts = PIE_GetTexts("language/" . $language . ".ini");
else
$this->texts = PIE_GetTexts("language/" . PIE_DEFAULT_LANGUAGE . ".ini");

//Load the texts that not exists in the current langugare from english.
$texts = PIE_GetTexts("language/en-GB.ini");

foreach ($texts as $key => $text) {
if (array_key_exists($key, $this->texts) === false)
$this->texts[$key] = $text;
}
}

function SetSrcOriginal() {
$arr = explode("/", $this->srcEdit);
$this->srcOriginal = PIE_IMAGE_ORIGINAL_PATH . $this->AddUserIdToImageSrc($arr[count($arr) - 1]);
}

function SetSrcWorkWith() {
$arr = explode("/", $this->srcEdit);
$srcWorkWith = PIE_IMAGE_WORK_WITH_PATH . $this->AddUserIdToImageSrc($arr[count($arr) - 1]);
$srcWorkWith = substr($srcWorkWith, 0, strripos($srcWorkWith, ".")) . ".png";
$this->srcWorkWith = $srcWorkWith;
// $this->urlWorkWith = $this->isAjaxPost && $_POST['actiontype'] == $this->actionSaveAndClose
// ? "http://".str_replace(DIRECTORY_SEPARATOR,"/",str_replace(DOC_ROOT,$_SERVER['SERVER_NAME'],$this->srcEdit))
// : "http://".str_replace(DIRECTORY_SEPARATOR,"/",str_replace(DOC_ROOT,$_SERVER['SERVER_NAME'],$srcWorkWith))
// ;
if ($_POST['actiontype'] == $this->actionSaveAndClose) {
$this->urlWorkWith = "http://" . str_replace(DIRECTORY_SEPARATOR, "/", str_replace(DOC_ROOT, $_SERVER['SERVER_NAME'], $this->srcEdit));
# echo "Ajax:{$this->urlWorkWith}";
} else {
$this->urlWorkWith = "http://" . str_replace(DIRECTORY_SEPARATOR, "/", str_replace(DOC_ROOT, $_SERVER['SERVER_NAME'], $srcWorkWith));
# echo "noAjax:{$this->urlWorkWith}";
}
}

function SetSrcPng() {
$arr = explode("/", $this->srcEdit);
$srcPng = PIE_IMAGE_PNG_PATH . $this->AddUserIdToImageSrc($arr[count($arr) - 1]);
$srcPng = substr($srcPng, 0, strripos($srcPng, ".")) . ".png";
$this->srcPng = $srcPng;
}

function SaveOriginal() {
copy($this->srcEdit, $this->srcOriginal);
#Resize to fit in max width/height.
$imageTmp = $this->CreateImage($this->srcOriginal);
$finalWidth = $this->GetWidthFromImage($imageTmp);
$finalHeight = $this->GetHeightFromImage($imageTmp);

$doSave = false;

if ($finalWidth > PIE_IMAGE_MAX_WIDTH) {
$widthProp = PIE_IMAGE_MAX_WIDTH / $finalWidth;
$finalWidth = PIE_IMAGE_MAX_WIDTH;
$finalHeight = round($finalHeight * $widthProp);
$doSave = true;
}

if ($finalHeight > PIE_IMAGE_MAX_HEIGHT) {
$heightProp = PIE_IMAGE_MAX_HEIGHT / $finalHeight;
$finalHeight = PIE_IMAGE_MAX_HEIGHT;
$finalWidth = round($finalWidth * $heightProp);
$doSave = true;
}

if ($doSave) {
$imageTmp = $this->ActionResize($finalWidth, $finalHeight, $imageTmp);
$this->SaveImage($imageTmp, $this->srcOriginal);
}
}

function SavePng() {
$this->SaveImage($this->resourceWorkWith, $this->srcPng, image_type_to_mime_type(IMAGETYPE_PNG));
}

function ErrorHasOccurred() {
return (count($this->errorMessages) > 0);
}

function GetWidthFinal() {
return $this->finalWidth;
}

function GetHeightFinal() {
return $this->finalHeight;
}

function GetWidth() {
return $this->GetWidthFromImage($this->resourceWorkWith);
}

function GetWidthLast() {
if ($this->isPostBack)
return (int) $_POST["widthlast"];

return $this->GetWidth();
}

function GetHeight() {
return $this->GetHeightFromImage($this->resourceWorkWith);
}

function GetHeightLast() {
if ($this->isPostBack)
return (int) $_POST["heightlast"];

return $this->GetWidth();
}

function GetWidthFromImage($image) {
return imagesx($image);
}

function GetHeightFromImage($image) {
return imagesy($image);
}

function Action($actionType) {
$this->doSave = false;

if ($actionType == $this->actionUndo) {
$this->ActionUndo();
$this->doSave = true;
}

if ($actionType == $this->actionUpdate || $actionType == $this->actionSaveAndClose) {
if ($this->inputWidth != $this->GetWidthLast() || $this->inputHeight != $this->GetHeightLast())
$this->actions .= $this->GetActionSeparator() . "resize:" . $this->inputWidth . "," . $this->inputHeight;

if ($this->inputCropLeft != 0 || $this->inputCropRight != 0 || $this->inputCropTop != 0 || $this->inputCropBottom != 0)
$this->actions .= $this->GetActionSeparator() . "crop:" . $this->inputCropLeft . "," . $this->inputCropRight . "," . $this->inputCropTop . "," . $this->inputCropBottom;

$this->doSave = true;
}

if ($actionType == $this->actionUpdate && $this->inputGrayscale) {
if (strpos($this->actions, $this->actionGrayscale) === false) {
$this->actions .= $this->GetActionSeparator() . $this->actionGrayscale . ":0";
$this->doSave = true;
}
} else if ($actionType == $this->actionUpdate && !$this->inputGrayscale) {
if (!(strpos($this->actions, $this->actionGrayscale) === false)) {
$this->actions = str_replace($this->actionGrayscale . ":0" . $this->GetActionSeparator(), "", $this->actions);
$this->actions = str_replace($this->GetActionSeparator() . $this->actionGrayscale . ":0", "", $this->actions);
$this->actions = str_replace($this->actionGrayscale . ":0", "", $this->actions);
$this->doSave = true;
}
}

if ($this->inputContrast != $this->inputContrastLast) {
$this->actions .= $this->GetActionSeparator() . $this->actionContrast . ":" . $this->inputContrast;
$this->doSave = true;
}

if ($this->inputBrightness != $this->inputBrightnessLast) {
$this->actions .= $this->GetActionSeparator() . $this->actionBrightness . ":" . $this->inputBrightness;
$this->doSave = true;
}

if ($this->actionRotateIsSelected) {
if ($this->actionRotate == $this->actionRotateLeft) {
$this->actions .= $this->GetActionSeparator() . $this->actionRotateLeft;
$this->doSave = true;
} else if ($this->actionRotate == $this->actionRotateRight) {
$this->actions .= $this->GetActionSeparator() . $this->actionRotateRight;
$this->doSave = true;
}
}

$finalContrast = 0;
$finalBrightness = 0;
$finalContrastFound = false;
$finalBrightnessFound = false;
$finalGrayscale = false;

if ($this->doSave && $this->actions != "") {
$allActions = explode($this->actionSeparatorSign, $this->actions);

$finalRotate = 0;
$finalCropLeft = 0;
$finalCropRight = 0;
$finalCropTop = 0;
$finalCropBottom = 0;

$doSwitch = false;

foreach ($allActions as $loopAction) {
$actionDetail = explode(":", $loopAction);
$actionValues = explode(",", $actionDetail[1]);

if ($actionDetail[0] == "resize") {
$this->finalWidth = (int) $actionValues[0];
$this->finalHeight = (int) $actionValues[1];
} else if ($actionDetail[0] == "crop") {
$actionValueLeft = (int) $actionValues[0];
$actionValueRight = (int) $actionValues[1];
$actionValueTop = (int) $actionValues[2];
$actionValueBottom = (int) $actionValues[3];

$widthProp = 1;
$heightProp = 1;

if ($doSwitch) {
$widthProp = (($this->GetHeight() - ($finalCropTop + $finalCropBottom)) / $this->finalWidth);
$heightProp = (($this->GetWidth() - ($finalCropLeft + $finalCropRight)) / $this->finalHeight);
} else {
$widthProp = (($this->GetWidth() - ($finalCropLeft + $finalCropRight)) / $this->finalWidth);
$heightProp = (($this->GetHeight() - ($finalCropTop + $finalCropBottom)) / $this->finalHeight);
}

$cropLeft = $actionValueLeft * $widthProp;
$cropRight = $actionValueRight * $widthProp;
$cropTop = $actionValueTop * $heightProp;
$cropBottom = $actionValueBottom * $heightProp;

$cropValues = array();
$cropValues[] = $cropRight;
$cropValues[] = $cropBottom;
$cropValues[] = $cropLeft;
$cropValues[] = $cropTop;

if ($finalRotate != 0)
$cropValues = $this->RotateArray(($finalRotate / -90), $cropValues);

$finalCropRight += $cropValues[0];
$finalCropBottom += $cropValues[1];
$finalCropLeft += $cropValues[2];
$finalCropTop += $cropValues[3];

$this->finalWidth -= ($actionValueLeft + $actionValueRight);
$this->finalHeight -= ($actionValueTop + $actionValueBottom);
}
else if ($actionDetail[0] == $this->actionGrayscale && $this->inputGrayscale) {
$finalGrayscale = true;
} else if ($actionDetail[0] == "contrast") {
$finalContrastFound = true;
$finalContrast = $actionValues[0];
} else if ($actionDetail[0] == "brightness") {
$finalBrightnessFound = true;
$finalBrightness = $actionValues[0];
} else if ($actionDetail[0] == "rotate") {
$finalRotate += (int) $actionValues[0];
$finalWidthTmp = $this->finalWidth;
$this->finalWidth = $this->finalHeight;
$this->finalHeight = $finalWidthTmp;
}

if ($finalRotate == -360 || $finalRotate == 360)
$finalRotate = 0;

$doSwitch = ($finalRotate != 0 && ($finalRotate == 90 || $finalRotate == 270 || $finalRotate == -90 || $finalRotate == -270));
}

//1. All effects.
if ($finalGrayscale)
$this->ActionGrayscale();

if ($finalBrightnessFound)
$this->ActionBrightness($finalBrightness);

if ($finalContrastFound)
$this->ActionContrast($finalContrast * -1);

//2. Do cropping.
$finalCropLeft = round($finalCropLeft);
$finalCropRight = round($finalCropRight);
$finalCropTop = round($finalCropTop);
$finalCropBottom = round($finalCropBottom);
if ($finalCropLeft != 0 || $finalCropRight != 0 || $finalCropTop != 0 || $finalCropBottom != 0)
$this->ActionCrop($finalCropLeft, $finalCropRight, $finalCropTop, $finalCropBottom);

//3. Rotate
if ($finalRotate != 0)
$this->ActionRotate($finalRotate);

//Calculate keep proportions values.
if (round($this->finalWidth / $this->finalHeight, 1) == round($this->GetWidth() / $this->GetHeight(), 1)) {
//It seems to have the same proportions as the original. Use the original proportions value.
$this->widthKeepProportions = $this->GetWidth();
$this->heightKeepProportions = $this->GetHeight();
} else {
//The proportions has been changed. Use the new width and height instead.
$this->widthKeepProportions = $this->finalWidth;
$this->heightKeepProportions = $this->finalHeight;
}

//4. Resize
if ($this->finalWidth > 0 && $this->finalHeight > 0)
$this->resourceWorkWith = $this->ActionResize($this->finalWidth, $this->finalHeight, $this->resourceWorkWith);

$this->SaveImage($this->resourceWorkWith, $this->srcWorkWith, image_type_to_mime_type(IMAGETYPE_PNG));
}

$this->inputBrightness = $finalBrightness;
$this->inputContrast = $finalContrast;
$this->inputGrayscale = $finalGrayscale;

if ($actionType == $this->actionSaveAndClose) {
$this->SaveImage($this->resourceWorkWith, $this->srcEdit, $this->mimeType);
unlink($this->srcOriginal);
unlink($this->srcPng);
unlink($this->srcWorkWith);
PIE_DeleteOldImages(PIE_IMAGE_ORIGINAL_PATH);
PIE_DeleteOldImages(PIE_IMAGE_PNG_PATH);
PIE_DeleteOldImages(PIE_IMAGE_WORK_WITH_PATH);
$reloadParentBrowser = PIE_RELOAD_PARENT_BROWSER_ON_SAVE ? 'window.opener.location.reload();' : '';
// PIE_Echo('<script language="javascript" type="text/javascript">'.$reloadParentBrowser.'window.open(\'\',\'_parent\',\'\');window.close();</script>');
}
}

function ActionResize($width, $height, $image) {
$newImage = @imagecreatetruecolor($width, $height);

PIE_KeepTranspacecyCopyResampled($newImage, $this->mimeType);

imagecopyresampled($newImage, $image, 0, 0, 0, 0, $width, $height, $this->GetWidthFromImage($image), $this->GetHeightFromImage($image));
return $newImage;
}

function ActionCrop($cropLeft, $cropRight, $cropTop, $cropBottom) {
$cropWidth = $this->GetWidth() - $cropLeft - $cropRight;
$cropHeight = $this->GetHeight() - $cropTop - $cropBottom;

$newImageCropped = @imagecreatetruecolor($cropWidth, $cropHeight);

PIE_KeepTranspacecyCopyResampled($newImageCropped, $this->mimeType);

//imagecopy($newImageCropped, $this->resourceWorkWith, 0, 0, $cropLeft, $cropTop, $cropWidth, $cropHeight);
imagecopyresampled($newImageCropped, $this->resourceWorkWith, 0, 0, $cropLeft, $cropTop, $cropWidth, $cropHeight, $cropWidth, $cropHeight);

$this->resourceWorkWith = $newImageCropped;
}

function ActionUndo() {
$separatorPos = strrpos($this->actions, $this->actionSeparatorSign);
if (!($separatorPos === false)) {
$this->actions = substr($this->actions, 0, $separatorPos);
} else {
$this->actions = "";
}
}

function CreateImage($srcEdit) {
$info = getimagesize($srcEdit);

if (!$info)
return NULL;

$mimeType = image_type_to_mime_type($info[2]);

if ($mimeType == image_type_to_mime_type(IMAGETYPE_JPEG)) {
return imagecreatefromjpeg($srcEdit);
} else if ($mimeType == image_type_to_mime_type(IMAGETYPE_GIF)) {
return imagecreatefromgif($srcEdit);
} else if ($mimeType == image_type_to_mime_type(IMAGETYPE_PNG)) {
return imagecreatefrompng($srcEdit);
}

return NULL;
}

function ActionRotate($Degrees) {
if (function_exists('imagerotate'))
$this->resourceWorkWith = imagerotate($this->resourceWorkWith, $Degrees, 0);
else
$this->resourceWorkWith = PIE_ImageRotate($this->resourceWorkWith, $Degrees);

if ($this->mimeType == image_type_to_mime_type(IMAGETYPE_GIF) || $this->mimeType == image_type_to_mime_type(IMAGETYPE_PNG)) {
//Keep transparecy
imagealphablending($this->resourceWorkWith, true);
imagesavealpha($this->resourceWorkWith, true);
}
}

function ActionGrayscale() {
if (function_exists('imagefilter'))
imagefilter($this->resourceWorkWith, IMG_FILTER_GRAYSCALE);
else
PIE_Grayscale($this->resourceWorkWith);
}

function ActionContrast($contrast) {
//-100 = max contrast, 0 = no change, +100 = min contrast
if (function_exists('imagefilter'))
imagefilter($this->resourceWorkWith, IMG_FILTER_CONTRAST, $contrast);
else
PIE_Contrast($this->resourceWorkWith, $contrast);
}

function ActionBrightness($light) {
//-255 = min brightness, 0 = no change, +255 = max brightness
if (function_exists('imagefilter'))
imagefilter($this->resourceWorkWith, IMG_FILTER_BRIGHTNESS, $light);
else
PIE_Brightness($this->resourceWorkWith, $light);
}

function GetErrorMessages() {
if (count($this->errorMessages)) {
PIE_Echo('<div class="error">');
PIE_Echo('<ul>');

foreach ($this->errorMessages as $errorMessage)
PIE_Echo('<li>' . $errorMessage . '</li>');

PIE_Echo("</ul>");
PIE_Echo('</div>');
}
}

function GetActions() {
PIE_Echo($this->actions);
}

function GetActionSeparator() {
if ($this->actions != "")
return $this->actionSeparatorSign;

return "";
}

function SaveImage($image, $toSrc, $mimeType = -1) {
if ($mimeType == -1)
$mimeType = $this->mimeType;

if ($mimeType == image_type_to_mime_type(IMAGETYPE_JPEG)) {
imagejpeg($image, $toSrc);
} else if ($mimeType == image_type_to_mime_type(IMAGETYPE_GIF)) {
imagegif($image, $toSrc);
} else if ($mimeType == image_type_to_mime_type(IMAGETYPE_PNG)) {
//Keep transparecy.
imagesavealpha($image, true);

imagepng($image, $toSrc);
}
}

function CleanUp() {
if ($this->resourceWorkWith)
imagedestroy($this->resourceWorkWith);
}

function RotateArray($numberOfSteps, $arr) {
$finalArray = array();

//-3 to 3
$finalArray[] = $arr[$this->NumberOfStepsCalculator($numberOfSteps + 0)];
$finalArray[] = $arr[$this->NumberOfStepsCalculator($numberOfSteps + 1)];
$finalArray[] = $arr[$this->NumberOfStepsCalculator($numberOfSteps + 2)];
$finalArray[] = $arr[$this->NumberOfStepsCalculator($numberOfSteps + 3)];

return $finalArray;
}

function NumberOfStepsCalculator($sum) {
$maxIndex = 3;
if ($sum > $maxIndex)
return ($sum - $maxIndex) - 1;
else if ($sum < 0) {
return ($sum + $maxIndex) + 1;
}

return $sum;
}

function AddUserIdToImageSrc($imageSrc) {
$name = end(explode(DIRECTORY_SEPARATOR, $imageSrc));
$this->name = $name;
$ext = end(explode('.', $name));
$p = strlen($ext) + 1;
$f = str_replace(substr($imageSrc, -$p), "{$this->userId}.{$ext}", $name);
return $f;
}

function GetFormAction() {
$joomlaIsAdmin = isset($_GET['isadmin']) ? 'isadmin=' . $_GET['isadmin'] . '&' : '';

#return "index.php?".$joomlaIsAdmin.$this->httpImageKey."=".urlencode($this->srcEdit);
return "index.php?" . $joomlaIsAdmin . $this->httpImageKey . "=" . urlencode($this->name);
}

function GetWidthKeepProportions() {
return $this->widthKeepProportions;
}

function GetHeightKeepProportions() {
return $this->heightKeepProportions;
}


$ vim phpimageeditor/lite/shared/index.php
覆盖:

<?php
ini_set('default_charset', 'utf-8');

header("Cache-Control: no-store");
header('content-type: text/html; charset: utf-8');
include 'lite/shared/config.php';
include 'lite/shared/includes/constants.php';
include 'lite/shared/includes/functions.php';
include 'lite/shared/classes/phpimageeditor.php';
global $objPHPImageEditor;
$objPHPImageEditor = new PHPImageEditor();

if (!$objPHPImageEditor->isAjaxPost) { ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>PHP Image Editor</title>
<script type="text/javascript" src="lite/shared/javascript/jquery-1.7.1.min.js"></script>
<script type="text/javascript" src="lite/shared/javascript/jquery.jcrop.js"></script>
<script type="text/javascript" src="lite/shared/javascript/jquery.numeric.js"></script>
<script type="text/javascript" src="lite/shared/javascript/jquery-ui-1.8.16.custom.min.js"></script>

<script type="text/javascript" src="lite/shared/javascript/phpimageeditor.js"></script>

<link rel="stylesheet" type="text/css" href="lite/shared/css/style.css"/>
<link rel="stylesheet" type="text/css" href="lite/shared/css/ui.resizable.css"/>
<link rel="stylesheet" type="text/css" href="lite/shared/css/ui.slider.css"/>
<link rel="stylesheet" type="text/css" href="lite/shared/css/jquery.jcrop.css?a=1"/>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<script type="text/javascript">
var ImageMaxWidth = <?php PIE_Echo(PIE_IMAGE_MAX_WIDTH); ?>;
var ImageMaxHeight = <?php PIE_Echo(PIE_IMAGE_MAX_HEIGHT); ?>;
var ImageWidth = <?php PIE_Echo($objPHPImageEditor->GetWidthFinal()); ?>;
var ImageHeight = <?php PIE_Echo($objPHPImageEditor->GetHeightFinal()); ?>;
var TextIsRequired = "<?php PIE_Echo($objPHPImageEditor->texts["IS REQUIRED"]); ?>";
var TextMustBeNumeric = "<?php PIE_Echo($objPHPImageEditor->texts["MUST BE NUMERIC"]); ?>";
var TextWidth = "<?php PIE_Echo($objPHPImageEditor->texts["WIDTH"]); ?>";
var TextHeight = "<?php PIE_Echo($objPHPImageEditor->texts["HEIGHT"]); ?>";
var TextNotNegative = "<?php PIE_Echo($objPHPImageEditor->texts["NOT NEGATIVE"]); ?>";
var TextNotInRange = "<?php PIE_Echo($objPHPImageEditor->texts["NOT IN RANGE"]); ?>";
var TextCantBeLargerThen = "<?php PIE_Echo($objPHPImageEditor->texts["CANT BE LARGER THEN"]); ?>";
var TextAnUnexpectedError = "<?php PIE_Echo($objPHPImageEditor->texts["AN UNEXPECTED ERROR"]); ?>";
var Brightness = <?php PIE_Echo($objPHPImageEditor->inputBrightness); ?>;
var Contrast = <?php PIE_Echo($objPHPImageEditor->inputContrast); ?>;
var BrightnessMax = <?php PIE_Echo($objPHPImageEditor->brightnessMax); ?>;
var ContrastMax = <?php PIE_Echo($objPHPImageEditor->contrastMax); ?>;
var FormAction = "<?php PIE_Echo($objPHPImageEditor->GetFormAction()); ?>";
var FormId = "<?php PIE_Echo($objPHPImageEditor->formName); ?>";
var ActionUpdate = "<?php PIE_Echo($objPHPImageEditor->actionUpdate); ?>";
var ActionUndo = "<?php PIE_Echo($objPHPImageEditor->actionUndo); ?>";
var ActionSaveAndClose = "<?php PIE_Echo($objPHPImageEditor->actionSaveAndClose); ?>";
var ActionRotateLeft = "<?php PIE_Echo($objPHPImageEditor->actionRotateLeft); ?>";
var ActionRotateRight = "<?php PIE_Echo($objPHPImageEditor->actionRotateRight); ?>";
var ActionSaveAndClose = "<?php PIE_Echo($objPHPImageEditor->actionSaveAndClose); ?>";
var MenuResize = "<?php PIE_Echo(PIE_MENU_RESIZE); ?>";
var MenuRotate = "<?php PIE_Echo(PIE_MENU_ROTATE); ?>";
var MenuCrop = "<?php PIE_Echo(PIE_MENU_CROP); ?>";
var MenuEffects = "<?php PIE_Echo(PIE_MENU_EFFECTS); ?>";
var AjaxPostTimeoutMs = <?php PIE_Echo(PIE_AJAX_POST_TIMEOUT_MS); ?>;
var tid = <?php echo $tid?>;
var pid = <?php echo $pid?>;
var uid = <?php echo $uid?>;
var imgName = "<?php echo $img?>";
var Pw = 375;
var Ph = 500;
</script>
</head>
<body>


<div id="phpImageEditor">
<?php } ?>

<form id="<?php PIE_Echo($objPHPImageEditor->formName); ?>" name="<?php PIE_Echo($objPHPImageEditor->formName); ?>" method="post" action="<?php PIE_Echo($objPHPImageEditor->GetFormAction()); ?>">
<?php if (!$objPHPImageEditor->ErrorHasOccurred()) { ?>

<div class="tabs">

<div id="menu">
<?php if (PIE_RESIZE_ENABLED) { ?>
<div class="<?php PIE_Echo($objPHPImageEditor->inputPanel == PIE_MENU_RESIZE ? 'selected' : 'not-selected'); ?>" id="menuitem_<?php PIE_Echo(PIE_MENU_RESIZE); ?>">
<h1><?php PIE_Echo($objPHPImageEditor->texts["RESIZE IMAGE"]); ?></h1>
</div>
<?php } ?>
<?php if (PIE_ROTATE_ENABLED) { ?>
<div class="<?php PIE_Echo($objPHPImageEditor->inputPanel == PIE_MENU_ROTATE ? 'selected' : 'not-selected'); ?>" id="menuitem_<?php PIE_Echo(PIE_MENU_ROTATE); ?>">
<h1><?php PIE_Echo($objPHPImageEditor->texts["ROTATE IMAGE"]); ?></h1>
</div>
<?php } ?>
<?php if (PIE_CROP_ENABLED) { ?>
<!-- <div class="<?php PIE_Echo($objPHPImageEditor->inputPanel == PIE_MENU_CROP ? 'selected' : 'not-selected'); ?>" id="menuitem_<?php PIE_Echo(PIE_MENU_CROP); ?>">
<h1><?php PIE_Echo($objPHPImageEditor->texts["CROP IMAGE"]); ?></h1>
</div>-->
<?php } ?>
<?php if (PIE_EFFECTS_ENABLED) { ?>
<div class="<?php PIE_Echo($objPHPImageEditor->inputPanel == PIE_MENU_EFFECTS ? 'selected' : 'not-selected'); ?>" id="menuitem_<?php PIE_Echo(PIE_MENU_EFFECTS); ?>">
<h1><?php PIE_Echo($objPHPImageEditor->texts["EFFECTS"]); ?></h1>
</div>
<?php } ?>
</div>

<div id="actionContainer">

<div id="panel_<?php PIE_Echo(PIE_MENU_RESIZE); ?>" class="panel">
<table cellpadding="0" cellspacing="0" border="0">
<tr>
<td>
<div class="field widthAndHeight">
<div class="col-1">
<label for="width"><?php PIE_Echo($objPHPImageEditor->texts["WIDTH"]); ?></label>
<input class="input-number" type="text" name="width" id="width" value="<?php PIE_Echo($objPHPImageEditor->GetWidthFinal()); ?>"/>
<input type="hidden" name="widthoriginal" id="widthoriginal" value="<?php PIE_Echo($objPHPImageEditor->GetWidth()); ?>"/>
</div>
<div class="col-2">
<label for="height"><?php PIE_Echo($objPHPImageEditor->texts["HEIGHT"]); ?></label>
<input class="input-number" type="text" name="height" id="height" value="<?php PIE_Echo($objPHPImageEditor->GetHeightFinal()); ?>"/>
<input type="hidden" name="heightoriginal" id="heightoriginal" value="<?php PIE_Echo($objPHPImageEditor->GetHeight()); ?>"/>
</div>
</div>
<div class="field">
<input class="checkbox" type="checkbox" name="<?php PIE_Echo($objPHPImageEditor->fieldNameKeepProportions); ?>" id="<?php PIE_Echo($objPHPImageEditor->fieldNameKeepProportions); ?>" <?php PIE_Echo($objPHPImageEditor->inputKeepProportions ? 'checked="checked"' : ''); ?>/>
<input type="hidden" name="keepproportionsval" id="keepproportionsval" value="<?php PIE_Echo($objPHPImageEditor->inputKeepProportions ? '1' : '0'); ?>"/>
<label for="<?php PIE_Echo($objPHPImageEditor->fieldNameKeepProportions); ?>" class="checkbox"><?php PIE_Echo($objPHPImageEditor->texts["KEEP PROPORTIONS"]); ?></label>
</div>
</td>
<td>
<div class="help" id="resizehelp">
<div class="help-header" id="resizehelpheader"><?php PIE_Echo($objPHPImageEditor->texts["INSTRUCTIONS"]); ?></div>
<div class="help-content" id="resizehelpcontent"><?php PIE_Echo($objPHPImageEditor->texts["RESIZE HELP"]); ?></div>
</div>
</td>
<td>
<div class="field">
排列序号:<input type="text" name="displayorder" id="picturedisplayorder" value="" οnblur="javascript:retry();" style="width:50px;height: 18px;"/>
<br/>
排列位置:<input type="radio" name="coverdisplayposition" value="1" checked />左
<input type="radio" name="coverdisplayposition" value="2" />右
<div>
</td>
<td>
<div class="help" id="kiddlynotice" style="display:none">
<div class="help-header" id="notice">温馨提示</div>
<div class="help-content" id="noticeinfo"></div>
</div>
</td>
</tr>
</table>
<div class="field">
<input class="input-number" type="hidden" name="croptop" id="croptop" value="0"/>
<input class="input-number" type="hidden" name="cropleft" id="cropleft" value="0"/>
<input class="input-number" type="hidden" name="cropright" id="cropright" value="0"/>
<input class="input-number" type="hidden" name="cropbottom" id="cropbottom" value="0"/>
<!-- <div class="help" id="crophelp">
<div class="help-header" id="crophelpheader"><?php PIE_Echo($objPHPImageEditor->texts["INSTRUCTIONS"]); ?></div>
<div class="help-content" id="crophelpcontent"><?php PIE_Echo($objPHPImageEditor->texts["CROP HELP"]); ?></div>
</div>-->
</div>
<div class="field crop-settings">
<div class="crop-top">
<?php PIE_Echo($objPHPImageEditor->texts["CROP WIDTH"]); ?>: <span id="cropwidth" style="display: none">0</span><input type="text" id="Pcropwidth" value="" style="width:50px;" />
<?php PIE_Echo($objPHPImageEditor->texts["CROP HEIGHT"]); ?>: <span id="cropheight" style="display: none">0</span><input type="text" id="Pcropheight" value="" style="width:50px;" />
</div>
<!--<input id="cropkeepproportions" class="checkbox" type="checkbox" name="cropkeepproportions" <?php PIE_Echo($objPHPImageEditor->inputCropKeepProportions ? 'checked="checked"' : ''); ?>/>-->
<!--<label class="checkbox" for="cropkeepproportions"><?php PIE_Echo($objPHPImageEditor->texts["CROP KEEP PROPORTIONS"]); ?></label>-->
<input id="cropkeepproportionsval" type="hidden" name="cropkeepproportionsval" value="<?php PIE_Echo($objPHPImageEditor->inputCropKeepProportions ? '1' : '0'); ?>"/>
<input id="cropkeepproportionsratio" type="hidden" name="cropkeepproportionsratio" value="<?php PIE_Echo($objPHPImageEditor->inputCropKeepProportionsRatio); ?>"/>
</div>
</div>

<div id="panel_<?php PIE_Echo(PIE_MENU_ROTATE); ?>" class="panel">
<div class="field">
<input id="btnRotateLeft" type="button" value="<?php PIE_Echo($objPHPImageEditor->texts["LEFT 90 DEGREES"]); ?>"/>
<input id="btnRotateRight" type="button" value="<?php PIE_Echo($objPHPImageEditor->texts["RIGHT 90 DEGREES"]); ?>"/>
<input type="hidden" name="rotate" id="rotate" value="-1"/>
</div>
</div>

<!-- <div id="panel_<?php PIE_Echo(PIE_MENU_CROP); ?>" class="panel">
<div class="field">
<input class="input-number" type="hidden" name="croptop" id="croptop" value="0"/>
<input class="input-number" type="hidden" name="cropleft" id="cropleft" value="0"/>
<input class="input-number" type="hidden" name="cropright" id="cropright" value="0"/>
<input class="input-number" type="hidden" name="cropbottom" id="cropbottom" value="0"/>
<div class="help" id="crophelp">
<div class="help-header" id="crophelpheader"><?php PIE_Echo($objPHPImageEditor->texts["INSTRUCTIONS"]); ?></div>
<div class="help-content" id="crophelpcontent"><?php PIE_Echo($objPHPImageEditor->texts["CROP HELP"]); ?></div>
</div>
</div>
<div class="field crop-settings">
<div class="crop-top">
<?php PIE_Echo($objPHPImageEditor->texts["CROP WIDTH"]); ?>: <span id="cropwidth">0</span>
<?php PIE_Echo($objPHPImageEditor->texts["CROP HEIGHT"]); ?>: <span id="cropheight">0</span>
</div>
<input id="cropkeepproportions" class="checkbox" type="checkbox" name="cropkeepproportions" <?php PIE_Echo($objPHPImageEditor->inputCropKeepProportions ? 'checked="checked"' : ''); ?>/>
<label class="checkbox" for="cropkeepproportions"><?php PIE_Echo($objPHPImageEditor->texts["CROP KEEP PROPORTIONS"]); ?></label>
<input id="cropkeepproportionsval" type="hidden" name="cropkeepproportionsval" value="<?php PIE_Echo($objPHPImageEditor->inputCropKeepProportions ? '1' : '0'); ?>"/>
<input id="cropkeepproportionsratio" type="hidden" name="cropkeepproportionsratio" value="<?php PIE_Echo($objPHPImageEditor->inputCropKeepProportionsRatio); ?>"/>
</div>
</div>-->
<div id="panel_<?php PIE_Echo(PIE_MENU_EFFECTS); ?>" class="panel">
<div class="field">
<label for="brightness"><?php PIE_Echo($objPHPImageEditor->texts["BRIGHTNESS"]); ?></label>
<div id="brightness_slider_track"></div>
</div>
<input type="hidden" name="brightness" id="brightness" value="<?php PIE_Echo($objPHPImageEditor->inputBrightness); ?>"/>
<div class="field">
<label for="contrast"><?php PIE_Echo($objPHPImageEditor->texts["CONTRAST"]); ?></label>
<div id="contrast_slider_track"></div>
</div>
<input type="hidden" name="contrast" id="contrast" value="<?php PIE_Echo($objPHPImageEditor->inputContrast); ?>"/>
<div class="field">
<input class="checkbox" type="checkbox" name="<?php PIE_Echo($objPHPImageEditor->actionGrayscale); ?>" id="<?php PIE_Echo($objPHPImageEditor->actionGrayscale); ?>" <?php PIE_Echo($objPHPImageEditor->inputGrayscale ? 'checked="checked"' : ''); ?>/>
<label for="<?php PIE_Echo($objPHPImageEditor->actionGrayscale); ?>" class="checkbox"><?php PIE_Echo($objPHPImageEditor->texts["GRAYSCALE"]); ?></label>
<input type="hidden" name="grayscaleval" id="grayscaleval" value="<?php PIE_Echo($objPHPImageEditor->inputGrayscale ? '1' : '0'); ?>"/>
</div>
</div>

<div id="loading" style="display: none;"><?php PIE_Echo($objPHPImageEditor->texts["LOADING"]); ?>...<div id="loading_bar" style="width: 0px;"></div></div>

</div>

<div class="main-actions">
<input type="button" id="btnupdate" name="btnupdate" value="<?php PIE_Echo($objPHPImageEditor->texts["UPDATE"]); ?>"/>
<input type="button" id="btnsave" name="btnsave" value="<?php PIE_Echo($objPHPImageEditor->texts["SAVE AND CLOSE"]); ?>"/>
<input type="button" <?php PIE_Echo($objPHPImageEditor->actions == "" ? 'disabled="disabled"' : ''); ?> id="btnundo" name="btnundo" value="<?php PIE_Echo($objPHPImageEditor->texts["UNDO"]); ?>"/>
    
<input type="button" id="uploadCoolyun" name="uploadCoolyun" value="uploadCoolyun"/>
</div>

</div>
<input type="hidden" name="actiontype" id="actiontype" value="<?php PIE_Echo($objPHPImageEditor->actionUpdate); ?>"/>
<input type="hidden" name="panel" id="panel" value="<?php PIE_Echo($objPHPImageEditor->inputPanel); ?>"/>
<input type="hidden" name="language" id="language" value="<?php PIE_Echo($objPHPImageEditor->inputLanguage); ?>"/>
<textarea name="actions" id="actions"><?php $objPHPImageEditor->GetActions(); ?></textarea>
<input type="hidden" name="widthlast" id="widthlast" value="<?php PIE_Echo($objPHPImageEditor->GetWidthFinal()); ?>"/>
<input type="hidden" name="heightlast" id="heightlast" value="<?php PIE_Echo($objPHPImageEditor->GetHeightFinal()); ?>"/>
<input type="hidden" name="widthlastbeforeresize" id="widthlastbeforeresize" value="<?php PIE_Echo($objPHPImageEditor->GetWidthKeepProportions()); ?>"/>
<input type="hidden" name="heightlastbeforeresize" id="heightlastbeforeresize" value="<?php PIE_Echo($objPHPImageEditor->GetHeightKeepProportions()); ?>"/>
<input type="hidden" name="userid" id="userid" value="<?php PIE_Echo($objPHPImageEditor->userId); ?>"/>
<input type="hidden" name="contrastlast" id="contrastlast" value="<?php PIE_Echo($objPHPImageEditor->inputContrast); ?>"/>
<input type="hidden" name="brightnesslast" id="brightnesslast" value="<?php PIE_Echo($objPHPImageEditor->inputBrightness); ?>"/>
<input type="hidden" name="isajaxpost" id="isajaxpost" value="false"/>
<?php } ?>
</form>
<?php $objPHPImageEditor->GetErrorMessages(); ?>
<div id="divJsErrors" class="error" style="display: none;">
<ul id="ulJsErrors" style="display: none;"><li></li></ul>
</div>
<div><img src="lite/shared/images/empty.gif" alt=""/></div>
<?php if (!$objPHPImageEditor->ErrorHasOccurred()) { ?>
<div id="editimage">
<img id="image"
style="position: absolute; left: 0px; top: 0px; width: <?php PIE_Echo($objPHPImageEditor->GetWidthFinal()); ?>px; height: <?php PIE_Echo($objPHPImageEditor->GetHeightFinal()); ?>px;"
alt=""
src="<?php PIE_Echo($objPHPImageEditor->urlWorkWith); ?>?timestamp=<?php PIE_Echo(time()); ?>"/>
<div id="imageResizerKeepProportions" style="diplay: <?php PIE_Echo(($objPHPImageEditor->inputKeepProportions && $objPHPImageEditor->inputPanel == PIE_MENU_RESIZE) ? 'block' : 'none'); ?>; width: <?php PIE_Echo($objPHPImageEditor->GetWidthFinal()); ?>px; height: <?php PIE_Echo($objPHPImageEditor->GetHeightFinal()); ?>px;"></div>
<div id="imageResizerNoProportions" style="diplay: <?php PIE_Echo((!$objPHPImageEditor->inputKeepProportions && $objPHPImageEditor->inputPanel == PIE_MENU_RESIZE) ? 'block' : 'none'); ?>; width: <?php PIE_Echo($objPHPImageEditor->GetWidthFinal()); ?>px; height: <?php PIE_Echo($objPHPImageEditor->GetHeightFinal()); ?>px;"></div>
</div>
<?php } ?>

<?php if (!$objPHPImageEditor->isAjaxPost) { ?>
</div>
</body>
</html>
<?php } ?>

<?php $objPHPImageEditor->CleanUp(); ?>


$ vim phpimageeditor/lite/shared/javascript/phpimageeditor.js
覆盖:

var objCrop = null;
var act ="block";

function ajax_post()
{
if ($('#loading').css('display') == 'none')
{
$('#width').attr('disabled','disabled');
$('#height').attr('disabled','disabled');
$('#keepproportions').attr('disabled','disabled');
$('#btnRotateLeft').attr('disabled','disabled');
$('#btnRotateRight').attr('disabled','disabled');
$('#croptop').attr('disabled','disabled');
$('#cropbottom').attr('disabled','disabled');
$('#cropleft').attr('disabled','disabled');
$('#cropright').attr('disabled','disabled');
$('#grayscale').attr('disabled','disabled');
$('#btnupdate').attr('disabled','disabled');
$('#btnsave').attr('disabled','disabled');
$('#btnundo').attr('disabled','disabled');
$('#brightness_slider_track').slider('disable');
$('#contrast_slider_track').slider('disable');
$('#loading').css('display','block');
$('#loading_bar').width(0);
$('#loading_bar').animate({width: document.getElementById('loading').offsetWidth-30}, document.getElementById('loading').offsetWidth*10);
$.ajax({
timeout: AjaxPostTimeoutMs,
type: "POST",
url: FormAction,
data: "grayscaleval="+$('#grayscaleval').val()+"&keepproportionsval="+$('#keepproportionsval').val()+"&width="+$('#width').val()+"&widthoriginal="+$('#widthoriginal').val()+"&height="+$('#height').val()+"&heightoriginal="+$('#heightoriginal').val()+"&rotate="+$('#rotate').val()+"&croptop="+$('#croptop').val()+"&cropleft="+$('#cropleft').val()+"&cropright="+$('#cropright').val()+"&cropbottom="+$('#cropbottom').val()+"&contrast="+$('#contrast').val()+"&brightness="+$('#brightness').val()+"&actiontype="+$('#actiontype').val()+"&panel="+$('#panel').val()+"&language="+$('#language').val()+"&actions="+$('#actions').val()+"&widthlast="+$('#widthlast').val()+"&heightlast="+$('#heightlast').val()+"&userid="+$('#userid').val()+"&contrastlast="+$('#contrastlast').val()+"&brightnesslast="+$('#brightnesslast').val()+"&widthlastbeforeresize="+$('#widthlastbeforeresize').val()+"&heightlastbeforeresize="+$('#heightlastbeforeresize').val()+"&cropkeepproportionsval="+$('#cropkeepproportionsval').val()+"&cropkeepproportionsratio="+$('#cropkeepproportionsratio').val()+"&isajaxpost=true",
success: function(data)
{
$('#phpImageEditor').html(data);
activate_form();
phpimageeditor_crop_activator(parseInt($('#panel').val()));
phpimageeditor_init();
$('#loading_bar').stop();
//$('#loading').css('display','none');
},
error: function(XMLHttpRequest, textStatus, errorThrown)
{
activate_form();
$('#ulJsErrors').html("");
adderror(TextAnUnexpectedError);
$('#divJsErrors').css('display','block');
$('#ulJsErrors').css('display','block');
phpimageeditor_crop_activator(parseInt($('#panel').val()));
$('#loading_bar').stop();
//$('#loading').css('display','none');
}
});

}
}

function isinteger(s)
{
var i;

if (isempty(s))
if (isinteger.arguments.length == 1) return 0;
else return (isinteger.arguments[1] == true);

for (i = 0; i < s.length; i++)
{
var c = s.charAt(i);

if (!isdigit(c)) return false;
}

return true;
}

function focus_on_enter(element, event)
{
if(event.keyCode == 13)
element.focus();
}

function reload_mouse_crop()
{
objCrop.destroy();
objCrop = $.Jcrop('#image',{onChange: set_crop_values,onSelect: set_crop_values, aspectRatio: $("input#cropkeepproportions").attr('checked') ? $("#cropkeepproportionsratio").val() : 0});
// $(".jcrop-holder").css("display", "none");

// add by zengyueming Todo 图片大小变化时依然显示剪裁框
objCrop.setSelect([ 0, 0, Pw, Ph ]);
$(".jcrop-holder").css("display", "block");
// end
$("#image").css("display", "block");
}

function update_width(InputWidth, EditForm)
{
if (isinteger(InputWidth.val()))
{
var Width = parseInt($('#width').val());
var Height = parseInt($('#height').val());

$('#image').css('width',Width+'px');

if ($("input#keepproportions").attr('checked'))
{
$('#image').css('height', get_proportional_height(Width, EditForm) + "px");
$('#height').val(get_proportional_height(Width, EditForm));
}

update_mouse_resizer();
reload_mouse_crop();
}
}

function update_mouse_resizer()
{
$('#imageResizerKeepProportions').css('width',$('#width').val()+'px');
$('#imageResizerKeepProportions').css('height',$('#height').val()+'px');
$('#imageResizerNoProportions').css('width',$('#width').val()+'px');
$('#imageResizerNoProportions').css('height',$('#height').val()+'px');
}

function update_height(InputHeight, EditForm)
{
if (isinteger(InputHeight.val()))
{
var Height = parseInt($('#height').val());
var Width = parseInt($('#width').val());

$('#image').css('height',$('#height').val()+'px');

if ($("input#keepproportions").attr('checked'))
{
$('#image').css('width',get_proportional_width(Height, EditForm)+'px');
$('#width').val(get_proportional_width(Height, EditForm));
}

update_mouse_resizer();
reload_mouse_crop();
}
}

function isempty(s)
{
return ((s == null) || (s.length == 0))
}

function isdigit (c)
{
return ((c >= "0") && (c <= "9"))
}

function isintegerinrange(s, a, b)
{
if (isempty(s))
if (isintegerinrange.arguments.length == 1) return false;
else return (isintegerinrange.arguments[1] == true);

// Catch non-integer strings to avoid creating a NaN below,
// which isn't available on JavaScript 1.0 for Windows.
if (!isinteger(s, false)) return false;


var num = parseInt (s);
return ((num >= a) && (num <= b));
}

function validate_form()
{
var sendForm = true;

var width = $('#width').val();
var height = $('#height').val();
var cropleft = $('#cropleft').val();
var cropright = $('#cropright').val();
var croptop = $('#croptop').val();
var cropbottom = $('#cropbottom').val();

$('#divJsErrors').css('display','none');
$('#ulJsErrors').css('display','none');

$('#ulJsErrors').html("");

if (width == "")
{
adderror("\"" + TextWidth + "\" " + TextIsRequired)
sendForm = false;
}

if (height == "")
{
adderror("\"" + TextHeight + "\" " + TextIsRequired)
sendForm = false;
}

if (!sendForm)
{
$('#divJsErrors').css('display','block');
$('#ulJsErrors').css('display','block');

return sendForm;
}

if (!isinteger(width))
{
adderror("\"" + TextWidth + "\" " + TextMustBeNumeric)
sendForm = false;
}

if (!isinteger(height))
{
adderror("\"" + TextHeight + "\" " + TextMustBeNumeric)
sendForm = false;
}

if (!sendForm)
{
$('#divJsErrors').css('display','block');
$('#ulJsErrors').css('display','block');
return sendForm;
}

width = parseInt(width);
height = parseInt(height);

if (!isintegerinrange(width, 1, ImageMaxWidth))
{
adderror("\"" + TextWidth + "\" " + TextNotInRange + ": 1 - " + ImageMaxWidth)
sendForm = false;
}

if (!isintegerinrange(height, 1, ImageMaxHeight))
{
adderror("\"" + TextHeight + "\" " + TextNotInRange + ": 1 - " + ImageMaxHeight)
sendForm = false;
}


if ($('#textlist').val() == '-1' && $('#text').val() != '')
{
if (!isintegerinrange(textposx, 0, width))
{
adderror("\"" + TextStartPositionX + "\" " + TextNotInRange + ": 1 - " + width)
sendForm = false;
}

if (!isintegerinrange(textposy, 0, height))
{
adderror("\"" + TextStartPositionY + "\" " + TextNotInRange + ": 1 - " + height)
sendForm = false;
}
}

if (!sendForm)
{
$('#divJsErrors').css('display','block');
$('#ulJsErrors').css('display','block');
}

return sendForm;
}

function adderror(ErrorText)
{
$('#ulJsErrors').html($('#ulJsErrors').html()+'<li>'+ErrorText+'</li>');
}

function get_proportional_width(Height, EditForm)
{
var HeightOriginal = parseInt($("#heightlastbeforeresize").val());
var WidthOriginal = parseInt($("#widthlastbeforeresize").val());

return Math.round((WidthOriginal/HeightOriginal)*Height);
}

function get_proportional_height(Width, EditForm)
{
var HeightOriginal = parseInt($("#heightlastbeforeresize").val());
var WidthOriginal = parseInt($("#widthlastbeforeresize").val());

return Math.round((HeightOriginal/WidthOriginal)*Width);
}

function remove_px(Value)
{
return Value.replace("px","");
}

function activate_form()
{
$('#width').removeAttr('disabled');
$('#height').removeAttr('disabled');
$('#keepproportions').removeAttr('disabled');
$('#btnRotateLeft').removeAttr('disabled');
$('#btnRotateRight').removeAttr('disabled');
$('#croptop').removeAttr('disabled');
$('#cropbottom').removeAttr('disabled');
$('#cropleft').removeAttr('disabled');
$('#cropright').removeAttr('disabled');
$('#grayscale').removeAttr('disabled');
$('#btnupdate').removeAttr('disabled');
$('#btnsave').removeAttr('disabled');
$('#btnundo').removeAttr('disabled');
$('#brightness_slider_track').slider('enable');
$('#contrast_slider_track').slider('enable');

if ($('#actions').val() == '')
{
$('#btnundo').attr('disabled','disabled');
$('#btnsave').attr('disabled','disabled');
}
else
{
$('#btnundo').removeAttr('disabled');
$('#btnsave').removeAttr('disabled');
}
}


function set_crop_values(c)
{
if (isinteger($("#height").val()) && isinteger($("#width").val()))
{
$("#croptop").val(c.y);
$("#cropbottom").val(parseInt($("#height").val()) - (c.y + c.h));
$("#cropleft").val(c.x);
$("#cropright").val(parseInt($("#width").val()) - (c.x + c.w));
$("#cropwidth").html(c.w);
$("#cropheight").html(c.h);
//zeny edit by 2015/01/15
$("#Pcropwidth").val(c.w);
$("#Pcropheight").val(c.h);
}
}

function phpimageeditor_resize_activator(selectedIndex)
{
if (selectedIndex == MenuResize)
{
if ($('#keepproportionsval').val() == "1")
{
$("#imageResizerKeepProportions").css("display", "block");
$("#imageResizerNoProportions").css("display", "none");
}
else
{
$("#imageResizerKeepProportions").css("display", "none");
$("#imageResizerNoProportions").css("display", "block");
}
}
else
{
$("#imageResizerKeepProportions").css("display", "none");
$("#imageResizerNoProportions").css("display", "none");
}
}

function phpimageeditor_panelfade(selectedIndex)
{
for (i = 0; i < 4; i++)
{
if ($('#panel_'+i) != null)
{
$("#panel_"+i).css('opacity','0.0');

if (i == selectedIndex)
{
$("#menuitem_"+i).removeClass("not-selected");
$("#menuitem_"+i).addClass("selected");
$("#panel_"+i).css('display','block');
$("#panel_"+i).fadeTo("normal", 1.0);
}
else
{
$("#menuitem_"+i).removeClass("selected");
$("#menuitem_"+i).addClass("not-selected");
$("#panel_"+i).css('display','none');
}
}
}

if (selectedIndex != MenuCrop)
{
$("#cropleft").val("0");
$("#cropright").val("0");
$("#croptop").val("0");
$("#cropbottom").val("0");
$("#cropwidth").html("0");
$("#cropheight").html("0");
}

phpimageeditor_resize_activator(selectedIndex);
phpimageeditor_crop_activator(selectedIndex);

$("#panel").val(selectedIndex);
}

function phpimageeditor_crop_activator(selectedIndex)
{
if (objCrop != null)
{
if (selectedIndex != MenuCrop && selectedIndex != MenuResize)
{
objCrop.release();
objCrop.disable();
$(".jcrop-holder").css("display", "none");
$("#image").css("display", "block");
}
else
{
objCrop.release();
objCrop.enable();
console.log(objCrop);
$(".jcrop-holder").css("display", "block");
$("#image").css("display", "block");
// alert(act+'ssss');
if (act != "none"){
objCrop.setSelect([ 0, 0, Pw, Ph ]);
}
}
}
}

function phpimageeditor_init()
{
objCrop = $.Jcrop('#image',{onChange: set_crop_values,onSelect: set_crop_values, aspectRatio: $("input#cropkeepproportions").attr('checked') ? $("input#cropkeepproportionsratio").val() : 0});

$("#imageResizerKeepProportions").resizable(
{
aspectRatio: parseFloat($("input#widthlastbeforeresize").val()) / parseFloat($("input#heightlastbeforeresize").val()),
stop: function(event,ui)
{
var resize_width = parseInt(remove_px($("#imageResizerKeepProportions").css("width")));
var resize_height = parseInt(remove_px($("#imageResizerKeepProportions").css("height")));

$("#image").css("width", resize_width+"px");
$("#image").css("height", resize_height+"px");
$("#width").val(resize_width);
$("#height").val(resize_height);

update_mouse_resizer();

$("#imageResizerKeepProportions").css("opacity", "0.0");

reload_mouse_crop();
},
start: function(event,ui)
{
$("#imageResizerKeepProportions").css("opacity", "0.5");
}
});

$("#imageResizerNoProportions").resizable(
{
aspectRatio: false,
stop: function(event,ui)
{
var resize_width = parseInt(remove_px($("#imageResizerNoProportions").css("width")));
var resize_height = parseInt(remove_px($("#imageResizerNoProportions").css("height")));

$("#image").css("width", resize_width+"px");
$("#image").css("height", resize_height+"px");
$("#width").val(resize_width);
$("#height").val(resize_height);

update_mouse_resizer();

$("#widthlastbeforeresize").val(resize_width);
$("#heightlastbeforeresize").val(resize_height);
$("#imageResizerKeepProportions").resizable('option','aspectRatio',parseFloat($('#widthlastbeforeresize').val())/parseFloat($('#heightlastbeforeresize').val()));

$("#imageResizerNoProportions").css("opacity", "0.0");

reload_mouse_crop();
},
start: function(event,ui)
{
$("#imageResizerNoProportions").css("opacity", "0.5");
}
});

$("#contrast_slider_track").slider({value: parseInt($("#contrast").val()) + ContrastMax, min: 1, max: ((ContrastMax*2)+1), step: 1,
stop: function(event,ui)
{
if (validate_form())
ajax_post();
},
slide: function(event, ui)
{
$("#contrast").val(parseInt(ui.value)-((ContrastMax)+1));
}
});

$("#brightness_slider_track").slider({value: (parseInt($("input#brightness").val())+BrightnessMax),min: 1,max: ((BrightnessMax*2)+1),step: 1,
stop: function(event,ui)
{
if (validate_form())
ajax_post();
},
slide: function(event, ui)
{
$("#brightness").val(parseInt(ui.value)-(BrightnessMax+1));
}
});

$("#grayscale").click(function()
{
if (validate_form())
{
$("#grayscale").attr('checked') ? $('#grayscaleval').val('1') : $('#grayscaleval').val('0');
ajax_post();
}
});

$("#btnupdate").click(function()
{
if (validate_form())
{
act = "none";
$("#actiontype").val(ActionUpdate);
ajax_post();
}
});

$("#btnundo").click(function()
{
if (validate_form())
{
act = "none";
$("#actiontype").val(ActionUndo);
ajax_post();

}
});

$("#btnsave").click(function()
{
if (validate_form())
{
act = "none";
$("#actiontype").val(ActionSaveAndClose);
ajax_post();
}
});

$("#uploadCoolyun").click(function () {
var width = $("#widthoriginal").val(),
height = $("#heightoriginal").val(),
displayorder = $("#picturedisplayorder").val(),
coverdisplayposition = $('input[name="coverdisplayposition"]:checked').val();
$.ajax({
url:"uploadCool.php",
data:{tid:tid,pid:pid,uid:uid,img:imgName,width:width,height:height,displayorder:displayorder,picposition:coverdisplayposition},
type:"post",
dataType:"json",
success : function (msg) {
if (msg.rs==='success'){
alert(msg.info);
}else{
alert(msg.info);
}
}
});
}) ;
retry = function () {
var va = $("#picturedisplayorder").val();
$.ajax({
url:"retryOrd.php",
data:{order:va,tid:tid},
dataType:"json",
type:"post",
success: function (msg){
if(msg.rs==='fail'){
document.getElementById("kiddlynotice").style.display="block";
$("#noticeinfo").html(msg.info);
return;
}
var arr = msg.info.split("_");
Pw = arr[0];Ph=arr[1];
update_mouse_resizer();
reload_mouse_crop();
return;
}
});
};

$("#btnRotateLeft").click(function()
{
if (validate_form())
{
$("#rotate").val(ActionRotateLeft);
ajax_post();
}
});

$("#btnRotateRight").click(function()
{
if (validate_form())
{
$("#rotate").val(ActionRotateRight);
ajax_post();
}
});

$("#btnRotateLeft_text").click(function()
{
if (validate_form())
{
$("#rotatetext").val(ActionRotateLeftText);
ajax_post();
}
});

$("#btnRotateRight_text").click(function()
{
if (validate_form())
{
$("#rotatetext").val(ActionRotateRightText);
ajax_post();
}
});

$("#btnDelete_text").click(function()
{
if (validate_form())
{
$("#deletetext").val(ActionDeleteText);
ajax_post();
}
});

$("form#" + FormId).submit(function()
{
if (validate_form())
{
$("#actiontype").val(ActionSaveAndClose);
return true;
}
return false;
});

$("#textlist").change(function()
{
if (validate_form())
{
$("#actiontype").val(ActionChangeText);
ajax_post();
}
});

$("#width").keydown(function(event)
{
focus_on_enter($("input#btnupdate"), event);
});

$("#width").keyup(function()
{
update_width($(this),$("form#" + FormId));
});

$("#height").keydown(function(event)
{
focus_on_enter($("input#btnupdate"), event);
});

$("#height").keyup(function()
{
update_height($(this),$("form#" + FormId));
});
//edit by 2015/1/14
$("#Pcropwidth").keydown(function (event){
focus_on_enter($("input#btnupdate"), event);
});
$("#Pcropwidth").keyup(function (){
if (isinteger($(this).val())){
console.log($("#Pcropwidth").val());
Pw = parseInt($("#Pcropwidth").val());
update_mouse_resizer();
reload_mouse_crop();
}
});
$("#Pcropheight").keydown(function (event){
focus_on_enter($("input#btnupdate"), event);
});
$("#Pcropheight").keyup(function (){
if (isinteger($(this).val())){
console.log($("#Pcropheight").val());
Ph = parseInt($("#Pcropheight").val());
update_mouse_resizer();
reload_mouse_crop();
}
});
//end

$("#keepproportions").click(function()
{
if ($(this).attr('checked'))
{
$('#keepproportionsval').val('1');
$('#imageResizerKeepProportions').css('display','block');
$('#imageResizerNoProportions').css('display','none');
}
else
{
$('#keepproportionsval').val('0');
$('#imageResizerKeepProportions').css('display','none');
$('#imageResizerNoProportions').css('display','block');
}
});


$("#cropkeepproportions").click(function()
{
if ($(this).attr('checked'))
{
$('#cropkeepproportionsval').val('1');
}
else
{
$('#cropkeepproportionsval').val('0');
}
});

$("#menuitem_" + MenuResize).click(function()
{
if ($('#panel').val() != MenuResize)
{
phpimageeditor_panelfade(MenuResize);
}
});

$("#menuitem_" + MenuRotate).click(function()
{
if ($('#panel').val() != MenuRotate)
{
phpimageeditor_panelfade(MenuRotate);
}
});

$("#menuitem_" + MenuCrop).click(function()
{
if ($('#panel').val() != MenuCrop)
{
phpimageeditor_panelfade(MenuCrop);
}
});

if ($("#menuitem_" + MenuEffects) != null)
{
$("#menuitem_" + MenuEffects).click(function()
{
if ($('#panel').val() != MenuEffects)
{
phpimageeditor_panelfade(MenuEffects);
}
});
}

$('#cropkeepproportions').change(function(e)
{
if (objCrop != null)
{
if (this.checked && parseFloat($("#cropwidth").html()) != 0 && parseFloat($("#cropheight").html()) != 0)
{
var aspectRatio = parseFloat($("#cropwidth").html()) / parseFloat($("#cropheight").html());
objCrop.setOptions({ aspectRatio: aspectRatio });
$("#cropkeepproportionsratio").val(aspectRatio);
}
else if (this.checked && parseFloat($("#cropwidth").html()) == 0 && parseFloat($("#cropheight").html()) == 0)
{
objCrop.setOptions({ aspectRatio: $("#cropkeepproportionsratio").val() });
}
else
{
objCrop.setOptions({ aspectRatio: 0 });
}

}
});

$("input#width").numeric();
$("input#height").numeric();

var selectedIndex = parseInt($('#panel').val());
for (i = 0; i < 4; i++)
{
if ($('#panel_'+i) != null)
{
if (i == selectedIndex)
{
$("#panel_"+i).css('opacity','1.0');
$("#panel_"+i).css('display','block');
}
else
{
$("#panel_"+i).css('opacity','0.0');
$("#panel_"+i).css('display','none');
}
}
}

phpimageeditor_crop_activator(selectedIndex);
phpimageeditor_resize_activator(selectedIndex);
}

$(document).ready(function()
{
phpimageeditor_init();

//add by zengyueming 默认选择第一个menu;
if ($('#panel').val() != MenuResize)
{
$("#Pcropwidth").val(Pw);
$("#Pcropheight").val(Ph);
phpimageeditor_panelfade(MenuResize);
}
//end

});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Pixie Image Editor 在线图片编辑器 中文版 功能 集成 - 轻松将pixie集成到任何现有项目或应用程序中。 可扩展 - Pixie接口和API可以使用新功能进行扩展。 移动 - Pixie拥有完整的移动支持,并可自动调整其界面以适应任何设备的大小。 可自定义的UI - 通过显示,隐藏或添加新菜单项,更改工具栏位置或使用不同的主题来自定义UI。 可翻译 - Pixie的界面可通过配置完全翻译。 水印 - 保存的照片可以使用指定的文本轻松加水印。 模式 - 在叠加(模态),内联或全屏模式之间进行选择。 工具API - 通过API使用所有精灵工具(调整大小,裁剪,框架等),而无需打开精灵界面。 可自定义的工具 - 所有工具都可完全自定义,您可以删除或修改和添加自定义贴纸,形状,字体,框架等。 状态 - 以json格式保存当前编辑器状态,允许使用预构建模板等功能。 照片处理 - 通过界面或API调整大小,裁剪,转换等。 滤镜 - Pixie配有许多内置滤镜,如灰度,模糊,黑白,复古等。可以通过API添加更多过滤器.. 框架 - 为任何大小的照片添加内置响应帧或添加自己的帧。 裁剪 - 将照片裁剪为指定宽高比之一,或让用户通过UI选择自定义裁剪区域。 绘图 - 功能强大的免费绘图工具支持鼠标和触摸,具有多种画笔类型,颜色等。 文本 - 完全支持向图像添加文本。可以使用数百种谷歌字体或仅使用自定义添加的字体。 形状 - 只需指定svg图像路径,即可轻松添加自定义形状。 贴纸 - 可以添加或删除自定义贴纸。任何类型的图像都可以用作贴纸。 角落 - 只需单击一下或API调用即可对图像角进行四舍五入。 空画布 - Pixie不必编辑现有照片,也可以从头开始轻松创建自定义图像。 历史记录 - 所有编辑器操作都是非破坏性的,可以通过历史记录工具轻松撤消和重做。 对象 - 所有对象(如贴纸,形状和文本)都在自己的图层上,可以通过更改颜色,添加阴影,背景等来轻松移动,调整大小,删除和修改。 图案和渐变 - 所有对象都可以使用许多内置或自定义图案和渐变填充。 保存 - 修改后的图像可以通过API或接口轻松保存在本地设备或服务器上。 缩放和平移 - 可以使用鼠标,鼠标滚轮或移动设备上的触摸和捏合手势来缩放和平移画布。 HTML5 - Pixie使用原生HTML5,这意味着它可以在每个设备上运行。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值