php循环读取文件夹里面的图片 并将其裁剪成需要的尺寸

<?php

/**
 * 将读取到的目录以数组的形式展现出来
 * @return array
 * opendir() 函数打开一个目录句柄,可由 closedir(),readdir() 和 rewinddir() 使用。
 * is_dir() 函数检查指定的文件是否是目录。
 * readdir() 函数返回由 opendir() 打开的目录句柄中的条目。
 * @param array $files 所有的文件条目的存放数组
 * @param string $file 返回的文件条目
 * @param string $dir 文件的路径
 * @param resource $handle 打开的文件目录句柄
 */
function my_scandir($dir)
{
    //定义一个数组
    $files = array();
    //检测是否存在文件
    if (is_dir($dir)) {
        //打开目录
        if ($handle = opendir($dir)) {
            //返回当前文件的条目
            while (($file = readdir($handle)) !== false) {
                //去除特殊目录
                if ($file != "." && $file != "..") {
                    //判断子目录是否还存在子目录
                    if (is_dir($dir . "/" . $file)) {
                        //递归调用本函数,再次获取目录
                        $files[$file] = my_scandir($dir . "/" . $file);
                    } else {
                        //获取目录数组
                        $files[] = $dir . "/" . $file;
                    }
                }
            }
            //关闭文件夹
            closedir($handle);
            //返回文件夹数组
            return $files;
        }
    }
}
echo "<pre>";
$files = my_scandir($_SERVER['CONTEXT_DOCUMENT_ROOT']."\upload\\20190226");
foreach ($files as $key => $value) {
	 
	$imgname = substr(strrchr($value, '/'), 1);
	image_resize($value, $_SERVER['CONTEXT_DOCUMENT_ROOT'].'\smallpic\small-'.$imgname, '150px', '150px');
}
echo "</pre>";
function image_resize($src_file, $dst_file, $new_width, $new_height) {
    var_dump($src_file);
    var_dump($dst_file);
    var_dump($new_width);
    var_dump($new_height);
    // exit();
    $new_width = intval($new_width);
    $new_height = intval($new_width);
    if ($new_width < 1 || $new_height < 1) {
        echo "params width or height error !";
        exit();
    }
    if (!file_exists($src_file)) {
        echo $src_file . " is not exists !";
        exit();
    }
    // 图像类型
    $type = exif_imagetype($src_file);
    $support_type = array(IMAGETYPE_JPEG, IMAGETYPE_PNG, IMAGETYPE_GIF);
    if (!in_array($type, $support_type, true)) {
        echo
       "this type of image does not support! only support jpg , gif or png";
        exit();
    }
    //Load image
    switch ($type) {
        case IMAGETYPE_JPEG:
            $src_img = imagecreatefromjpeg($src_file);
            break;
        case IMAGETYPE_PNG:
            $src_img = imagecreatefrompng($src_file);
            break;
        case IMAGETYPE_GIF:
            $src_img = imagecreatefromgif($src_file);
            break;
        default:
            echo "Load image error!";
            exit();
    }
    $w = imagesx($src_img);
    $h = imagesy($src_img);
    $ratio_w = 1.0 * $new_width / $w;
    $ratio_h = 1.0 * $new_height / $h;
    $ratio = 1.0;
    // 生成的图像的高宽比原来的都小,或都大 ,原则是 取大比例放大,取大比例缩小(缩小的比例就比较小了)
    if (($ratio_w < 1 && $ratio_h < 1) || ($ratio_w > 1 && $ratio_h > 1)) {
        if ($ratio_w < $ratio_h) {
            $ratio = $ratio_h;
            // 情况一,宽度的比例比高度方向的小,按照高度的比例标准来裁剪或放大
        } else {
            $ratio = $ratio_w;
        }
        // 定义一个中间的临时图像,该图像的宽高比 正好满足目标要求
        $inter_w = (int) ($new_width / $ratio);
        $inter_h = (int) ($new_height / $ratio);
        $inter_img = imagecreatetruecolor($inter_w, $inter_h);
        //var_dump($inter_img);
        imagecopy($inter_img, $src_img, 0, 0, 0, 0, $inter_w, $inter_h)
                                          ;
        // 生成一个以最大边长度为大小的是目标图像$ratio比例的临时图像
        // 定义一个新的图像
        $new_img = imagecreatetruecolor($new_width, $new_height);
        //var_dump($new_img);exit();
        imagecopyresampled($new_img, $inter_img, 0, 0, 0, 0, $new_width
                         , $new_height, $inter_w, $inter_h);
        switch ($type) {
            case IMAGETYPE_JPEG:
                // 存储图像
                imagejpeg($new_img, $dst_file, 100);
                break;
            case IMAGETYPE_PNG:
                imagepng($new_img, $dst_file, 100);
                break;
            case IMAGETYPE_GIF:
                imagegif($new_img, $dst_file, 100);
                break;
            default:
                break;
        }
    } // end if 1
    // 2 目标图像 的一个边大于原图,一个边小于原图 ,先放大平普图像,然后裁剪
    // =if( ($ratio_w < 1 && $ratio_h > 1) || ($ratio_w >1 && $ratio_h <1) )
    else {
        $ratio = $ratio_h > $ratio_w ? $ratio_h : $ratio_w;
        //取比例大的那个值
        // 定义一个中间的大图像,该图像的高或宽和目标图像相等,然后对原图放大
        $inter_w = (int) ($w * $ratio);
        $inter_h = (int) ($h * $ratio);
        $inter_img = imagecreatetruecolor($inter_w, $inter_h);
        //将原图缩放比例后裁剪
        imagecopyresampled($inter_img, $src_img, 0, 0, 0, 0, $inter_w,
                                 $inter_h, $w, $h);
        // 定义一个新的图像
        $new_img = imagecreatetruecolor($new_width, $new_height);
        imagecopy($new_img, $inter_img, 0, 0, 0, 0, $new_width,
                                   $new_height);
        switch ($type) {
            case IMAGETYPE_JPEG:
                imagejpeg($new_img, $dst_file, 100);
                break;
            case IMAGETYPE_PNG:
                imagepng($new_img, $dst_file, 100);
                break;
            case IMAGETYPE_GIF:
                imagegif($new_img, $dst_file, 100);
                break;
            default:
                break;
        }
    } // if3
    return $dst_file;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值