php扇形分布图,PHP_php生成扇形比例图实例,我们在很多网站会看到一些图 - phpStudy...

php生成扇形比例图实例

我们在很多网站会看到一些图形的百分比显示图,像三个地区所占地多少或者是成绩等,给大家介绍一款用php生成的扇形比例百分比显示程序代码,不过使用它首先得有phpGD库支持。

//填充图表的参数

$ChartDiameter = 60; //图表直径

$ChartData = array(30,70);//用于生成图表的数据,可通过数据库来取得来确定也可以多个不过和颜色数组对应

//把角度转换为弧度

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));}

//确定图形的大小

$ChartWidth = $ChartDiameter + 20;

$ChartHeight = $ChartDiameter + 20;

//确定统计的总数

$ChartTotal = “”;

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, 0×00, 0×00, 0×00);

$colorText = imagecolorallocate($image, 0×00, 0×00, 0×00);

$colorSlice[] = imagecolorallocate($image, 0xFF, 0×00, 0×00);//这里是和你上面写的数组对应的颜色

$colorSlice[] = imagecolorallocate($image, 0×00, 0xFF, 0×00);

//填充背境

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);

}

//到此脚本 已经生了一幅图像的,现在需要的是把它发到浏览器上,重要的一点是要将标头发给浏览器,让它知道是一个GIF文件。不然的话你只能看到一堆奇怪的乱码

header(“Content-type: image/png”);

imagegif($image);

?>

相关阅读:

css判断不同分辨率显示不同宽度布局实现自适应宽度

OEM专供办Win10预览版11103安装截图曝光 水印还是11102版

JavaScript多线程详解

jquery获取radio值(单选组radio)

UITableView 实现汽车品牌(demo)

AngularJS基础 ng-model-options 指令简单示例

C#实现将程序运行信息写入日志的方法

Java异常分类及统一处理详解

分享3个php获取日历的函数

js中如何复制一个对象并获取其所有属性和属性对应的值

C++ AfxBeginThread的介绍/基本用法

NopCommerce架构分析之(五)Model绑定Action参数

jQuery代码实现发展历程时间轴特效

MYSQL必知必会读书笔记第五章之排序检索数据

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值