在調查程序中,咱們須要根據統計的數據來 生成各類圖表來生動的表示調查的百分比 。在PHP在這方面也是不負衆望,它中能夠經過加載GD庫來實現一開始。餅狀圖表對於查看一個值佔總值的百分比是一個好的方法。如今咱們就用PHP來實現一個餅形圖表,給你們講述PHP在這方面的應用。它的設計思想是:首先以用imagecreate()來生成一個空白圖形,而後在空白圖形中用imageare()圓弧函數先畫圓弧,再畫兩條線鏈接圓心和圓弧端點(PHP圖像函數不能畫扇形),再用imagefilltoborder函數來填充扇形。其程序實 現以下: <?php /* 把角度轉換爲弧度 */ function radians ($degrees) { return($degrees * (pi()/180.0)); } /* ** 取得在圓心爲(0,0)圓上 x,y點的值 */ function circle_point($degrees, $diameter) { $x = cos(radians($degrees)) * ($diameter/2); $y = sin(radians($degrees)) * ($diameter/2); return (array($x, $y)); } // 填充圖表的參數 $ChartDiameter = 200; //圖表直徑 $ChartFont = 2; //圖表字體 $ChartFontHeight = imagefontheight($ChartFont);//圖表字體的大小 $ChartData = array( "75","45");//用於生成圖表的數據,可經過數據庫來取得來肯定 //$ChartLabel = array("yes", "no"); //數據對應的名稱 //肯定圖形的大小 $ChartWidth = $ChartDiameter + 20; $ChartHeight = $ChartDiameter + 20 + (($ChartFontHeight + 2) * count($ChartData)); //肯定統計的總數 for($index = 0; $index < count($ChartData); $index++) { $ChartTotal += $ChartData[$index]; } $ChartCenterX = $ChartDiameter/2 + 10; $ChartCenterY = $ChartDiameter/2 + 10; //生成空白圖形 $image = imagecreate($ChartWidth, $ChartHeight); //分配顏色 $colorBody = imagecolorallocate($image, 0xFF, 0xFF, 0xFF); $colorBorder = imagecolorallocate($image, 0x00, 0x00, 0x00); $colorText = imagecolorallocate($image, 0x00, 0x00, 0x00); $colorSlice[] = imagecolorallocate($image, 0xFF, 0x00, 0x00); $colorSlice[] = imagecolorallocate($image, 0x00, 0xFF, 0x00); //填充背境 imagefill($image, 0, 0, $colorBody); /* ** 畫每個扇形 */ $Degrees = 0; for($index = 0; $index < count($ChartData); $index++) { $StartDegrees = round($Degrees); $Degrees += (($ChartData[$index]/$ChartTotal)*360); $EndDegrees = round($Degrees); $CurrentColor = $colorSlice[$index%(count($colorSlice))]; //畫圖F imagearc($image,$ChartCenterX,$ChartCenterY,$ChartDiameter, $ChartDiameter,$StartDegrees,$EndDegrees, $CurrentColor); //畫直線 list($ArcX, $ArcY) = circle_point($StartDegrees, $ChartDiameter); imageline($image,$ChartCenterX,$ChartCenterY,floor($ChartCenterX + $ArcX), floor($ChartCenterY + $ArcY),$CurrentColor); //畫直線 list($ArcX, $ArcY) = circle_point($EndDegrees, $ChartDiameter); imageline($image,$ChartCenterX,$ChartCenterY,ceil($ChartCenterX + $ArcX), ceil($ChartCenterY + $ArcY),$CurrentColor); //填充扇形 $MidPoint = round((($EndDegrees - $StartDegrees)/2) + $StartDegrees); list($ArcX, $ArcY) = circle_point($MidPoint, $ChartDiameter/2); imagefilltoborder($image,floor($ChartCenterX + $ArcX),floor($ChartCenterY + $ArcY), $CurrentColor,$CurrentColor); } //畫邊框 imagearc($image, $ChartCenterX, $ChartCenterY, $ChartDiameter, $ChartDiameter, 0, 180, $colorBorder); imagearc($image, $ChartCenterX, $ChartCenterY, $ChartDiameter, $ChartDiameter, 180, 360, $colorBorder); imagearc($image, $ChartCenterX, $ChartCenterY, $ChartDiameter+7, $ChartDiameter+7, 0, 180, $colorBorder); imagearc($image, $ChartCenterX, $ChartCenterY, $ChartDiameter+7, $ChartDiameter+7, 180, 360, $colorBorder); imagefilltoborder($image, floor($ChartCenterX + ($ChartDiameter/2) + 2), $ChartCenterY, $colorBorder, $colorBorder); //畫圖例 for($index = 0; $index < count($ChartData); $index++) { $CurrentColor = $colorSlice[$index%(count($colorSlice))]; $LineY = $ChartDiameter + 20 + ($index*($ChartFontHeight+2)); //draw color box imagerectangle($image, 10, $LineY, 10 + $ChartFontHeight, $LineY+$ChartFontHeight, $colorBorder); imagefilltoborder($image, 12, $LineY + 2, $colorBorder, $CurrentColor); //畫標籤 imagestring($image, $ChartFont, 20 + $ChartFontHeight, $LineY, "$ChartLabel[$index]: $ChartData[$index]", $colorText); } //到此腳本 已經生了一幅圖像的,如今須要的是把它發到瀏覽器上,重要的一點是要將標頭髮給瀏覽器,讓它知道是一個GIF文件。否則的話你只能看到一堆奇怪的亂碼 header("Content-type: image/gif"); //輸出生成的圖片 imagegif($image); ?> 保存爲chart.php,運行程序其結果如圖1. 但這是在服務器端生在GIF圖片,咱們要在HTML文件中應用就須要以下格式來調用它: <?php echo "<img src='chart.php' > " ?> 注:運行環境爲apache_1_3_12+php-4.0RC1+win98,windows平臺下. 在PHP中圖像函數都是在GD庫中完成,GD庫實際是處理GIF格式的免費軟件。要加載GD擴展才能使用php4的GD庫能夠到www.phpuser.com下載。解壓COPY php_gd.dll文件到PHP的執行目錄,而後編輯php.ini配置文件,找到配置文件中;extension=php_gd.dll"這行 去掉";"號,若是沒有發現則在配置文件的'Dynamic Extensions' 後增長一行extension=php_gd.dl。最後運行phpinfo()函數,你就能夠看到支持信息。 天極網Yesky 2000年06月23日