圖片太大且規格不統一,顯示的控制需要靠JavaScript來完成,用在行動裝置上時顯示效果不好且流量巨大,需要對現有圖片庫的圖片進行一次處理,產生符合行動裝置用的縮圖,將原來用戶端JS做的工作轉移到伺服器端用PHP的GD庫來集中處理。
圖片源與需要的大小: 複製代碼 代碼如下:$src_img = "wallpaper.jpg";
$dst_w = 300;
$dst_h = 200;
剪裁映像,保證映像地區最大化顯示,並按比例縮放到指定大小。
一開始採用了 imagecopyresized 方法進行映像等比縮小,實際操作後發現,映像縮小後燥點非常嚴重。後再換用 imagecopyresampled (這裡說一下,網上轉載這個文章的很多,但是他們都把imagecopyresampled寫成了imagecopysampled導致無法使用,所以我才重新貼了這個)方法,該方法會對映像進行重新採樣,對縮小的映像進行平滑處理,使清晰度得到很大提高。 複製代碼 代碼如下:<?php
list($src_w,$src_h)=getimagesize($src_img); // 擷取原圖尺寸
$dst_scale = $dst_h/$dst_w; //靶心圖表像長寬比
$src_scale = $src_h/$src_w; // 原圖長寬比
if($src_scale>=$dst_scale)
{
// 過高
$w = intval($src_w);
$h = intval($dst_scale*$w);
$x = 0;
$y = ($src_h - $h)/3;
}
else
{
// 過寬
$h = intval($src_h);
$w = intval($h/$dst_scale);
$x = ($src_w - $w)/2;
$y = 0;
}
// 剪裁
$source=imagecreatefromjpeg($src_img);
$croped=imagecreatetruecolor($w, $h);
imagecopy($croped,$source,0,0,$x,$y,$src_w,$src_h);
// 縮放
$scale = $dst_w/$w;
$target = imagecreatetruecolor($dst_w, $dst_h);
$final_w = intval($w*$scale);
$final_h = intval($h*$scale);
imagecopyresampled($target,$croped,0,0,0,0,$final_w,$final_h,$w,$h);
// 儲存
$timestamp = time();
imagejpeg($target, "$timestamp.jpg");
imagedestroy($target);
?>
希望大家能用到,還是比較方便的。