当前位置: 首页 > 图文教程 > 网络编程 > PHP > php下用GD生成生成缩略图的两个选择和区别

PHP
php 接口类与抽象类的实际作用
php google或baidu分页代码
完美解决PHP中文乱码
PHP Session变量不能传送到下一页的解决方法
Ajax+PHP 边学边练之四 表单
php session_start()关于Cannot send session cache limiter - headers already sent错误解决方法
php中$this->含义分析
php操作sqlserver关于时间日期读取的小小见解
php 获取客户端的真实ip
php读取html并截取字符串的简单代码
PHP MYSQL乱码问题,使用SET NAMES utf8校正
php 一元分词算法
php smarty模版引擎中的缓存应用
PHP5 面向对象(学习记录)
php zip文件解压类代码
Asp.net 文本框全选的实现
php 无限分类的树类代码
又一个php 分页类实现代码
PHPMyadmin 配置文件详解(配置)
Ajax+PHP边学边练 之五 图片处理

PHP 中的 php下用GD生成生成缩略图的两个选择和区别


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-12   浏览: 80 ::
收藏到网摘: n/a

PHP的GD扩展提供了两个函数来缩放图像:
ImageCopyResized(dest, src, dx, dy, sx, sy, dw, dh, sw, sh);
ImageCopyResampled(dest, src, dx, dy, sx, sy, dw, dh, sw, sh);

ImageCopyResized( )函数在所有GD版本中有效,但其缩放图像的算法比较粗糙,可能会导致图像边缘的锯齿。GD 2.x中新增了一个ImageCopyResampled( )函数,其像素插值算法得到的图像边缘比较平滑(但该函数的速度比ImageCopyResized()慢)。

来看一个例子,我们将这个图缩小四倍:
<?php
$src
= ImageCreateFromJPEG('/upload/tech/20091012/20091012014550_42e7aaa88b48137a16a1acd04ed91125.jpg');
$width = ImageSx($src);
$height = ImageSy($src);
$x = $width/2; $y = $height/2;
$dst = ImageCreateTrueColor($x,$y);
ImageCopyResized($dst,$src,0,0,0,0,$x,$y,$width,$height);
//ImageCopyResampled($dst,$src,0,0,0,0,$x,$y,$width,$height);
header('Content-Type: image/jpeg');
ImageJPEG($dst,'',100);
?>
原图:

使用
ImageCopyResized()函数生成的结果:


使用ImageCopyResampled()函数生成的结果:



很明显可以看到两个函数生成的图像效果是不一样的,ImageCopyResampled()函数生成的结果比较平滑,效果较好。
顺便贴一个效果,用ASCII表示图像。ImageColorAt()有一个很有趣的用处,它可以循环检查
图像中的每一个像素的颜色,然后对该颜色数据进行操作。
源代码:
<html>
<body bgcolor="#000000" style="line-height:6pt"> <?php 
$im
= imagecreatefromjpeg('/upload/tech/20091012/20091012014552_a4300b002bcfb71f291dac175d52df94.jpg'
);
$dx = imagesx($im
);
$dy = imagesy($im
);
for(
$y = 0; $y < $dy; $y
++) {
for(
$x=0; $x < $dx; $x
++) {
$col = imagecolorat($im, $x, $y
);
$rgb = imagecolorsforindex($im,$col
);
printf('<font color=#%02x%02x%02x>*</font>'
,
$rgb['red'],$rgb['green'],$rgb['blue'
]);
}
echo
"<br>\n"
;
}
imagedestroy($im
);
?>
</body></html>


很有趣吧,呵呵..