-
PHP GD库生成图像的几个函数总结
这篇文章主要介绍了PHP GD库生成图像的几个函数总结,即imagegif、imagejpeg、imagepng、imagewbmp几个生成图片的函数,需要的朋友可以参考下
使用GD库中提供的函数动态绘制完成图像以后,就需要输出到浏览器或者将图像保存起来。在PHP中,可以将动态绘制完成的画布,直接生成GIF、JPEG、PNG和WBMP四种图像格式。可以通过调用下面四个函数生成这些格式的图像:
- bool imagegif(resource $image[,string $filename]) //以GIF格式将图像输出
- bool imagejpeg(resource $image[,string $filename[,int $quality]]) //以JPEG格式将图像输出
- bool imagepng(resource $image[,string $filename]) //以PNG格式将图像输出
- bool imagewbmp(resource $image[,string $filename[,int $foreground]]) //以WBMP格式将图像输出
以上四个函数的使用类似,前两个参数的使用是相同的。第一个参数$image为必选项,是前面介绍的图像引用句柄。如果部位这些函数提供其他参数,访问时则直接将原图像流出,并在浏览器使用中显示动态输出的图像,但一定要在输出之前,使用header()函数发送标头信息,用来通知浏览器使用正确的MIME类型对接收的内容进行解析,让它知道我们发送的是图片而不似乎文本的HTML,以下代码段通过自动检测GD库支持的图像类型,来写出移植性更好的PHP程序,如下所示:
- <?php
- if(function_exists("imagegif")){ //判断生成GIF格式图像的函数是否存在
- header("Content-type:image/gif"); //发送标头信息设置MIME类型为image/gif
- imagegif($im); //以GIF格式将图像输出到浏览器
- }elseif(function_exists("imageipeg")){
- header("Content-type:image/jpeg");
- imagejpeg($im,"",0.5);
- }elseif(function_exists("imagepng")){
- header("Content-type:image/png");
- imagepng($im);
- }elseif(function_exists("imagewbmp")){
- header("Content-type:image/wbmp");
- imagewbmp($im);
- }else{
- die("在PHP服务器中,不支持图像");
- }
- ?>
如果希望将PHP动态绘制的图像保存在本地服务器上,则必须在第二个可选参数中指定一个文件名字符串。这样不仅不会将图像直接输出到浏览器,也不需要使用header()函数发送标头信息。如果使用imageJPEG()函数生成JPEG格式的图像,还可以通过第三个可选参数$quality指定JPEG格式图像的品质,该参数可以提供的值是从0(最差品质,但文件最小)到100(最高品质,文件也最大)的整数,默认值为75.也可以为函数imageWBMP()提供第三个可选参数$forground,指定图像的前景颜色,默认颜色值为黑色。
原文链接:http://www.phpfensi.com/php/20210427/14610.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式