適合自己的 ● 才是最好的 新聞動態,洞悉互聯網前沿資訊,探尋網站營銷規律
當前位置:網站首頁 >> 網站制作
pbootcms縮略圖裁剪優化居中裁剪
日期:2021-11-03 17:26:39 來源:合肥良馬網絡科技有限公司 官網:http://www.educate8.com/ 閱讀:63次
pbootcms默認的圖片裁剪是從左上角開始裁剪,使用width,height,maxwidth,maxheight等參數進行調節。
 
但是裁剪出來的圖片始終感覺不是那么令人滿意。(也許是我不會用)
 
比如多人物合影,PB默認的裁剪是左上,那么這個裁剪就會丟掉C位,那怎么能行。
 
今天來優化一下裁剪圖片,讓他能簡單快捷的裁剪出理想的圖片。
 
我想要的效果是不論橫圖豎圖都是居中裁剪。
 
翠花,上干貨!
 
解決方案
 
首先找到裁剪縮略圖的方法,
 
文件位置:/core/function/file.php
 
搜索:function cut_img,大約在447行
 
對cut_img方法進行優化,直接上代碼:
01 // 剪切圖片
02 function cut_img($src_image, $out_image = null, int $new_width = null, int $new_height = null, $img_quality = 90)
03 {
04     // 輸出地址
05     if (! $out_image)
06         $out_image = $src_image;
07      
08     // 讀取配置文件設置
09     if (! $new_width && ! $new_height)
10         return;
11      
12     // 獲取圖片屬性
13     list ($width, $height, $type, $attr) = getimagesize($src_image);
14     switch ($type) {
15         case 1:
16             $img = imagecreatefromgif($src_image);
17             break;
18         case 2:
19             $img = imagecreatefromjpeg($src_image);
20             break;
21         case 3:
22             $img = imagecreatefrompng($src_image);
23             break;
24     }
25      
26     // 不限定是等比例縮放
27     if (! $new_width) {
28         $new_width = floor($width * ($new_height / $height));
29     }
30     if (! $new_height) {
31         $new_height = floor($height * ($new_width / $width));
32     }
33     // 創建畫布
34     $new_img = imagecreatetruecolor($new_width, $new_height);
35      
36     // 創建透明畫布,避免黑色
37     if ($type == 1 || $type == 3) {
38         $color = imagecolorallocate($new_img, 255, 255, 255);
39         imagefill($new_img, 0, 0, $color);
40         imagecolortransparent($new_img, $color);
41     }
42  
43  
44     // 先縮放
45     $scale = max($new_width / $width, $new_height / $height);
46     $scale_width = floor($scale * $width);
47     $scale_height = floor($scale * $height);
48     $scale_img = imagecreatetruecolor($scale_width, $scale_height); // 創建畫布
49     if(function_exists("ImageCopyResampled")) {
50        imagecopyresampled($scale_img, $img, 0, 0, 0, 0, $scale_width, $scale_height, $width, $height);
51     else {
52        imagecopyresized($scale_img, $img, 0, 0, 0, 0, $scale_width, $scale_height, $width, $height);
53     }
54     //再裁剪
55     $start_x = ($scale_width - $new_width) / 2;
56     $start_y = ($scale_height - $new_height) / 2;
57  
58     //拷貝剪切的圖像數據到畫板,生成剪切圖像
59     imagecopy($new_img, $scale_img, 0, 0, $start_x, $start_y, $scale_width, $scale_height);
60  
61     check_dir(dirname($out_image), true); // 檢查輸出目錄
62      
63     switch ($type) {
64         case 1:
65             imagegif($new_img, $out_image, $img_quality);
66             break;
67         case 2:
68             imagejpeg($new_img, $out_image, $img_quality);
69             break;
70         case 3:
71             imagepng($new_img, $out_image, $img_quality / 10); // $quality參數取值范圍0-99 在php 5.1.2之后變更為0-9
72             break;
73         default:
74             imagejpeg($new_img, $out_image, $img_quality);
75     }
76     imagedestroy($new_img);
77     imagedestroy($img);
78     return true;
79 }
小伙伴可以直接復制替換該方法。
 
使用方法
1 {pboot:list scode=*}
2 <a href= "[list:link]"><img src="[list:ico width=600 height=400]" /></a>
3 {/pboot:list}

如上代碼,直接生成600*400像素的居中裁剪過的圖片。
 
收工。
舉個例子:列表中輸出圖片


本文標題:pbootcms縮略圖裁剪優化居中裁剪
本文網址:http://www.educate8.com/news/1483.html
原創作者:合肥良馬網絡科技有限公司 版權所有,轉載請注明出處,并以鏈接形式注明。
聲明:本頁內容由合肥良馬網絡科技有限公司通過網絡收集編輯和原創所得,所有資料僅供用戶參考;本站不擁有所有權,也不承認相關法律責任。如您認為本網頁中有涉嫌抄寫的內容,請及時與我們聯系進行舉報,并提供相關證據,工作人員會在5個工作日內聯系您,一經查實,本站將立刻刪除涉嫌侵權內容。如果您對SEO優化核心技術文章感興趣,請點擊查看網絡推廣網站制作的相關文章,請關注良馬科技官網(www.educate8.com)

亚洲日韩精品欧美一区二区,精品国产美女福到在线不卡,亚洲 欧美 另类 综合 日韩,国内卡一卡二卡三免费网站