快速业务通道

说说PHP作图(一)

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-05-22

实在不敢说是在这里“讲”GD库,因为我用GD也才一两次而已,绝大多数的函数还没有接触到。可是三斑竹小刁热情地向我约稿,我只好硬着头皮写一点自己的心得。希望能够起到抛砖引玉的效果。

其实,我们在web页面里实现“图”的效果不一定非用GD不可,比较容易解决的是柱状图——用HTML就可以解决。比如:

<? $b = array(150,110,125,180,160,175,230,220); ?>

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312">

<title></title>

<style>

<!--

td{ font-size:9pt }

-->

</style>

</head>

<body>

<table border=0>

<tr valign="bottom"> /* (1) */

<?for($i=0;$i<8;$i++) { ?><td align="center">

<table height="<?echo $b[$i];?>" border=0> /* (2) */

<tr>

<td bgcolor="#3F7F9F" width="40"></td> /* (3) */

</tr>

</table><br><font color="#3F7F9F"><?echo $b[$i];?></font> /* (4) */

</td><? } ?>

</tr>

</table>

</body>

</html>

<? $b = array(150,110,125,180,160,175,230,220); ?> 是一组数据,数据从哪里来,是无关大局的,就看你的需要了;代码中需要说两句的地方我都加了注释,现在一一来说明。

(1) 这里要注意的是 valign="bottom",是为了让单元格的内容底部对齐。为什么加在<tr>里呢?可以让表格里这一行的内容都遵循这一对齐方式,不必在每一个<td>里指定,这样可以使PHP执行结果的HTML页的原代码节约好几十个字节呐!节约浏览者的宝贵时间。

(2) 注意,最关键的东西在这里!<table height="xxx">,我们就是利用table的height属性来实现不同高度的“柱”的。我这里为了让大家看得清楚,原始数据没有经过按比例的缩放,如果你的数据特别大,或者特别小,都不适宜直接赋给table的height属性,而应该根据情况按适当比例缩放这些数据。比如你估计你的这组数据的每一个数字都会在3000~8000之间,可以考虑将他们缩小25倍,即 height="<? echo floor(b[$i]/25); ?>"

(3) 提一下这一行里的 bgcolor="#xxxxxx",这是柱体的颜色(RGB)。其实,真正的柱状图应该每一个柱体用一种颜色,这里为了代码尽量简单,我用了这个for循环,因此也就没办法给每一个柱体指定一种颜色。——其实也是有办法的,我只是实在没有必要为了这个例子再写一个抽取颜色的函数来把初学者搞晕。所以,那一部分由你自己去完善吧。

(4) 在这里以与柱体相同的颜色显示真实的数据。当然,你也可以选择把这个数字放在柱体的顶上,可能更专业一些。然而我本人还是习惯于把它放在下面。

借助于HTML的table,我们可以构造出各种柱状图,这个例子讲的是用bgcolor来显示色块,除此以外,还可以用 background="(图片)" ,图片是带花纹的,于是柱状图的柱体就有了花纹。

而你把真实的数据用反差很大的颜色显示在上面注释(3)所示的那个<td>里,也是很好的效果。

前面是回避GD的一个有效的方法,但要做复杂的图形,就非用GD不可了。

sadly 的PHP4中文手册里,说GD函数库里有44个函数,但我看最新版的英文PHP4手册里,GD的函数已经有80余个!由于笔者英文比较差,读英文的手册只能连蒙带猜,所以不能确定新的GD库是否重新支持GIF了?不管怎样,我认为,既然我们在使用完全免费的PH

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号