使用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,指定影像的前景顏色,預設顏色值為黑色。
更多PHP GD庫生成圖像的幾個函數總結相關文章請關注PHP中文網!