<?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;
}