円グラフ|棒グラフ
PHP コード:---------------------------------------------- ----------------------------------
/*----------- -------------------------------------------------- -- ---------*/
//
// モジュール名: 3D 円グラフ クラス
//
// 著者:Avenger(avenger@php.net) 最終更新日: 2002-10- 30 11:19
// Copyright (c) 2002 by Avenger
/*-------------------------------- - --------------------------------------*/
//パブリック関数部分
//角度をラジアンに変換します
function deg2Arc($degrees) {
return($degrees * (pi()/180.0));
}
//RGB
function getRGB($color){
$R=( $color>>16) & 0xff;
$G=($color>>8) & 0xff;
$B=($color) & 0xff;
return (array($R,$G,$B) );
}
// (0, 0)を中心とする楕円上のx点とy点の値を取得
function pie_point($deg,$va,$vb){
$x= cos( deg2Arc($ deg)) * $va;
$y= sin(deg2Arc($deg)) * $vb;
return (array($x, $y));
}
//3D 円グラフ クラス
class Pie3d{
var $a; //楕円の長半軸
var $b; //楕円の短半軸
var $DataArray //各セクターのデータ
var $ ColorArray; //各セクターの色の要件は 16 進数で記述されますが、前に 0x
var は付きません $Fize; //フォント サイズ
//エッジと影は黒です
function Pie3d($pa=60,$pb=30, $sData="100,200,300,400,500" , $sColor="ee00ff,dd0000,cccccc,ccff00,00ccff",$fontsize=1) {
$this->a=$pa;
$this->b=$pb;
$this->DataArray=split(",",$sData);
$this->ColorArray=split(",",$sColor);
$this->Fsize=$fontsize;
}
function setA($v ){
$this->a=$v;
}
function getA(){
return $this->a;
}
function setB($v){
$ this->b= $v;
}
function getB(){
return $this->b;
}
function setDataArray($v){
$this->DataArray=split(", ",$v);
}
function getDataArray($v){
return $this->DataArray;
}
function setColorArray($v){
$this->ColorArray=split("," ,$v);
}
function getColorArray(){
return $this->ColorArray;
}
function DrawPie(){
$fsize=$this->Fsize;
$image=imagecreate( $this->a *2+40,$this->b*2+40);
$PieCenterX=$this->a+10;
$PieCenterY=$this->b+10;
$DoubleA=$this->a*2;
$DoubleB=$this->b*2;
list($R,$G,$B)=getRGB(0);
$colorBorder=imagecolorallocate($ image,$R,$ G,$B);
$DataNumber=count($this->DataArray);
//$DataTotal
for($i=0;$i<$DataNumber;$i++) $ DataTotal+=$this-> ;DataArray[$i]; //データの合計を計算
//背景を塗りつぶす
imagefill($image, 0, 0, imagecolorallocate($image, 255, 255, 255));
/*
** 各 A セクターを描画します
*/
$Degrees = 0;
for ($i = 0; $i <$DataNumber; $i++) {
$StartDegrees =round($Degrees);
$Degrees += (($this ->DataArray[$i]/$DataTotal)*360);
$EndDegrees =round($Degrees);
$percent =number_format($this->DataArray[$i]) ]/$DataTotal*100, 1) ;
list($R,$G,$B)=getRGB(hexdec($this->ColorArray[$i]));
$CurrentColor=imagecolorallocate($image,$ R,$G,$B);
if ($R>60 and $R<256) $R=$R-60;
if ($G>60 and $G<256) $G=$G-60 ;
if ($B>60 and $B<256) $B=$B-60;
$CurrentDarkColor=imagecolorallocate($image,$R,$G,$B);
//扇形の円弧を描画します
imagearc($image,$PieCenterX,$PieCenterY ,$DoubleA,$DoubleB,$StartDegrees,$EndDegrees,$CurrentColor);
//直線を描きます
list($ArcX, $ArcY) = pie_point($StartDegrees , $this->a , $this-> b);
imageline($image,$PieCenterX,$PieCenterY,floor($PieCenterX + $ArcX),floor($PieCenterY + $ArcY),$CurrentColor);
//直線を描く
list($ArcX, $ ArcY) = pie_point($EndDegrees,$this->a , $this->b);
imageline($image,$PieCenterX,$PieCenterY,ceil ($PieCenterX + $ArcX),ceil($PieCenterY + $ ArcY),$CurrentColor);
//セクターを塗りつぶします
$MidPoint =round((($EndDegrees - $StartDegrees)/2) + $StartDegrees);
list($ArcX, $ArcY) = Pie_point($MidPoint, $this->a*3/4 , $this->b*3/4);
imagefilltoborder($image,floor($PieCenterX + $ArcX),floor($PieCenterY + $ArcY),$CurrentColor ,$CurrentColor);
imagestring($image,$fsize,floor($PieCenterX + $ArcX-5),floor($PieCenterY + $ArcY-5) ,$percent."%",$colorBorder);
/ /影を描く
if ($StartDegrees>=0 and $StartDegrees if ($EndDegrees<=180){
for($k = 1; $k < 15; $k++)
imagearc($image,$PieCenterX, $PieCenterY+$k,$DoubleA, $DoubleB, $StartDegrees, $EndDegrees, $CurrentDarkColor);
}else{
for($k = 1; $k < 15; $k++)
imagearc($image,$PieCenterX, $PieCenterY+$k,$DoubleA, $DoubleB, $StartDegrees, 180, $CurrentDarkColor);
}
}
}
//生成した絵片を出力
imagepng($image,'consture.png');
imagedestroy($image);
}//EnddrawPie()
}//End class
$pie = new Pie3d ;
$pie->Pie3d($pa=300,$pb=150,$sData="100,200,300,400,500", $sColor="ee00ff,dd0000,cccccc,ccff00,ddddaa",$fontsize=5);
$pie ->DrawPie();
echo '';
?>