PbootCms模板默認(rèn)的圖片裁剪是從左上角開(kāi)始裁剪,使用width,height,maxwidth,maxheight等參數(shù)進(jìn)行調(diào)節(jié)。
但是裁剪出來(lái)的圖片始終感覺(jué)不是那么令人滿(mǎn)意。(也許是我不會(huì)用)
比如多人物合影,PB默認(rèn)的裁剪是左上,那么這個(gè)裁剪就會(huì)丟掉C位,那怎么能行。
今天來(lái)優(yōu)化一下裁剪圖片,讓他能簡(jiǎn)單快捷的裁剪出理想的圖片。
我想要的效果是不論橫圖豎圖都是居中裁剪。
翠花,上干貨!
解決方案
首先找到裁剪縮略圖的方法,
文件位置:/core/function/file.php
搜索:function cut_img,大約在447行
對(duì)cut_img方法進(jìn)行優(yōu)化,直接上代碼:
// 剪切圖片 function cut_img($src_image, $out_image = null, int $new_width = null, int $new_height = null, $img_quality = 90) { // 輸出地址 if (! $out_image) $out_image = $src_image; // 讀取配置文件設(shè)置 if (! $new_width && ! $new_height) return; // 獲取圖片屬性 list ($width, $height, $type, $attr) = getimagesize($src_image); switch ($type) { case 1: $img = imagecreatefromgif($src_image); break; case 2: $img = imagecreatefromjpeg($src_image); break; case 3: $img = imagecreatefrompng($src_image); break; } // 不限定是等比例縮放 if (! $new_width) { $new_width = floor($width * ($new_height / $height)); } if (! $new_height) { $new_height = floor($height * ($new_width / $width)); } // 創(chuàng)建畫(huà)布 $new_img = imagecreatetruecolor($new_width, $new_height); // 創(chuàng)建透明畫(huà)布,避免黑色 if ($type == 1 || $type == 3) { $color = imagecolorallocate($new_img, 255, 255, 255); imagefill($new_img, 0, 0, $color); imagecolortransparent($new_img, $color); } // 先縮放 $scale = max($new_width / $width, $new_height / $height); $scale_width = floor($scale * $width); $scale_height = floor($scale * $height); $scale_img = imagecreatetruecolor($scale_width, $scale_height); // 創(chuàng)建畫(huà)布 if(function_exists("ImageCopyResampled")) { imagecopyresampled($scale_img, $img, 0, 0, 0, 0, $scale_width, $scale_height, $width, $height); } else { imagecopyresized($scale_img, $img, 0, 0, 0, 0, $scale_width, $scale_height, $width, $height); } //再裁剪 $start_x = ($scale_width - $new_width) / 2; $start_y = ($scale_height - $new_height) / 2; //拷貝剪切的圖像數(shù)據(jù)到畫(huà)板,生成剪切圖像 imagecopy($new_img, $scale_img, 0, 0, $start_x, $start_y, $scale_width, $scale_height); check_dir(dirname($out_image), true); // 檢查輸出目錄 switch ($type) { case 1: imagegif($new_img, $out_image, $img_quality); break; case 2: imagejpeg($new_img, $out_image, $img_quality); break; case 3: imagepng($new_img, $out_image, $img_quality / 10); // $quality參數(shù)取值范圍0-99 在php 5.1.2之后變更為0-9 break; default: imagejpeg($new_img, $out_image, $img_quality); } imagedestroy($new_img); imagedestroy($img); return true; } |
小伙伴可以直接復(fù)制替換該方法。
使用方法
{pboot:list scode=*} {/pboot:list} |
如上代碼,直接生成600*400像素的居中裁剪過(guò)的圖片。
收工。
舉個(gè)例子:列表中輸出圖片
版權(quán)聲明: 本站資源均來(lái)自互聯(lián)網(wǎng)或會(huì)員發(fā)布,如果侵犯了您的權(quán)益請(qǐng)與我們聯(lián)系,我們將在24小時(shí)內(nèi)刪除!謝謝!
轉(zhuǎn)載請(qǐng)注明: PbootCms縮略圖裁剪優(yōu)化居中裁剪(直接上干貨)