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像素的居中裁剪过的图片。
收工。
举个例子:列表中输出图片

主题授权提示:请在后台主题设置-主题授权-激活主题的正版授权,授权购买:RiTheme官网

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。