php生成略缩图代码


Posted in PHP onJuly 16, 2012

虽然在HTML中可以通过指定图片的宽度和高度来随意缩放图片,但是这种方法不会减少图片的像素数目。图形文件的尺寸没有改变,当然也不会加快图片下载的速度了。当然也可以手动通过图形软件生成图片的缩略图,但对于大量的图片展示来说,这个工作量将十分巨大。为此微缩图的自动生成程序就被设计出来了。
PHP中提供的imagecopyresized函数就可以用来生成真正的缩赂图片。该函数的标推
语法如下:
语法:int imagecopyresized(int dst_im,int src_im,int dstX,int dstY,
int srcX,int srcY,int dstW,int dstH,int srcW,int srcH);

返回值:整数
函数种类:图形处理
内容说明:本函数可复制新图,并重新调整图片的大小尺寸。参数都是目的在前,来源在后。参数dst im及src_im为图片的handle。参数dstX、dstY、srcX、srcY分别为目的及来源的坐标。参数dstW、dstH、srcW、srcH分别为来源及目的的宽及高,欲调整的新图的尺寸就在这儿配置。
下面举个例子来说明这个函数的用法,对应的程序thumb.php如程序清单12—5所示。

程序清单12—5 thumb.php

<? 
// 本函数从源文件取出图像,设定成指定大小,并输出到目的文件 
// 源文件格式:gif,jpg,png 
// 目的文件格式:gif 
// $srcFile:源文件 
// $dstFile: 目标文件 
// $dstW:目标图片宽度 
// $dstH:目标文件高度 
function makethumb($srcFile,$dstFile,$dstW,$dstH) 
{ 
$data = GetImageSize($srcFile,&$info); 
switch ($data[2]) 
{ 
case 1: 
$imgsrc = @ImageCreateFromGIF($srcFile); 
break; 
case 2: 
$imgsrc = @ImageCreateFromJPEG($srcFile); 
break; 
case 3: 
$imgsrc = @ImageCreateFromPNG($srcFile); 
break; 
} 
$srcW = ImageSX($imgsrc); 
$srcH = ImageSY($imgsrc); 
$ni = ImageCreate($dstW,$dstH); 
ImageCopyResized($ni,$imgsrc,0,0,0,0,$dstW,$dstH,$srcW,$srcH); 
Imagegif($ni,$dstFile); 
// 如果需要输出到浏览器,那么将上一句改为 ImageJpeg($ni); 
// 如果需要其他格式的图片,改动最后一句就可以了 
} 
?>

在这个例子中,首先通过getimagesize()函数获得源图片的情况,再用 imagecreatefromgif()、
imagecreatefromjpeg()或imagecreatefrompng()创建一个源位图$imgsrc,然后用
imagecreate()函数创建一个目标位图,其长、宽各是源位图的一半。然后调用imagecopyresized()
函数,将源位图缩小后拷贝到目标位图中,最后再用imagegif()函数生成缩略图。
这里所用到的图形处理函数就是由安装的GD库提供的,现对其分别进行说明。首先
介绍getimagesize()函数,其标准语法如下。
语法:array getimagesize(string filename,array [imageinfo]);
返回值:数组
函数种类:图形处理
内容说明:本函数可用来取得GIF、JPEG及PNG 3种WWW上图片的高与宽,不需要安装GD library就可以便用本函数。返回的数组有4个元素,返回数组的第一个元素(索引值0)是图片的高度,单位是像素(pixel);第二个元素(索引值1)是图片的宽度;第三个元素(索引值2)是图片的文件格式,其值1为GIF格式、2为JPEG/JPG格式、3为PNG格式;
第四个元素(索引值3)为图片的高与宽字符串,height=xxx width=yyy。
通过getimagesize()函数的应用,能轻易获取图片的各种信息。下面给大家举一个获取图片宽度、高度、格式、文件大小的信息的例子,来进一步领会getimagesize()函数的使用 技巧。
程序imginfo如程序清单12—6所示。

