X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/9a24b86c2c7ddd574bf21ad86877c9c3bf0f229e..af49d9b508825f62a0ea80c9069dd32d1147b433:/thumb/index.php diff --git a/thumb/index.php b/thumb/index.php index 1267919..24f46cc 100644 --- a/thumb/index.php +++ b/thumb/index.php @@ -1,8 +1,7 @@ getCode() ?: 500); $target = '500.png'; if (file_exists($target)) { @@ -34,13 +32,30 @@ header('Content-type: '.mime_content_type($target)); readfile($target); exit; -function mkthumb($source, $target, $width, $height) +function mkthumb($source, $size) { + if (strpos($size, 'x') !== FALSE) { + list ($width, $height) = explode('x', $size); + if (empty($height)) { + $height = $width * 4; + } + } + else { + $height = $size; + } + if (empty($width)) { + $width = $height * 4; + } + $target = "thumb/$size/$source"; + if (isset($_GET['backend'])) { $backend = $_GET['backend']; } elseif (file_exists($target)) { - return; + return $target; + } + elseif (extension_loaded('gd')) { + $backend = 'gd'; } else { $backend = 'exec'; @@ -49,6 +64,21 @@ function mkthumb($source, $target, $width, $height) @mkdir(dirname($target), 0777, TRUE); $backend($source, $target, $width, $height); + return $target; +} + +function mkthumb_gd($source, $target, $width, $height) +{ + $data = imagecreatefromstring(file_get_contents($source)); + if (!$data) throw new Exception("error reading $source"); + $orgwidth = imagesx($data); + $orgheight = imagesy($data); + $width = min($width, $orgwidth * $height / $orgheight); + $gd = imagecreatetruecolor($width, $height); + //TODO: trim + imagecopyresampled($gd, $data, 0, 0, 0, 0, + $width, $height, $orgwidth, $orgheight); + imagejpeg($gd, $target, 90); } function mkthumb_exec($source, $target, $width, $height) @@ -61,7 +91,7 @@ function mkthumb_exec($source, $target, $width, $height) '-trim', '-resize', "${width}x${height}", '-quality', '90%', - $source, $target + $source, "jpg:$target" ])); $return = shell_exec("$cmd 2>&1"); if ($return) {