2011-09-06 99 views
5

我目前正在編寫基於Uploadify的上傳程序腳本。現在我調整給定的圖像和水印的大小之一。這一切運作良好,但我需要腳本來調整高度,然後裁剪寬度,以便縱橫比不會混亂。使用GD調整圖像尺寸並保留長寬比

這是我到目前爲止的代碼:

if ($fileExtension == "jpg" || 
     $fileExtension == "jpeg" || 
     $fileExtension == "png" || 
     $fileExtension == "gif"){ 

     // GD variables: 
     list($width, $height, $type) = GetImageSize($uploadedFile['tmp_name']); 

     // Image sizes: 
     $bigImage = array(800, 453); 
     $mediumImage = array(410, 231); 
     $listImage = array(120, 68); 
     $thumbnail = array(90, 51); 

     $sourceAspect = $width/$height; 
     $bigAspect = $bigImage[0]/$bigImage[1]; 
     $mediumAspect = $mediumImage[0]/$mediumImage[1]; 
     $listAspect = $listImage[0]/$listImage[1]; 
     $thumbnailAspect = $thumbnail[0]/$thumbnail[1]; 

     // Image is PNG: 
     if ($type == IMAGETYPE_PNG){ 
      $image = imagecreatefrompng($uploadedFile['tmp_name']); 
      $valid = true; 
     } 

     // Image is JPEG: 
     else if ($type == IMAGETYPE_JPEG){ 
      $image = imagecreatefromjpeg($uploadedFile['tmp_name']); 
      $valid = true; 
     } 

     // Image is GIF: 
     else if ($type == IMAGETYPE_GIF){ 
      $image = imagecreatefromgif($uploadedFile['tmp_name']); 
      $valid = true; 
     } 

     // Format not allowed: 
     else { 
      $valid = false; 
     } 

     // Start creating images: 
     if ($valid){ 

      // Get size: 
      $imageSize = getimagesize($uploadedFile['tmp_name']); 

      // Generate canvas: 
      $bCanvas = imagecreatetruecolor($bigImage[0], $bigImage[1]); 
      $mCanvas = imagecreatetruecolor($mediumImage[0], $mediumImage[1]); 
      $lCanvas = imagecreatetruecolor($listImage[0], $listImage[1]); 
      $tCanvas = imagecreatetruecolor($thumbnail[0], $thumbnail[1]); 

      // Copy content: 
      imagecopyresampled($bCanvas, $image, 0, 0, 0, 0, ($bigImage[0] * $sourceAspect), ($bigImage[1]/$sourceAspect), $imageSize[0], $imageSize[1]); 
      imagecopyresampled($mCanvas, $image, 0, 0, 0, 0, $mediumImage[0], $mediumImage[1], $imageSize[0], $imageSize[1]); 
      imagecopyresampled($lCanvas, $image, 0, 0, 0, 0, $listImage[0], $listImage[1], $imageSize[0], $imageSize[1]); 
      imagecopyresampled($tCanvas, $image, 0, 0, 0, 0, $thumbnail[0], $thumbnail[1], $imageSize[0], $imageSize[1]); 

      // Save images: 
      $saveB = imagejpeg($bCanvas, $targetFile.'_big.jpg', 90); 
      $saveM = imagejpeg($mCanvas, $targetFile.'_medium.jpg', 90); 
      $saveT = imagejpeg($lCanvas, $targetFile.'_list.jpg', 90); 
      $saveT = imagejpeg($tCanvas, $targetFile.'_thumb.jpg', 90); 

      // Destroy images: 
      imagedestroy($image); 
      imagedestroy($bCanvas); 
      imagedestroy($mCanvas); 
      imagedestroy($lCanvas); 
      imagedestroy($tCanvas); 

      // Watermark images: 
      $mark = imagecreatefrompng("logo.png"); 
      list($mwidth, $mheight) = getimagesize("logo.png"); 
      $img = imagecreatefromjpeg($targetFile.'_big.jpg'); 

      list($bwidth, $bheight) = getimagesize($targetFile.'_big.jpg'); 
      imagecopy($img, $mark, $bwidth-$mwidth-25, $bheight-$mheight-25, 0, 0, $mwidth, $mheight); 
      imagejpeg($img, $targetFile.'_big.jpg', 100); 
      imagedestroy($img); 

     } else { 
      echo "0"; 
     } 

    } else { 
     move_uploaded_file($tempFile,$targetFile.'.'.$fileExtension); 
    } 

我會真的很高興,如果有人可以幫助我解決這個問題。我一直在嘗試幾種方法,但沒有一個似乎正常工作。正如您在頂部看到的,我已經定義了要在變量「bigImage」,「mediumImage」,「listImage」和「thumbnail」中使用的畫布大小。

在此先感謝! // 喬納森

+0

據我記得你不能用GD做到這一點,但Imagick會提供這些可能性。 – markus

回答

16

有調整圖像大小的方法不止一種。我來替換出來供你:

  • 拉伸以適應屏幕 - 的圖像被調整大小到所需的大小忽略寬高比
  • Scale to fit - 圖像被調整大小,使得一個維度(寬度或高度)具有所需的大小,而另一個是相同或較短的,同時保持高寬比(一個額外的步驟,可能需要填充純色短邊)
  • Crop to fit - 圖像被調整大小,使得一個維度(寬度或高度)具有所需的尺寸,而另一個相同或更長,同時保持寬高比(修剪外部區域需要一個額外的步驟)

PS:這兩篇文章都是我寫的。

+0

謝謝,我試圖使用你的文章,但我最終得到一個完全黑色的圖像。我不知道爲什麼,但我已經多次瞭解代碼,我無法找到問題。這裏是我的代碼使用你的功能:http://pastebin.com/XgDvUEWe – Jonathan

+0

對不起,我得到它的工作! :) – Jonathan

+0

@Jonathan,我啓用了完整的錯誤報告來找到問題;您的粘貼的修訂版可在http://pastebin.com/J41aPe9g –

相關問題