新入手单反一周了,今天终于找上了机会带上老婆老妈去荔枝公园拍了一天的照,回来准备上传至相册,突然发现,每张图片都有点偏大,找工具也很累,直接上网,东拼西凑了点代码.实现将指定目录的图片,按指定大小范围缩放并输出到指定目录(含递归) ,供自己以后处理相片使用. 不多废话了,附代码.
header('Content-type:text/html; charset=utf-8'); require "lib/imgHelper.php"; $imgHelper = new imgHelper( "dir1" ); $imgHelper->setOutputDir( "dir2" ); //默认输出在1024 768 下等比缩放,需要自定义时,$imgHelper->setOutputSize(1440,900); $imgHelper->execution();
lib 库代码.
<?php/** * 图片处理助手 */class imgHelper{ public $srcFiles; //源文件 array public $srcDirs; //源目录 public $exportDir; //输出目录 public $exportFiles; //输出文件 array private $_option = array("maxWidth"=>"1024" , "maxHeight"=>"768"); function __construct($dir = '' , $option = array() ) { if (!$dir) return; $this->srcDirs = $dir; $this->srcFiles = $this->traversal($dir); $this->setOptions( $option ); } /** * 设置输出目录 * @param $dir */ public function setOutputDir( $dir ) { if( !is_dir( $dir )) { mkdir($dir , 0777 , 1);} $this->exportDir = $dir; } public function execution() { foreach( $this->srcFiles as $key =>$val ): $srcImg = $val; $toFile = str_replace( $this->srcDirs , $this->exportDir , $srcImg); //todo 简便处理. $maxWidth = $this->_option["maxWidth"]; $maxHeight = $this->_option["maxHeight"]; $this->resize($srcImg , $toFile , $maxWidth , $maxHeight ); endforeach; } //缩放图片. private function resize($srcImage,$toFile,$maxWidth = 100,$maxHeight = 100,$imgQuality=100) { //创建目录目录! $pInfo = pathinfo( $toFile ); $dir = $pInfo["dirname"]; if(!is_dir( $dir) ){ mkdir($dir , 0777 , 1);} list($width, $height, $type, $attr) = getimagesize($srcImage); if($width < $maxWidth || $height < $maxHeight) return ; switch ($type) { case 1: $img = imagecreatefromgif($srcImage); break; case 2: $img = imagecreatefromjpeg($srcImage); break; case 3: $img = imagecreatefrompng($srcImage); break; } $scale = min($maxWidth/$width, $maxHeight/$height); //求出绽放比例 if($scale < 1) { $newWidth = floor($scale*$width); $newHeight = floor($scale*$height); $newImg = imagecreatetruecolor($newWidth, $newHeight); imagecopyresampled($newImg, $img, 0, 0, 0, 0, $newWidth, $newHeight, $width, $height); $newName = ""; $toFile = preg_replace("/(.gif|.jpg|.jpeg|.png)/i","",$toFile); switch($type) { case 1: if(imagegif($newImg, "$toFile$newName.gif", $imgQuality)) return "$newName.gif"; break; case 2: if(imagejpeg($newImg, "$toFile$newName.jpg", $imgQuality)) return "$newName.jpg"; break; case 3: if(imagepng($newImg, "$toFile$newName.png", $imgQuality)) return "$newName.png"; break; default: if(imagejpeg($newImg, "$toFile$newName.jpg", $imgQuality)) return "$newName.jpg"; break; } imagedestroy($newImg); } imagedestroy($img); return false; } /** * 设置输出的大小 * @param string $width * @param string $height */ public function setOutputSize( $width = "1024" , $height = "768"){ $_option = array("maxWidth"=>"$width" , "maxHeight"=>"$height"); $this->setOptions( $_option ); } /** * 设置可选参数 * @param $option */ private function setOptions( $option) { foreach( $option as $key =>$val): if( isset( $option[$key]) && $option[$key] ){ $this->_option[$key] = $val; } endforeach; } /** * 遍得到文件夹下的所有文件 */ private function traversal($path) { if (!$path) return array(); $files = array(); if (!is_dir($path)) return; foreach (scandir($path) as $file) { if ($file != '.' && $file != '..') { $path2 = $path . '/' . $file; if (is_dir($path2)) { $temp = $this->traversal($path2); $files = array_merge($files, $temp); } else { if ($this->isIMg($file)) { $files[] = $path . "/" . $file; } } } } return $files; } /** * 判断是否是图片 * @param $file * @return bool */ private function isIMg($file) { $pInfo = pathinfo( $file); $extention = $pInfo["extension"]; return preg_match("/(jpg)|(png)|gif/i" , $extention); } /** * 调试数据 */ public function debug() {$this->pr($this->srcFiles, "待处理图片数组."); $this->pr( $this->srcDirs , "源目录"); $this->pr( $this->exportDir , "目标目录"); } private function pr($array, $title = 'DEBUG', $type = 'array', $width = '') { /*** @格式化输出 */ $title .= date("Y-m-d H:i:s"); $widthStr = ""; if ($width) $widthStr = "width:$width" . "px"; echo "<fieldset style=\"-moz-border-radius:5px 5px 5px 5px; -moz-box-shadow:0px 0px 10px rgba(00,00,00,0.45); border: 3px solid transparent; padding:3px; margin-top:20px; \"><legend style=\"color: #069; margin:3px; $widthStr \">$title</legend>"; echo "<div style = '-moz-border-radius:10px 10px 10px 10px;font-size:14px; color:#069; border:1px solid #F0FAF9; font-size:9pt; background:#F0FAF9; padding:5px;'>"; print("<pre class="brush:php;toolbar:false">"); if ($type == 'json') { $array = json_decode($array); } print_r($array); print(""); echo "
回复讨论(解决方案)
刚运行了一下,发现图片太多,运行时间不够,加一句 ini_set('max_execute_time',3600); 即可.
晕一个 上面的写错了,更正为 max_execution_time
代码没收了~~很好。
回帖超过30楼,送今日偷拍美女照片一张!
... ...
有点吗?有点嘛?有点啊?!
回帖超过30楼,送今日偷拍美女照片一张!
哈哈,类收起,....
$maxWidth = $this->_option["maxWidth"];
$maxHeight = $this->_option["maxHeight"];
放到循环外不是更好些?
resize 方法显得很臃肿
进来看看
这个不错,收藏一下,要用到
最近照了3k多张图片约20G图片,本以为程序写好后,就happy 的在运行转换了,谁知,当我当睡没多久,电脑遭遇老妈黑手,直接断电式关机.打开一看,只转了400张,再次运行,这400张图片将重复操作,于是折腾了一下代码,将重复去掉,并追加日志记录功能.
//在class imgHelper 内.添加如下代码. private $copyOverWrite = true; private $isLog = true; /** * 设置是否日志记录 * @param $bool */ public function setIsLog( $bool ) { $this->isLog = $bool; } /** * 设置是否覆盖 * @param $bool */ public function setCopyOverWrite( $bool ){ $this->copyOverWrite = $bool; } //记录日志. private function log( $str ,$title = '图片助手日志' ) { $logFile ="log/".date("Y-m-d").".log"; $pInfo = pathinfo( $logFile ); $dir = $pInfo["dirname"]; if(!is_dir( $dir) ){ mkdir($dir , 0777 , 1);} $str = date("H:i:s").$str . "\n"; file_put_contents($logFile, $str,FILE_APPEND); }
//对function resize() 进行修改//追加至首行. if( !$this->copyOverWrite && is_file($toFile)) //当设置为不覆盖,以及文件已存在时,跳过 { $this->log("$toFile 已存在,且系统设置为不覆盖,将做跳过处理","操作提示"); return ; } $this->log( "正在努力的生成 $toFile " );//修改后 private function resize($srcImage,$toFile,$maxWidth = 100,$maxHeight = 100,$imgQuality=100) { if( !$this->copyOverWrite && is_file($toFile)) //当设置为不覆盖,以及文件已存在时,跳过 { $this->log("$toFile 已存在,且系统设置为不覆盖,将做跳过处理","操作提示"); return ; } $this->log( "正在努力的生成 $toFile " ); //创建目录目录! $pInfo = pathinfo( $toFile ); $dir = $pInfo["dirname"]; if(!is_dir( $dir) ){ mkdir($dir , 0777 , 1);} list($width, $height, $type, $attr) = getimagesize($srcImage); if($width < $maxWidth || $height < $maxHeight) return ; switch ($type) { case 1: $img = imagecreatefromgif($srcImage); break; case 2: $img = imagecreatefromjpeg($srcImage); break; case 3: $img = imagecreatefrompng($srcImage); break; } $scale = min($maxWidth/$width, $maxHeight/$height); //求出绽放比例//...........
好建议,写得太随手,已修改!
$maxWidth = $this->_option["maxWidth"];
$maxHeight = $this->_option["maxHeight"];
放到循环外不是更好些?
resize 方法显得很臃肿
public function execution() { $maxWidth = $this->_option["maxWidth"]; $maxHeight = $this->_option["maxHeight"]; foreach( $this->srcFiles as $key =>$val ): $srcImg = $val; $toFile = str_replace( $this->srcDirs , $this->exportDir , $srcImg); //todo 简便处理. $this->resize($srcImg , $toFile , $maxWidth , $maxHeight ); endforeach; }
很不错~Mark学习一下~
技术流改变生活....等楼主放美女照片
代码收藏了,原来楼主是在深圳工作
来深圳两年了,有空一起出来,聊天吹水.
代码收藏了,原来楼主是在深圳工作
1.看你echo html 标签,这是第一个问题,这个程序理应适合用命令行执行,而不是web方式
2. if($width
3.递归目录用RecursiveDirectoryIterator 会爽很多,手册(用户讨论版)上面就有很多例程,以你能写出这个类的本领,看看应该例程不难掌握
4.resize的算法可以更加简单,再想想吧
5.图片很多的话建议用ImageMagick而不是GD,效率更高
6."\n" "/"换成PHP_EOL和DIRECTORY_SEPARATOR常量吧,兼容一下win
最后的最后,大量图片还是用工具做缩放吧,专业软件效率高而且能控制输出的图片质量
但你的这个类修改后可以用在处理上传图片的后续处理,还是用处不小
resize 这个方法,直接来自互联网, 我并未关注里面的写法,这里也不愿意去较真,更多的是快速整合与实现!
1.看你echo html 标签,这是第一个问题,这个程序理应适合用命令行执行,而不是web方式
2. if($width
3.递归目录用RecursiveDirectoryIterator 会爽很多,手册(用户讨论版)上面就有很多例程,以你能写出这个类的……
不要纠结效率啥的,前提是生活便利
imagick 核心三行代码完成缩略图,问题是你可能正好没imagick环境呢,或者安装了版本不匹配呢,这一折腾,我转换都快完成啦
$image = new Imagick("mypicture.png");
$image->thumbnailImage(200, 150, true);
$image->writeImage("thumb.png");
前面是凑字的,可完全忽略
我主要的意思是,LZ,你能否先放出图呢?
自己用更加要快,代码漂亮反而是次要的
不纠结上不了#30啊,看来我应该把6点分开6层楼……
呵呵,大家期待放照呢
我是来看美女的
楼主快爆照
过来参合一下~
F5已碎
有分散都没人接?快点盖到30楼
速速上图
接分外加看美女照片 兄弟们雄起啊 就差两楼了
楼下的 兄弟们终于等到你了....
照片涅
代码真心不错,最重要的是服务生活的思想,太酷了!
貌似我是30楼啊!!
中奖了!
sorry,图片在家里的机器上,回家立马补上~
不是美女揍一顿
我只对相片感兴趣
人格担保,图片来自偷拍~
请问我是看中间这个美女的上面还是下面?
echo '先别急嘛,伯虎兄,你要知道美女这种东西,跟鲜花一样,需要有绿叶来衬托才会显出她的娇媚,你再看看嘛';
美女看了,代码收下了!!哈哈
确实是美女,不过美女是不是穿个山寨衣服呀。 “never cry” 少个“y”?
出去走走,放松心情。周末程序员们都去拍照吧~
好东西,收藏了,谢谢!
先 mark, 日后再说
确实是美女,不过美女是不是穿个山寨衣服呀。 “never cry” 少个“y”?
哈哈 这个 可以有
46楼真相
F5已碎 呵呵,笑死我了。。。

PHP는 현대적인 프로그래밍, 특히 웹 개발 분야에서 강력하고 널리 사용되는 도구로 남아 있습니다. 1) PHP는 사용하기 쉽고 데이터베이스와 완벽하게 통합되며 많은 개발자에게 가장 먼저 선택됩니다. 2) 동적 컨텐츠 생성 및 객체 지향 프로그래밍을 지원하여 웹 사이트를 신속하게 작성하고 유지 관리하는 데 적합합니다. 3) 데이터베이스 쿼리를 캐싱하고 최적화함으로써 PHP의 성능을 향상시킬 수 있으며, 광범위한 커뮤니티와 풍부한 생태계는 오늘날의 기술 스택에 여전히 중요합니다.

PHP에서는 약한 참조가 약한 회의 클래스를 통해 구현되며 쓰레기 수집가가 물체를 되 찾는 것을 방해하지 않습니다. 약한 참조는 캐싱 시스템 및 이벤트 리스너와 같은 시나리오에 적합합니다. 물체의 생존을 보장 할 수 없으며 쓰레기 수집이 지연 될 수 있음에 주목해야합니다.

\ _ \ _ 호출 메소드를 사용하면 객체를 함수처럼 호출 할 수 있습니다. 1. 객체를 호출 할 수 있도록 메소드를 호출하는 \ _ \ _ 정의하십시오. 2. $ obj (...) 구문을 사용할 때 PHP는 \ _ \ _ invoke 메소드를 실행합니다. 3. 로깅 및 계산기, 코드 유연성 및 가독성 향상과 같은 시나리오에 적합합니다.

섬유는 PHP8.1에 도입되어 동시 처리 기능을 향상시켰다. 1) 섬유는 코 루틴과 유사한 가벼운 동시성 모델입니다. 2) 개발자는 작업의 실행 흐름을 수동으로 제어 할 수 있으며 I/O 집약적 작업을 처리하는 데 적합합니다. 3) 섬유를 사용하면보다 효율적이고 반응이 좋은 코드를 작성할 수 있습니다.

