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

PHP
PHP 手机归属地查询 api
php 自写函数代码 获取关键字 去超链接
检查url链接是否已经有参数的php代码 添加 ? 或 &
PHP生成网页快照 不用COM不用扩展.
一步一步学习PHP(1) php开发环境配置
一步一步学习PHP(2):PHP类型
一步一步学习PHP(3) php 函数
一步一步学习PHP(4) php 函数 补充2
提高PHP编程效率 引入缓存机制提升性能
php 数组的合并、拆分、区别取值函数集
PHP采集相关教程之一 CURL函数库
IP138 IP地址查询小偷实现代码
php 生成静态页面的办法与实现代码详细版
一步一步学习PHP(5) 类和对象
一步一步学习PHP(6) 面向对象
Apache环境下PHP利用HTTP缓存协议原理解析及应用分析
PHP 截取字符串函数整理(支持gb2312和utf-8)
php foreach 使用&(与运算符)引用赋值要注意的问题
PHP IPV6正则表达式验证代码
用PHP ob_start()控制浏览器cache、生成html实现代码

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-12   浏览: 77 ::
收藏到网摘: 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>


很有趣吧,呵呵..