用PHP製做餅圖調查表

  在調查程序中,咱們須要根據統計的數據來 生成各類圖表來生動的表示調查的百分比 。在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日 
相關文章
相關標籤/搜索