PHP 커뮤니티는 개발자 성장을 돕기 위해 풍부한 자원과 지원을 제공합니다. 1) 자료에는 공식 문서, 튜토리얼, 블로그 및 Laravel 및 Symfony와 같은 오픈 소스 프로젝트가 포함됩니다. 2) 지원은 StackoverFlow, Reddit 및 Slack 채널을 통해 얻을 수 있습니다. 3) RFC에 따라 개발 동향을 배울 수 있습니다. 4) 적극적인 참여, 코드에 대한 기여 및 학습 공유를 통해 커뮤니티에 통합 될 수 있습니다.

PHP와 Python은 각각 고유 한 장점이 있으며 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1.PHP는 간단한 구문과 높은 실행 효율로 웹 개발에 적합합니다. 2. Python은 간결한 구문 및 풍부한 라이브러리를 갖춘 데이터 과학 및 기계 학습에 적합합니다.

PHP는 죽지 않고 끊임없이 적응하고 진화합니다. 1) PHP는 1994 년부터 새로운 기술 트렌드에 적응하기 위해 여러 버전 반복을 겪었습니다. 2) 현재 전자 상거래, 컨텐츠 관리 시스템 및 기타 분야에서 널리 사용됩니다. 3) PHP8은 성능과 현대화를 개선하기 위해 JIT 컴파일러 및 기타 기능을 소개합니다. 4) Opcache를 사용하고 PSR-12 표준을 따라 성능 및 코드 품질을 최적화하십시오.

PHP의 미래는 새로운 기술 트렌드에 적응하고 혁신적인 기능을 도입함으로써 달성 될 것입니다. 1) 클라우드 컴퓨팅, 컨테이너화 및 마이크로 서비스 아키텍처에 적응, Docker 및 Kubernetes 지원; 2) 성능 및 데이터 처리 효율을 향상시키기 위해 JIT 컴파일러 및 열거 유형을 도입합니다. 3) 지속적으로 성능을 최적화하고 모범 사례를 홍보합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

Dreamweaver Mac版
시각적 웹 개발 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경
