资讯专栏INFORMATION COLUMN

php比例缩放图片及剪切图片

widuu / 2430人阅读

摘要:图片缩放函数可设置高度固定,宽度固定或者最大宽高,支持三种类型源图片目标宽度目标高度锁定宽高可选参数或者空值宽度固定高度固定最大宽或最大高用法最大宽高宽度固定高度固定剪切图片为固定大小源图过高源图过宽源图适中裁剪缩放

/**
 * 图片缩放函数(可设置高度固定,宽度固定或者最大宽高,支持gif/jpg/png三种类型)
 * Author : Specs
 *
 * @param string $source_path 源图片
 * @param int $target_width 目标宽度
 * @param int $target_height 目标高度
 * @param string $fixed_orig 锁定宽高(可选参数 width、height或者空值)
 * @return string
 */
function myImageResize($source_path, $target_width = 200, $target_height = 200, $fixed_orig = ""){
    $source_info = getimagesize($source_path);
    $source_width = $source_info[0];
    $source_height = $source_info[1];
    $source_mime = $source_info["mime"];
    $ratio_orig = $source_width / $source_height;
    if ($fixed_orig == "width"){
        //宽度固定
        $target_height = $target_width / $ratio_orig;
    }elseif ($fixed_orig == "height"){
        //高度固定
        $target_width = $target_height * $ratio_orig;
    }else{
        //最大宽或最大高
        if ($target_width / $target_height > $ratio_orig){
            $target_width = $target_height * $ratio_orig;
        }else{
            $target_height = $target_width / $ratio_orig;
        }
    }
    switch ($source_mime){
        case "image/gif":
            $source_image = imagecreatefromgif($source_path);
            break;
        
        case "image/jpeg":
            $source_image = imagecreatefromjpeg($source_path);
            break;
        
        case "image/png":
            $source_image = imagecreatefrompng($source_path);
            break;
        
        default:
            return false;
            break;
    }
    $target_image = imagecreatetruecolor($target_width, $target_height);
    imagecopyresampled($target_image, $source_image, 0, 0, 0, 0, $target_width, $target_height, $source_width, $source_height);
    //header("Content-type: image/jpeg");
    $imgArr = explode(".", $source_path);
    $target_path = $imgArr[0] . "_new." . $imgArr[1];
    imagejpeg($target_image, $target_path, 100);
}

用法:

myImageResize($filename, 200, 200); //最大宽高
myImageResize($filename, 200, 200, "width"); //宽度固定
myImageResize($filename, 200, 200, "height"); //高度固定

剪切图片为固定大小:

function imagecropper($source_path, $target_width, $target_height){
    $source_info = getimagesize($source_path);
    $source_width = $source_info[0];
    $source_height = $source_info[1];
    $source_mime = $source_info["mime"];
    $source_ratio = $source_height / $source_width;
    $target_ratio = $target_height / $target_width;
    
    // 源图过高
    if ($source_ratio > $target_ratio){
        $cropped_width = $source_width;
        $cropped_height = $source_width * $target_ratio;
        $source_x = 0;
        $source_y = ($source_height - $cropped_height) / 2;
    }elseif ($source_ratio < $target_ratio){ // 源图过宽
        $cropped_width = $source_height / $target_ratio;
        $cropped_height = $source_height;
        $source_x = ($source_width - $cropped_width) / 2;
        $source_y = 0;
    }else{ // 源图适中
        $cropped_width = $source_width;
        $cropped_height = $source_height;
        $source_x = 0;
        $source_y = 0;
    }
    
    switch ($source_mime){
        case "image/gif":
            $source_image = imagecreatefromgif($source_path);
            break;
        
        case "image/jpeg":
            $source_image = imagecreatefromjpeg($source_path);
            break;
        
        case "image/png":
            $source_image = imagecreatefrompng($source_path);
            break;
        
        default:
            return false;
            break;
    }
    
    $target_image = imagecreatetruecolor($target_width, $target_height);
    $cropped_image = imagecreatetruecolor($cropped_width, $cropped_height);
    
    // 裁剪
    imagecopy($cropped_image, $source_image, 0, 0, $source_x, $source_y, $cropped_width, $cropped_height);
    // 缩放
    imagecopyresampled($target_image, $cropped_image, 0, 0, 0, 0, $target_width, $target_height, $cropped_width, $cropped_height);
    $dotpos = strrpos($source_path, ".");
    $imgName = substr($source_path, 0, $dotpos);
    $suffix = substr($source_path, $dotpos);
    $imgNew = $imgName . "_small" . $suffix;
    imagejpeg($target_image, $imgNew, 100);
    imagedestroy($source_image);
    imagedestroy($target_image);
    imagedestroy($cropped_image);
}

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/21347.html

相关文章

  • Web端裁剪图片方法

    摘要:由于在端,不能直接处理本地文件,因此可以在后台裁剪图片,或者利用的来处理。通过来访问生成的步骤获取裁剪坐标参照方法中的步骤步骤利用重绘图片首先要设置剪截后的图片大小相等的。 由于在Web端,JavaScript不能直接处理本地文件,因此可以在后台裁剪图片,或者利用html5的canvas来处理。 方法1:传送到后台剪切 步骤1:上传图片到后台,向前端返回图片URL 利用input标签,...

    ysl_unh 评论0 收藏0
  • 移动端适配问题

    摘要:读设备宽度,动态设置标签的属性中的值网易的做法网易的做法现在的设计稿都是宽度的宽,那要想实现样式设计图这种比较方便的折算方式,就要设置成也就是说总结总结是为了实现移动端自适应布局。适配问题 怎么适配iphone6 1px问题 为什么页面与设计稿会出现偏差? dpr=设备像素/ css像素,只有dpr等于1的时候,实际效果和设计稿的尺寸比例才是1:1。 因为iPhone6的DPR(设备像素比)...

    孙淑建 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<