使用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,指定圖像的前景顏色,默認顏色值為黑色。