程序清单12-6 imginfo.php

<?php 
function getImageInfo($img) //$img为图像文件绝对路径 
{ 
$img_info = getimagesize($img); 
switch ($img_info[2]) 
{ 
case 1: 
$imgtype = "GIF"; 
break; 
case 2: 
$imgtype = "JPG"; 
break; 
case 3: 
$imgtype = "PNG"; 
break; 
} 
$img_type = $imgtype."图像"; 
$img_size = ceil(filesize($img)/1000)."k"; //获取文件大小 $new_img_info = array ( 
"width"=>$img_info[0], 
"height"=>$img_info[1], 
"type"=>$img_type, 
"size"=>$img_size 
); 
print " width"; 
print $img_info[0]; 
print " height"; 
print $img_info[1]; 
print " format"; 
print $img_type; 
print " size"; 
print $img_size; 
print $new_img_info; 
} 
$img = "/www/htdocs/images/jf.gif"; 
getImageInfo($img); 
?>

在程序12-5中要创建一个缩略图,需要先创建一个用来绘图的空白的画布。
ImageCreate函数可以做到这一点。它将返回一个图像的标识符,并且需要告诉函数用像素
计算的画布有多大(x(宽度)与y(高度))。在程序12-5中用到的图形创建函数imagecreate()
的标准语法如下:
语法:int imagecreate(int x_size,int y_size);
返回值:整数
函数种类:图形处理
内容说明:本函数用来建立一张全空的图形。参数x_size、y_size为图形的尺寸,单位
为像素(pixel)。

如果要从已经存在的图片中取出图片文件代码,可以用imagecreatefromgif()、
imagecreatefromjpeg()或imagecreatefrompng(),例如函数imagecreatefromgif()就是从一个GIF
格式的图片文件中取出对应的图片源代码,其标准语法如下:
语法:int imagecreatefromgif(string filename);
返回值:整数
函数种类:图形处理
内容说明:本函数用来取出一张GIF格式图形,通常作为背景或者基本的画布样本使
用。参数filename可以是本地端的文件,也可以是网络的URL地址。返回值为GIF的文件
代码,可供其他函数使用。
在将源位图缩小后拷贝到目标位图中时,用到了imagecopyresized()函数,此函数可以
复制新图并调整大小,其标准语法如下:
语法:int imagecopyresized(int dst_im,int src_im,int dstX,int dstY,int srcX,int srcY,
int dstW,int dstH,int srcW,int srcH);
返回值:整数
函数种类:图形处理

内容说明:本函数可复制新图,并重新调整图片的大小尺寸。参数那是目的在前,来
源在后。参数ddst_im及src_im为图片的handle。参数dstX、dstY、srcX、srcY分别为目的
及来源的坐标。参数dstW、dstH、srcW、srcH分别为来源及目的的宽及高,若欲调整新图
的尺寸就在这里配置。
最后在输出图像时用到的imagegif()函数的标准语法如下:
语法:int imagegif(int im,string [filename]);
返问值:整数
函数种类:图形处理
内容说明:本函数用来建立一张GIF格式图形。参数im为使用ImageCreate()所建立
的图片代码,参数filename可省略,若无本参数filename,则会将图片直接送到浏览器端,
记得在送出图片之前要先送出使用Content-type:image/gif的标头字符串(header)到浏览器
端,以顺利传输图片。若要使用透明背景的GIF图,也就是GIF89a的格式,需要先使用
ImageColorTransparent()配置透明背景。本函数产生的GIF图,由于有版权的问题,因此
在商业上的使用还要多加考虑。

