PHP压缩图片

/**
 * 图片压缩处理
 * @param string $oldImg 源图片路径
 * @param int $width 自定义图片宽度
 * @param int $height 自定义图片高度
 * @return string 压缩后的图片路径
 */
function getThumb($oldImg,$width = 0,$height = 0){
    //判断该图片是否存在
    if(!file_exists($oldImg)){
        return false;
    }
    //判断图片格式(图片文件后缀)
    $pathArr = pathinfo($oldImg);
    $extend = $pathArr['extension'];
    if(!in_array($extend,['jpg','png','jpeg'])){
        return false;
    }
    //未设置宽高 则以原尺寸压缩
    $oldImgInfo = getimagesize($oldImg);
    if(!$width){
        $width = $oldImgInfo[0];
    }
    if(!$height){
        $height = $oldImgInfo[1];
    }
    //压缩图片文件名称
    $newImg = str_replace('.'.$extend, '_thumb_'.$width.'_'.$height.'.'.$extend, $oldImg);
    //判断是否已压缩图片,若是则返回压缩图片路径
    if(file_exists($newImg)){
        return $newImg;
    }
    //生成压缩图片,并存储到原图同路径下
    resizeImage($oldImg, $newImg, $width, $height);
    if(!file_exists($newImg)){
        return $oldImg;
    }
    return $newImg;
}

/**
 * 生成图片
 * @param string $oldImgPath 源图片路径
 * @param string $newImgPath 目标图片路径
 * @param int $width 生成图片宽
 * @param int $height 生成图片高
 */
function resizeImage($oldImgPath, $newImgPath, $width, $height) {
    $img = getimagesize($oldImgPath);
    switch ($img[2]) {
        case 1:
            $resource = @imagecreatefromgif($oldImgPath);
            break;
        case 2:
            $resource = @imagecreatefromjpeg($oldImgPath);
            break;
        case 3:
            $resource = @imagecreatefrompng($oldImgPath);
            break;
        default:
            $resource = @imagecreatefrompng($oldImgPath);
            break;
    }
    //原图的宽
    $pic_width = imagesx($resource);
    //原图的高
    $pic_height = imagesy($resource);
    //判断是否压缩
    $resize_width_tag = $resize_height_tag = false;
    //默认压缩率1,即等尺寸压缩
    $width_ratio = $height_ratio = 1;
    if(($width && $pic_width > $width) || ($height && $pic_height > $height)){
        //宽度是否压缩
        if($width && $pic_width > $width){
            $width_ratio = $width / $pic_width;
            $resize_width_tag = true;
        }
        //高度是否压缩
        if($height && $pic_height > $height){
            $height_ratio = $height / $pic_height;
            $resize_height_tag = true;
        }
        //选择压缩率
        if($resize_width_tag && $resize_height_tag){
            if ($width_ratio < $height_ratio){
                $ratio = $width_ratio;
            } else{
                $ratio = $height_ratio;
            }
        }elseif ($resize_width_tag && !$resize_height_tag){
            $ratio = $width_ratio;
        }elseif ($resize_height_tag && !$resize_width_tag){
            $ratio = $height_ratio;
        }else{
            $ratio = 1;
        }
        $new_width = $pic_width * $ratio;
        $new_height = $pic_height * $ratio;
        if(function_exists("imagecopyresampled")){
            $newim = imagecreatetruecolor($new_width, $new_height);
            imagecopyresampled($newim, $resource, 0, 0, 0, 0, $new_width, $new_height, $pic_width, $pic_height);
        }else{
            $newim = imagecreate($new_width, $new_height);
            imagecopyresized($newim, $resource, 0, 0, 0, 0, $new_width, $new_height, $pic_width, $pic_height);
        }
        imagejpeg($newim, $newImgPath);
        imagedestroy($newim);
    } else {
        imagejpeg($resource, $newImgPath);
    }
}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
<?php class ThumbHandler { var $dst_img;// 目标文件 var $h_src; // 图片资源句柄 var $h_dst;// 新图句柄 var $h_mask;// 水印句柄 var $img_create_quality = 100;// 图片生成质量 var $img_display_quality = 80;// 图片显示质量,默认为75 var $img_scale = 0;// 图片缩放比例 var $src_w = 0;// 原图宽度 var $src_h = 0;// 原图高度 var $dst_w = 0;// 新图总宽度 var $dst_h = 0;// 新图总高度 var $fill_w;// 填充图形宽 var $fill_h;// 填充图形高 var $copy_w;// 拷贝图形宽 var $copy_h;// 拷贝图形高 var $src_x = 0;// 原图绘制起始横坐标 var $src_y = 0;// 原图绘制起始纵坐标 var $start_x;// 新图绘制起始横坐标 var $start_y;// 新图绘制起始纵坐标 var $mask_word;// 水印文字 var $mask_img;// 水印图片 var $mask_pos_x = 0;// 水印横坐标 var $mask_pos_y = 0;// 水印纵坐标 var $mask_offset_x = 5;// 水印横向偏移 var $mask_offset_y = 5;// 水印纵向偏移 var $font_w;// 水印字体宽 var $font_h;// 水印字体高 var $mask_w;// 水印宽 var $mask_h;// 水印高 var $mask_font_color = "#ffffff";// 水印文字颜色 var $mask_font = 2;// 水印字体 var $font_size;// 尺寸 var $mask_position = 0;// 水印位置 var $mask_img_pct = 50;// 图片合并程度,值越大,合并程序越低 var $mask_txt_pct = 50;// 文字合并程度,值越小,合并程序越低 var $img_border_size = 0;// 图片边框尺寸 var $img_border_color;// 图片边框颜色 var $_flip_x=0;// 水平翻转次数 var $_flip_y=0;// 垂直翻转次数 var $cut_type=0;// 剪切类型 var $img_type;// 文件类型

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

凌晨四点的_LA

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值