ホームページ  >  記事  >  バックエンド開発  >  円グラフを描画するための PHP コード例

円グラフを描画するための PHP コード例

WBOY
WBOYオリジナル
2016-07-25 08:59:061421ブラウズ
  1. //楕円弧を描くときの角度のサイズを変数定義
  2. define("ANGLELENGTH",3);
  3. /**
  4. * 絵を描く
  5. * @param $title 3D絵のタイトル
  6. * @param $dataArr 表示されるデータ配列
  7. * @param $labelArr データに対応するラベル分類配列
  8. * @param $colorArr 対応する配列描画色
  9. * @param $a キャンバスのベースの幅
  10. * @param $b キャンバスのベースの高さ
  11. * @param $v 3D柱の高さ
  12. * @param $font フォントサイズ
  13. * @return 描画を成功させるための画像アクセスパス
  14. */
  15. functiondrawPieImg($title, $ dataArr 、 $labelArr、 $colorArr、 $a=250、 $b=120、 $v=20、 $font=10){
  16. $ox = 5+$a;
  17. $oy = 5+$b;
  18. $fw = imagefontwidth($font);
  19. $fh = imagefontheight($font);
  20. $n = count($dataArr);//配列の長さを計算します
  21. $w = 10+$a*2;
  22. $h = 10+ $b *2+$v+($fh+2)*$n;
  23. //アートボードを作成
  24. $img = imagecreate($w, $h);
  25. //RGBをインデックスカラーに変換
  26. for($i=0 ; $ i<$n; $i++)
  27. $colorArr[$i] =drawIndexColor($img,$colorArr[$i]);//画像に色を割り当てる $img
  28. $clrbk = imagecolorallocate($img, 0xff, 0xff, 0xff);
  29. $clrt = imagecolorallocate($img, 0x00, 0x00, 0x00);
  30. //背景色を塗りつぶします
  31. imagefill($img, 0, 0, $clrbk);
  32. //合計
  33. $tot = 0;
  34. for($i=0; $i<$n; $i++)
  35. $tot += $dataArr[$i];
  36. //各カテゴリの開始角度サイズ
  37. $sd = 0;
  38. // Every 各カテゴリが占める角度
  39. $ed = 0;
  40. $ly = 10+$b*2+$v;
  41. for($i=0; $i<$n; $i++){
  42. $sd = $ ed;
  43. $ed += $dataArr[$i]/$tot*360;
  44. //3D セクターを描画
  45. draw3DSector($img, $ox, $oy+20, $a, $b, $v, $sd , $ed, $colorArr[$i]);
  46. //ラベルを描画します
  47. imagefilledrectangle($img, 5, $ly, 5+$fw, $ly+$fh, $colorArr[$i]);
  48. imagerectangle($ img, 5, $ly, 5+$fw, $ly+$fh, $clrt);
  49. //中国語トランスコーディング
  50. $str = iconv("GB2312", "UTF-8", $labelArr[$i]) ;
  51. 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)."%)");
  52. $ly += $fh+2;
  53. }
  54. //画像のタイトルを描画
  55. imagettftext($img, 15, 0, 5, 15, $clrt, "D:/wamp/www/source/font/simhei.ttf", iconv("GB2312", "UTF- 8",$title));
  56. //グラフィックを出力
  57. header("Content-type: image/png");
  58. //生成された画像を出力
  59. $imgFileName = "./".time().".png ";
  60. imagepng($img,$imgFileName);
  61. return $imgFileName;
  62. }
  63. /**
  64. * 3D セクターを描画します
  65. */
  66. functiondraw3DSector($img, $ox, $oy, $a, $b, $v, $sd, $ed, $clr) {
  67. drawSector($img, $ox, $oy, $a, $b, $sd, $ed, $clr);
  68. if($sd<180){
  69. list( $red, $green, $blue) =drawDarkColor($img, $clr);
  70. //画像に色を割り当てます
  71. $clr=imagecolorallocate($img, $red, $green, $blue);
  72. if($ ed>180)
  73. $ed = 180;
  74. list($sx, $sy) = getExy($a,$b,$sd);
  75. $sx += $ox;
  76. $sy += $oy;
  77. list ( $ex, $ey) = getExy($a, $b, $ed);
  78. $ex += $ox;
  79. $ey += $oy;
  80. imageline($img, $sx, $sy, $sx , $sy+$v, $clr);
  81. imageline($img, $ex, $ey, $ex, $ey+$v, $clr);
  82. drawArc($img, $ox, $oy+$v, $a , $b, $sd, $ed, $clr);
  83. list($sx, $sy) = getExy($a, $b, ($sd+$ed)/2);
  84. $sy += $oy+$ v /2;
  85. $sx += $ox;
  86. imagefill($img, $sx, $sy, $clr);
  87. }
  88. }
  89. /**
  90. * 楕円弧を描きます
  91. */
  92. functiondrawArc($img,$ox) , $oy,$a,$b,$sd,$ed,$clr){
  93. $n = ANGLELENGTH >0 ? ceil(($ed-$sd)/ANGLELENGTH) : -1;
  94. $d = $ sd ;
  95. list($x0,$y0) = getExy($a,$b,$d);
  96. for($i=0; $i<$n; $i++){
  97. $d = ($d+ ANGLELENGTH )>$ed?$ed:($d+ANGLELENGTH);
  98. list($x, $y) = getExy($a, $b, $d);
  99. imageline($img, $x0+$ox, $ y0+$oy, $x+$ox, $y+$oy, $clr);
  100. $x0 = $x;
  101. $y0 = $y;
  102. }
  103. }
  104. /**
  105. * 扇子を描きます
  106. */
  107. functiondrawSector( $ img, $ox, $oy, $a, $b, $sd, $ed, $clr) {
  108. $n = ANGLELENGTH > 0 ceil(($ed-$sd)/ANGLELENGTH) : -1;
  109. $d = $sd;
  110. list($x0,$y0) = getExy($a, $b, $d);
  111. imageline($img, $x0+$ox, $y0+$oy, $ox, $oy , $clr);
  112. for($i=0; $i$d = ($d+ANGLELENGTH)>$ed?$ed:($d+ANGLELENGTH);
  113. list ( $x, $y) = getExy($a, $b, $d);
  114. imageline($img, $x0+$ox, $y0+$oy, $x+$ox, $y+$oy, $clr);
  115. $x0 = $x;
  116. $y0 = $y;
  117. }
  118. imageline($img, $x0+$ox, $y0+$oy, $ox, $oy, $clr);
  119. list($x, $y ) = getExy($a/2, $b/2, ($d+$sd)/2);
  120. imagefill($img, $x+$ox, $y+$oy, $clr);
  121. }
  122. /**
  123. * $clr color に基づいて、対応する列の影の色を取得します
  124. * @param $img image
  125. * @param $clr color
  126. * @return rgb color array
  127. */
  128. functiondrawDarkColor($img,$clr){
  129. $rgb = imagecolorsforindex($img,$clr);
  130. return array($rgb["red"]/2,$rgb["green"] / 2,$rgb["blue"]/2);
  131. }
  132. /**+*/
  133. function getExy($a, $b, $d){
  134. $d = deg2rad($d);
  135. return array(round($a*cos($d)),round($b*sin($d)));
  136. }
  137. /**
  138. * RGB インデックスカラーを画像に割り当てます
  139. */
  140. functiondrawIndexColor($img, $clr){
  141. $red = ($clr>>16) & 0xff;
  142. $green = ($clr>>8)& 0xff;
  143. $blue = ($clr) & 0xff;
  144. return imagecolorallocate($img, $red, $green, $blue);
  145. }
  146. //テスト例
  147. $title = "動物園の動物の種類の分布";
  148. $dataArr = array(20, 10, 20, 20, 10, 20, 30, 10); //テストデータ array
  149. $labelArr = array("ゾウ", "キリン", "ワニ", "ダチョウ", "トラ" , "Lion", "Monkey", "Zebra"); //Tag
  150. $colorArr = array(0x99ff00, 0xff6666, 0x0099ff, 0xff99ff, 0xffff99, 0xff3333, 0x009999); // 対応する色の配列
  151. $result =drawパイ画像($title, $dataArr,$labelArr,$colorArr);
  152. echo "";
  153. ?>
コードをコピー

コードの説明: drawPieImg() 関数には 8 つのパラメータが含まれます。$title は円グラフのタイトルです。$dataArr は、対応するデータのラベル分類配列です。これらの 4 つのパラメータは必須です。異なるシステム アプリケーションに対応するパラメータを渡すだけです。

残りの 4 つのパラメータは、生成される円グラフのサイズを設定します。設定されていない場合は、システムのデフォルト値が使用されます。プログラムはベッド底部の配列データのサイズに応じて0度から描画を開始し、時計回りに対応するデータが占めるセクタサイズを描画します。

興味のある方は、上記のコードを試して、円グラフがどのように見えるかを確認してください。 !



声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。