| 订阅 | 在线投稿
分享
 
 
 

php 3维饼图的实现

2008-12-19 08:07:30 编辑來源:互联网 国际版 评论
 
 
本文为【php 3维饼图的实现】的汉字拼音对照版显示拼音
  yizhixiangfabiaodiandong西xizuijingangbaphp4zhongdephp_gd.dllgaodingjiupobujidaidexiangzuodiantuxingchengxuwanwankandaoyouxuduophpzuobingtudelizi,kanleyixiadoushi2weideyushijiuxiangzuoge3weidejingguonulipie3dwanchenglehaodong西xiyudajiafenxiangbuguoxiaodishiphpxinshoudaimakenengbugoujinglianxiwangdajiazhijiaogongtonglaiwanshanzhegechengxujidetongzhiwoestorm@yeah.net

  +------------------------+

  | pie3dfun.php//gongyonghanshu |

  +------------------------+

  define("ANGLE_STEP",5);//dingyihuatuoyuanhushidejiaodubuchang

  function chx_getdarkcolor($img,$clr){//qiu$clrduiyingdeanse

  $rgb=imagecolorsforindex($img,$clr);

  return array($rgb["red"]/2,$rgb["green"]/2,$rgb["blue"]/2);

  }

  function chx_getexy($a,$b,$d){//qiujiaodu$dduiyingdetuoyuanshangdedianzuobiao

  $d=deg2rad($d);

  return array(round($a*Cos($d)),round($b*Sin($d)));

  }

  function chx_arc($img,$ox,$oy,$a,$b,$sd,$ed,$clr){//tuoyuanhuhanshu

  $n=ceil(($ed-$sd)/ANGLE_STEP);

  $d=$sd;

  list($x0,$y0)=chx_getexy($a,$b,$d);

  for($i=0;$i<$n;$i++){

  $d=($d+ANGLE_STEP)>$ed?$ed:($d+ANGLE_STEP);

  list($x,$y)=chx_getexy($a,$b,$d);

  imageline($img,$x0+$ox,$y0+$oy,$x+$ox,$y+$oy,$clr);

  $x0=$x;

  $y0=$y;

  }

  }

  function chx_sector($img,$ox,$oy,$a,$b,$sd,$ed,$clr){//huashanmian

  $n=ceil(($ed-$sd)/ANGLE_STEP);

  $d=$sd;

  list($x0,$y0)=chx_getexy($a,$b,$d);

  imageline($img,$x0+$ox,$y0+$oy,$ox,$oy,$clr);

  for($i=0;$i<$n;$i++){

  $d=($d+ANGLE_STEP)>$ed?$ed:($d+ANGLE_STEP);

  list($x,$y)=chx_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)=chx_getexy($a/2,$b/2,($d+$sd)/2);

  imagefill($img,$x+$ox,$y+$oy,$clr);

  }

  function chx_sector3d($img,$ox,$oy,$a,$b,$v,$sd,$ed,$clr){//3dshanmian

  chx_sector($img,$ox,$oy,$a,$b,$sd,$ed,$clr);

  if($sd<180){

  list($R,$G,$B)=chx_getdarkcolor($img,$clr);

  $clr=imagecolorallocate($img,$R,$G,$B);

  if($ed>180) $ed=180;

  list($sx,$sy)=chx_getexy($a,$b,$sd);

  $sx+=$ox;

  $sy+=$oy;

  list($ex,$ey)=chx_getexy($a,$b,$ed);

  $ex+=$ox;

  $ey+=$oy;

  imageline($img,$sx,$sy,$sx,$sy+$v,$clr);

  imageline($img,$ex,$ey,$ex,$ey+$v,$clr);

  chx_arc($img,$ox,$oy+$v,$a,$b,$sd,$ed,$clr);

  list($sx,$sy)=chx_getexy($a,$b,($sd+$ed)/2);

  $sy+=$oy+$v/2;

  $sx+=$ox;

  imagefill($img,$sx,$sy,$clr);

  }

  }

  function chx_getindexcolor($img,$clr){//RBGzhuansuoyinse

  $R=($clr>>16) & 0xff;

  $G=($clr>>8)& 0xff;

  $B=($clr) & 0xff;

  return imagecolorallocate($img,$R,$G,$B);

  }

  ?>

  +--------------------------+

  | pie3d.php //sanweibingtuwenjian |

  +--------------------------+

  require("pie3dfun.php");

  $a=150;//tuoyuanchangbanzhou

  $b=50;//tuoyuanduanbanzhou

  $v=20;//yuanbinggaodu

  $font=5;//ziti

  $ox=5+$a;

  $oy=5+$b;

  $fw=imagefontwidth($font);

  $fh=imagefontheight($font);

  $datLst=array(30,10,20,20,10,20,10,20);//shuju

  $labLst=array("a1","a2","a3","a4","a5","a6","a7","a8");//biaoqian

  $clrLst=array(0x99ff00,0xff6666,0x0099ff,0xff99ff,0xffff99,0x99ffff,0xff3333,0x009999);

  $w=10+$a*2;

  $h=10+$b*2+$v+($fh+2)*count($datLst);

  $img=imagecreate($w,$h);

  //zhuanRGBweisuoyinse

  for($i=0;$i

  $clrbk=imagecolorallocate($img,0xff,0xff,0xff);

  $clrt=imagecolorallocate($img,0x00,0x00,0x00);

  //tianchongbeijingse

  imagefill($img,0,0,$clrbk);

  //qiuhe

  $tot=0;

  for($i=0;$i

  $sd=0;

  $ed=0;

  $ly=10+$b*2+$v;

  for($i=0;$i $sd=$ed;

  $ed+=$datLst[$i]/$tot*360;

  //huayuanbing

  chx_sector3d($img,$ox,$oy,$a,$b,$v,$sd,$ed,$clrLst[$i]);//$sd,$ed,$clrLst[$i]);

  //huabiaoqian

  imagefilledrectangle($img,5,$ly,5+$fw,$ly+$fh,$clrLst[$i]);

  imagerectangle($img,5,$ly,5+$fw,$ly+$fh,$clrt);

  imagestring($img,$font,5+2*$fw,$ly,

  $labLst[$i].":".$datLst[$i]."(".(round(10000*($datLst[$i]/$tot))/100)."%)",

  $clrt);

  $ly+=$fh+2;

  }

  //shuchutuxing

  header("Content-type:image/gif");

  imagegif($img);

  ?>原文
 
 
一直想发表点东西。最近刚把php4中的php_gd.dll搞定,就迫不及待的想做点图形程序玩玩。看到有许多php做饼图的例子,看了一下都是2维的,于是就想做个3维的。经过努力pie3d完成了,好东西与大家分享。不过小弟是php新手,代码可能不够精炼,希望大家指教共同来完善这个程序。记得通知我([url=mailto:estorm@yeah.net]estorm@yeah.net[/url]) +------------------------+ | pie3dfun.php//公用函数 | +------------------------+ define("ANGLE_STEP",5);//定义画椭圆弧时的角度步长 function chx_getdarkcolor($img,$clr){//求$clr对应的暗色 $rgb=imagecolorsforindex($img,$clr); return array($rgb["red"]/2,$rgb["green"]/2,$rgb["blue"]/2); } function chx_getexy($a,$b,$d){//求角度$d对应的椭圆上的点坐标 $d=deg2rad($d); return array(round($a*Cos($d)),round($b*Sin($d))); } function chx_arc($img,$ox,$oy,$a,$b,$sd,$ed,$clr){//椭圆弧函数 $n=ceil(($ed-$sd)/ANGLE_STEP); $d=$sd; list($x0,$y0)=chx_getexy($a,$b,$d); for($i=0;$i<$n;$i++){ $d=($d+ANGLE_STEP)>$ed?$ed:($d+ANGLE_STEP); list($x,$y)=chx_getexy($a,$b,$d); imageline($img,$x0+$ox,$y0+$oy,$x+$ox,$y+$oy,$clr); $x0=$x; $y0=$y; } } function chx_sector($img,$ox,$oy,$a,$b,$sd,$ed,$clr){//画扇面 $n=ceil(($ed-$sd)/ANGLE_STEP); $d=$sd; list($x0,$y0)=chx_getexy($a,$b,$d); imageline($img,$x0+$ox,$y0+$oy,$ox,$oy,$clr); for($i=0;$i<$n;$i++){ $d=($d+ANGLE_STEP)>$ed?$ed:($d+ANGLE_STEP); list($x,$y)=chx_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)=chx_getexy($a/2,$b/2,($d+$sd)/2); imagefill($img,$x+$ox,$y+$oy,$clr); } function chx_sector3d($img,$ox,$oy,$a,$b,$v,$sd,$ed,$clr){//3d扇面 chx_sector($img,$ox,$oy,$a,$b,$sd,$ed,$clr); if($sd<180){ list($R,$G,$B)=chx_getdarkcolor($img,$clr); $clr=imagecolorallocate($img,$R,$G,$B); if($ed>180) $ed=180; list($sx,$sy)=chx_getexy($a,$b,$sd); $sx+=$ox; $sy+=$oy; list($ex,$ey)=chx_getexy($a,$b,$ed); $ex+=$ox; $ey+=$oy; imageline($img,$sx,$sy,$sx,$sy+$v,$clr); imageline($img,$ex,$ey,$ex,$ey+$v,$clr); chx_arc($img,$ox,$oy+$v,$a,$b,$sd,$ed,$clr); list($sx,$sy)=chx_getexy($a,$b,($sd+$ed)/2); $sy+=$oy+$v/2; $sx+=$ox; imagefill($img,$sx,$sy,$clr); } } function chx_getindexcolor($img,$clr){//RBG转索引色 $R=($clr>>16) & 0xff; $G=($clr>>8)& 0xff; $B=($clr) & 0xff; return imagecolorallocate($img,$R,$G,$B); } ?> +--------------------------+ | pie3d.php //三维饼图文件 | +--------------------------+ require("pie3dfun.php"); $a=150;//椭圆长半轴 $b=50;//椭圆段半轴 $v=20;//圆饼高度 $font=5;//字体 $ox=5+$a; $oy=5+$b; $fw=imagefontwidth($font); $fh=imagefontheight($font); $datLst=array(30,10,20,20,10,20,10,20);//数据 $labLst=array("a1","a2","a3","a4","a5","a6","a7","a8");//标签 $clrLst=array(0x99ff00,0xff6666,0x0099ff,0xff99ff,0xffff99,0x99ffff,0xff3333,0x009999); $w=10+$a*2; $h=10+$b*2+$v+($fh+2)*count($datLst); $img=imagecreate($w,$h); //转RGB为索引色 for($i=0;$i $clrbk=imagecolorallocate($img,0xff,0xff,0xff); $clrt=imagecolorallocate($img,0x00,0x00,0x00); //填充背景色 imagefill($img,0,0,$clrbk); //求和 $tot=0; for($i=0;$i $sd=0; $ed=0; $ly=10+$b*2+$v; for($i=0;$i $sd=$ed; $ed+=$datLst[$i]/$tot*360; //画圆饼 chx_sector3d($img,$ox,$oy,$a,$b,$v,$sd,$ed,$clrLst[$i]);//$sd,$ed,$clrLst[$i]); //画标签 imagefilledrectangle($img,5,$ly,5+$fw,$ly+$fh,$clrLst[$i]); imagerectangle($img,5,$ly,5+$fw,$ly+$fh,$clrt); imagestring($img,$font,5+2*$fw,$ly, $labLst[$i].":".$datLst[$i]."(".(round(10000*($datLst[$i]/$tot))/100)."%)", $clrt); $ly+=$fh+2; } //输出图形 header("Content-type:image/gif"); imagegif($img); ?>
󰈣󰈤
日版宠物情人插曲《Winding Road》歌词

日版宠物情人2017的插曲,很带节奏感,日语的,女生唱的。 最后听见是在第8集的时候女主手割伤了,然后男主用嘴帮她吸了一下,插曲就出来了。 歌手:Def...

兄弟共妻,我成了他们夜里的美食

老钟家的两个儿子很特别,就是跟其他的人不太一样,魔一般的执着。兄弟俩都到了要结婚的年龄了,不管自家老爹怎么磨破嘴皮子,兄弟俩说不娶就不娶,老父母为兄弟两操碎了心...

网络安全治理:国家安全保障的主要方向是打击犯罪,而不是处置和惩罚受害者

来源:中国青年报 新的攻击方法不断涌现,黑客几乎永远占据网络攻击的上风,我们不可能通过技术手段杜绝网络攻击。国家安全保障的主要方向是打击犯罪,而不是处置和惩罚...

 
 
 
>>返回首页<<
 为你推荐
 
 
 
 转载本文
 UBB代码 HTML代码
复制到剪贴板...
 
 
 热帖排行
 
美女灿烂的笑容(二)
美女灿烂的笑容(一)
...雨秋
欧洲
 
 
王朝网络微信公众号
微信扫码关注本站公众号wangchaonetcn
 
  免责声明:本文仅代表作者个人观点,与王朝网络无关。王朝网络登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述,其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
©2005- 王朝网络 版权所有