From 197516b94fb05aa9dd0fd69d4dacbf7c71f540b8 Mon Sep 17 00:00:00 2001 From: a2nt Date: Tue, 7 May 2013 22:07:58 +0700 Subject: [PATCH] FIX ImageMagick cropped resize --- filesystem/ImagickBackend.php | 38 ++++++++++------------------------- 1 file changed, 11 insertions(+), 27 deletions(-) diff --git a/filesystem/ImagickBackend.php b/filesystem/ImagickBackend.php index d94fb0652..5cdc1dce4 100644 --- a/filesystem/ImagickBackend.php +++ b/filesystem/ImagickBackend.php @@ -236,42 +236,26 @@ class ImagickBackend extends Imagick implements Image_Backend { $width = round($width); $height = round($height); - $geometry = $this->getImageGeometry(); + $geo = $this->getImageGeometry(); // Check that a resize is actually necessary. - if ($width == $geometry["width"] && $height == $geometry["height"]) { + if ($width == $geo["width"] && $height == $geo["height"]) { return $this; } + if(!$backgroundColor){ + $backgroundColor = new ImagickPixel('transparent'); + } + $new = clone $this; $new->setBackgroundColor($backgroundColor); - $destAR = $width / $height; - if ($geometry["width"] > 0 && $geometry["height"] > 0) { - // We can't divide by zero theres something wrong. - - $srcAR = $this->width / $this->height; - - // Destination narrower than the source - if($destAR < $srcAR) { - $srcY = 0; - $srcHeight = $this->height; - - $srcWidth = round( $this->height * $destAR ); - $srcX = round( ($this->width - $srcWidth) / 2 ); - - // Destination shorter than the source - } else { - $srcX = 0; - $srcWidth = $this->width; - - $srcHeight = round( $this->width / $destAR ); - $srcY = round( ($this->height - $srcHeight) / 2 ); - } - - $new->extentImage($width, $height, $destX, $destY); + if(($geo['width']/$width) < ($geo['height']/$height)){ + $new->cropImage($geo['width'], floor($height*$geo['width']/$width), 0, (($geo['height']-($height*$geo['width']/$width))/2)); + }else{ + $new->cropImage(ceil($width*$geo['height']/$height), $geo['height'], (($geo['width']-($width*$geo['height']/$height))/2), 0); } - + $new->ThumbnailImage($width,$height,true); return $new; } }