PHP 相关文章推荐
COM in PHP (winows only)
Oct 09 PHP
php目录管理函数小结
Sep 10 PHP
让PHP支持断点续传的源码
May 16 PHP
php中使用cookie来保存用户登录信息的实现代码
Mar 08 PHP
wamp下修改mysql访问密码的解决方法
May 07 PHP
浅析php过滤html字符串,防止SQL注入的方法
Jul 02 PHP
PHP之autoload运行机制实例分析
Aug 28 PHP
php通过隐藏表单控件获取到前两个页面的url
Sep 09 PHP
php魔术变量用法实例详解
Nov 13 PHP
Yii2学习笔记之汉化yii设置表单的描述(属性标签attributeLabels)
Feb 07 PHP
Zend Framework框架中实现Ajax的方法示例
Jun 27 PHP
在云虚拟主机部署thinkphp5项目的步骤详解
Dec 21 PHP
ThinkPHP 连接Oracle数据库的详细教程[全]
Jul 16 #PHP
PHP+Mysql日期时间如何转换(UNIX时间戳和格式化日期)
Jul 15 #PHP
在项目中寻找代码的坏命名
Jul 14 #PHP
注册页面之前先验证用户名是否存在的php代码
Jul 14 #PHP
php学习之function的用法
Jul 14 #PHP
php 操作调试的方法
Jul 12 #PHP
php输出xml格式字符串(用的这个)
Jul 12 #PHP
You might like
第二节 对象模型 [2]
2006/10/09 PHP
分页详解 从此分页无忧(PHP+mysql)
2007/11/23 PHP
PHP中file_exists函数不支持中文名的解决方法
2014/07/26 PHP
tp5(thinkPHP5框架)时间查询操作实例分析
2019/05/29 PHP
jQuery-serialize()输出序列化form表单值的方法
2012/12/26 Javascript
文本有关的样式和jQuery求对象的高宽问题分别说明
2013/08/30 Javascript
JS中把字符转成ASCII值的函数示例代码
2013/11/21 Javascript
jquery判断元素的子元素是否存在的示例代码
2014/02/04 Javascript
jquery插件开发之实现jquery手风琴功能分享
2014/03/10 Javascript
关于function类中定义变量this的简单说明
2016/05/28 Javascript
jquery插件格式实例分析
2016/06/16 Javascript
微信小程序 火车票查询实例讲解
2016/10/17 Javascript
把json格式的字符串转换成javascript对象或数组的方法总结
2016/11/03 Javascript
js 定位到某个锚点的方法
2016/11/19 Javascript
SpringBoot+Vue前后端分离,使用SpringSecurity完美处理权限问题的解决方法
2018/01/09 Javascript
javaScript强制保留两位小数的输入数校验和小数保留问题
2018/05/09 Javascript
vue-resource 拦截器interceptors使用详解
2021/01/18 Vue.js
[00:52]DOTA2齐天大圣预告片
2016/08/13 DOTA
Python中的测试模块unittest和doctest的使用教程
2015/04/14 Python
python实现的希尔排序算法实例
2015/07/01 Python
使用Python对MySQL数据操作
2017/04/06 Python
Python双精度浮点数运算并分行显示操作示例
2017/07/21 Python
python判断字符串是否是json格式方法分享
2017/11/07 Python
python构建深度神经网络(DNN)
2018/03/10 Python
python爬虫之模拟登陆csdn的实例代码
2018/05/18 Python
浅述python2与python3的简单区别
2018/09/19 Python
Python集成开发工具Pycharm的安装和使用详解
2020/03/18 Python
Python用5行代码实现批量抠图的示例代码
2020/04/14 Python
使用tkinter实现三子棋游戏
2021/02/25 Python
CSS3中设置3D变形的transform-style属性详解
2016/05/23 HTML / CSS
JACK & JONES瑞典官方网站:杰克琼斯欧式风格男装
2017/12/23 全球购物
营销人才自我鉴定范文
2013/12/25 职场文书
大学生党员自我批评
2014/02/14 职场文书
党纪处分决定书
2015/06/24 职场文书
祝福语集锦:给妹妹结婚的祝福语
2019/12/18 职场文书
vue实现同时设置多个倒计时
2021/05/20 Vue.js