-
-
//變數定義,畫橢圓弧時的角度大小
- define("ANGLELENGTH",3);
- /* *
- * 繪製圖片
- * @param $title 3D圖的標題
- * @param $dataArr 顯示的資料陣列
- * @param $labelArr 對應資料的標籤分類陣列
- * @param $colorArr 對應繪圖顏色的陣列
- * @param $a 畫布的基準寬度
- * @param $b 畫布的基準高度
- * @param $v 3D柱的高度
- * @param $ font 字體大小
- * @return 繪製成功的圖片存取路徑
- */
- function drawPieImg($title, $dataArr, $labelArr, $colorArr, $a=250, $b=120, $v=20, $font=10){
- $ox = 5+$a;
- $oy = 5+$b;
- $fw = imagefontwidth($font);
- $fh = imagefontheight($font);
- $n = count($ dataArr);//計算數組長度
- $w = 10+$a*2;
- $h = 10+$b*2+$v+($fh+2)*$n;
- / /建立畫板
- $img = imagecreate($w, $h);
- //轉RGB為索引色
- for($i=0; $i $colorArr[$i] = drawIndexColor($img,$colorArr[$i]);//為圖像$img分配顏色
- $clrbk = imagecolorallocate($img, 0xff, 0xff, 0xff);
- $
- $
- $
- $
- $
- $
- $
- $
- $
- $
- $
- $
- $ clrt = imagecolorallocate($img, 0x00, 0x00, 0x00);
- //填充背景色
- imagefill($img, 0, 0, $clrbk);
- //求和for($i=0; $i$tot += $dataArr[$i];
- //每個分類的起始角度大小
- $sd = 0;
- //每個分類所佔據的角度大小
- $ed = 0;
- $ly = 10+$b*2+$v;
- for($ i=0; $i$sd = $ed;
- $ed += $dataArr[$i]/$tot*360;
- //畫3d扇面
- draw3DSector($img, $ox, $oy+20, $a, $b, $v, $sd, $ed, $colorArr[$i]);
- //畫標籤
- imagefilledrectangle ($img, 5, $ly, 5+$fw, $ly+$fh, $colorArr[$i]);
- imagerectangle($img, 5, $ly, 5+$fw, $ly+$fh, $clrt);
- //中文轉碼
- $str = iconv("GB2312", "UTF-8", $labelArr[$i]);
- imagettftext($img, $font, 0 , 5+2*$fw, $ly+13, $clrt, "D:/wamp/www/source/font/simhei.ttf", $str.":".$dataArr[$i]."(" .(round(10000*($dataArr[$i]/$tot))/100)."%)");
- $ly += $fh+2;
- }
- //繪製圖片標題
- imagettftext($img, 15, 0, 5, 15, $clrt, "D:/wamp/www/source/font/simhei.ttf", iconv("GB2312", "UTF-8", $title));
- //輸出圖形
- header("Content-type: image/png");
- //輸出產生的圖片
- $imgFileName = "./".time( ).".png";
- imagepng($img,$imgFileName);
- return $imgFileName;
- }
- /**
- * 繪製3d扇面
- */
- function draw3DSector($img, $ox, $oy, $a, $b, $v, $sd, $ed, $clr) {
- drawSector($img, $ox, $oy, $a, $b, $sd, $ed , $clr);
- if($sdlist($red, $green, $blue) = drawDarkColor($img, $clr);
- //為影像分配顏色
- $clr=imagecolorallocate($img, $red, $green, $blue);
- if($ed>180)
- $ed = 180;
- list($sx, $sy) = getExy($a,$b,$sd);
- $sx += $ox;
- $sy += $oy;
- list($ex, $ey) = getExy($a, $ b, $ed);
- $ex += $ox;
- $ey += $oy;
- imageline($img, $sx, $sy, $sx, $sy+$v, $clr );
- imageline($img, $ex, $ey, $ex, $ey+$v, $clr);
- drawArc($img, $ox, $oy+$v, $a, $b, $sd, $ed, $clr);
- list($sx, $sy) = getExy($a, $b, ($sd+$ed)/2);
- $sy += $oy+$ v/2;
- $sx += $ox;
- imagefill($img, $sx, $sy, $clr);
- }
- }
- /**
- * 繪製橢圓弧
- * /
- function drawArc($img,$ox,$oy,$a,$b,$sd,$ed,$clr){
- $n = ANGLELENGTH >0 ? ceil(($ed-$sd )/ANGLELENGTH) : -1;
- $d = $sd;
- list($x0,$y0) = getExy($a,$b,$d);
- for($i=0 ; $i$d = ($d+ANGLELENGTH)>$ed?$ed:($d+ANGLELENGTH);
- list($x, $y) = getExy ($a, $b, $d);
- imageline($img, $x0+$ox, $y0+$oy, $x+$ox, $y+$oy, $clr);
- $x0 = $ x;
- $y0 = $y;
- }
- }
- /**
- * 繪製扇面
- */
- function drawSector($img, $ox, $oy, $a, $b , $sd, $ed, $clr) {
- $n = ANGLELENGTH > 0 ? ceil(($ed-$sd)/ANGLELENGTH) : -1;
- $d = $sd;
- list ($x0,$y0) = getExy($a, $b, $d);
- imageline($img, $x0+$ox, $y0+$oy, $ox, $oy, $clr);
- for($i=0; $i$d = ($d+ANGLELENGTH)>$ed?$ed:($d+ANGLELENGTH);
- list($ x, $y) = getExy($a, $b, $d);
- imageline($img, $x0+$ox, $y0+$oy, $x+$ox, $y+$oy, $clr);
- $x0 = $x;
- $y0 = $y;
- }
- imageline($img, $x0+$ox, $y0+$oy, $ox, $oy, $clr);
- list($x, $y) = getExy($a/2, $b/2, ($d+$sd)/2);
- imagefill($img, $x+$ox, $y+$ oy, $clr);
- }
- /**
- * 根據$clr顏色取得對應的柱的陰影色
- * @param $img 影像
- * @param $clr 顏色
- * @return rgb顏色陣列
- */
- function drawDarkColor($img,$clr){
- $rgb = imagecolorsforindex($img,$clr);
- return array($rgb["red"]/2,$rgb["green"]/2,$rgb["blue"]/2);
- }
- /*** 求角度$d對應的橢圓上的點座標** @param $a 橫座標* @param $b 縱座標* @param $d 角度* @return 對應橢圓點座標* /function getExy($a, $b, $d){$d = deg2rad($d);return array(round($a*cos($d)), round($ b*sin($d)));}
- /**
- * 為影像分配RGB索引色
- */
- function drawIndexColor($img, $clr){
- $red = ($clr>>16) & 0xff;
- $green = ($clr> >8)& 0xff;
- $blue = ($clr) & 0xff;
- return imagecolorallocate($img, $red, $green, $blue);
- }
- //測試範例
- $title = "動物園動物種類分佈情形";
- $dataArr = array(20, 10, 20, 20, 10, 20, 30, 10); //測試資料數組
- $labelArr = array ("大象", "長頸鹿", "鱷魚", "鴕鳥", "老虎", "獅子", "猴子", "斑馬");//標籤
- $colorArr = array(0x99ff00, 0xff6666, 0x0099ff, 0xff99ff, 0xffff99, 0x99ffff, 0xff33333, 0x009999); //對應顏色數組
- $result = drawPieImg($title, $dataA,$mlabA,$result = dchoo,$mmg($title, $dataA,$mlabA,$mcolor); $result." mce_src=".$result.">";
- ?>
-
複製代碼
代碼說明:
drawPieImg()函數包含8個參數,$title為餅狀圖的標題;$dataArr為需要顯示的資料數組;$labelArr為對應資料的標籤分類數組;$colorArr為對應資料的繪圖顏色數組,這4個參數是必須的,對於不同的系統應用傳遞對應的參數即可。
其餘4個參數,負責設定要產生的餅狀圖的大小,如果不設定則使用系統預設值。程式依照床底數組資料的大小,從0度開始繪製,方向依順時針方向依序繪製對應資料佔據的扇面大小。
有興趣的朋友,動手測試下以上的程式碼吧,看看繪出的餅狀圖效果如何呢? !
|