PbootCms缩略图裁剪优化居中裁剪
更新日期:2024-09-19 18:59:49 来源:网络
为了实现居中裁剪图片的功能,可以通过修改 cut_img
方法来实现。具体步骤如下:
-
定位并修改
cut_img
方法:- 文件位置:
/core/function/file.php
- 修改
cut_img
方法,使其支持居中裁剪。
- 文件位置:
-
修改后的
cut_img
方法:- 在裁剪前先进行缩放处理,然后从中心位置裁剪。
以下是修改后的 cut_img
方法代码:
php
// 剪切图片
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;
// 读取配置文件设置
if (! $new_width && ! $new_height)
return;
// 获取图片属性
list ($width, $height, $type, $attr) = getimagesize($src_image);
switch ($type) {
case IMAGETYPE_GIF:
$img = imagecreatefromgif($src_image);
break;
case IMAGETYPE_JPEG:
$img = imagecreatefromjpeg($src_image);
break;
case IMAGETYPE_PNG:
$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));
}
// 创建画布
$new_img = imagecreatetruecolor($new_width, $new_height);
// 创建透明画布,避免黑色
if ($type == IMAGETYPE_GIF || $type == IMAGETYPE_PNG) {
$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); // 创建画布
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;
// 拷贝剪切的图像数据到画板,生成剪切图像
imagecopy($new_img, $scale_img, 0, 0, $start_x, $start_y, $new_width, $new_height);
check_dir(dirname($out_image), true); // 检查输出目录
switch ($type) {
case IMAGETYPE_GIF:
imagegif($new_img, $out_image, $img_quality);
break;
case IMAGETYPE_JPEG:
imagejpeg($new_img, $out_image, $img_quality);
break;
case IMAGETYPE_PNG:
imagepng($new_img, $out_image, $img_quality / 10); // $quality参数取值范围0-99 在php 5.1.2之后变更为0-9
break;
default:
imagejpeg($new_img, $out_image, $img_quality);
}
imagedestroy($new_img);
imagedestroy($img);
return true;
}
使用方法
使用 {pboot:list}
标签时,添加 width
和 height
参数来生成居中裁剪的图片:
html
{pboot:list scode=*}
<a href="[list:link]"><img src="[list:ico width=600 height=400]" alt="[list:title]" /></a>
{/pboot:list}
说明
-
width
和height
参数:- 设置图片的宽度和高度,裁剪后的图片将居中裁剪为指定大小。
-
居中裁剪:
- 通过计算裁剪起始点
$start_x
和$start_y
,确保裁剪从中心位置开始。
- 通过计算裁剪起始点
通过以上修改,你可以实现居中裁剪图片的功能,无论图片是横图还是竖图,都能得到理想的裁剪效果。
- PbootCms缩略图裁剪优化居中裁剪
- pbootcms列表如何置顶文章,istop不生效怎么办?
- pbootcms模板 后台升级程序后导致网站打不开 Parse error_ syntax error
- PbootCMS中使用sql标签统计网站留言总数
- PbootCms忘记后台管理员密码这样找回
- dedecms如何做好安全防范挂马
- pbootcms 登录请求发生错误,您可按照如下方式排查
- dedecms调用栏目名称与栏目链接地址的方法
- PbootCMS怎么安装?注意事项
- pbootcms安全设置解决网站被黑被篡改问题
- could not find driver
- pbootcms模板不出现要授权的域名,导致填写授权码也无效(1)
- Pbootcms忘记后台帐号密码如何重置
- PbootCMS如何开启手机访问
- dedecms修改文档标题最大长度
- eyoucms后台如何更换后台登录logo
- Fatal error_ Call to undefined function_ imagecreatefromgif() in ...._e_class_gd.php ..
- dedecms空白页面或500错误怎么办?织梦网站常见故障
- pbootcmsIIS7+环境伪静态配置
- PbootCMS提交留言成功后跳转到指定的网址