的颜色显示在上面注释(3)所示的那个<td>里,也是很好的效果。
前面是回避GD的一个有效的方法,但要做复杂的图形,就非用GD不可了。
sadly 的PHP4中文手册里,说GD函数库里有44个函数,但我看最新版的英文PHP4手册里, GD的函数已经有80余个!由于笔者英文比较差,读英文的手册只能连蒙带猜,所以不能确定 新的GD库是否重新支持GIF了?不管怎样,我认为,既然我们在使用完全免费的PHP,何必要 “冒险”去用有版权的GIF?何不免费到底,用PNG呢?只要你不需用动画,PNG同样可以做出 象GIF一样小的文件!
下面我就结合一段程序,一句代码一句代码地说说常用的这些GD函数。 从开头说起吧。
<? Header("Content-type: image/png"); // 这是发送一个HTTP头,告诉浏览器:“你听着,这是一个图象,可别当成文字来显示呀!” // 由于我个人的喜好,用了PNG,当然你也可以用 Header("Content-type: image/gif"); // 或者 Header("Content-type: image/jpeg"); $im = ImageCreate (50, 100); // 创建图象。注意,图象在创建的时候还没有被指定图象格式。 // ImageCreate函数,两个参数,无庸质疑,这是创建的图象的宽度和高度。 // 它的返回值是一个int数值,这个数值相当重要,你继续绘制这个图象、 // 直到你输出这个图象之前,无处不用到这个数值,我们暂且称之为图象的ID。 // 因为使用的频率相当高,所以,我们把它赋给一个名字比较短的变量。 // 现在我们先画一条线吧。画线的函数是这样的: // imageline (int im, int x1, int y1, int x2, int y2, int col); // 第一个参数im,就是图象的ID,后面的 x1,y1,x2,y2,不用说了, // 是起点(x1,y1) 终点(x2,y2)的坐标呀!(图象的左上角坐标是 (0,0) ) // 最后一个参数是什么呀?是颜色!GD要求针对图象定义颜色,用定义的这些颜色来作图。 // 为什么要针对图象定义颜色?我猜测,是为了GIF、PNG等图象用之做“调色板”的。 // 这牵扯到图象本身的知识,这里不赘述了。 // 所以,画线之前,我们还要先定义颜色(真麻烦)。
// $col_red = ImageColorAllocate($im, 255,192,192); // 这个函数四个参数,第一个$im……还用得着我每次都说嘛?下次就不说啦! // 后面三个参数就是要定义的颜色的红(R)、绿(G)、蓝(B)的分量,0~255之间。 // 这又牵扯到物理—光学的知识了。红、绿、蓝三原色光分量的不同, // 产生了千变万化的色彩。上面我定义的这个颜色,红255,绿192,蓝192。 // 如果没有搞错,这是一个较亮的红色。等一会儿我们来画一条线试试看。 // 为什么要等一会儿呢?因为一幅图只有一种颜色的话,是什么也看不出来的! // 我们把背景搞成黑的先! // 虽然手册上没有明确表示,但是我发现最先定义的颜色将默认被作为背景。 $col_black = ImageColorAllocate($im, 0,0,0); // 定义了一种颜色,红光、绿光、蓝光都没有,自然黑咕隆咚——黑色。 // 然后再定义画线用的颜色: $col_red = ImageColorAllocate($im, 255,192,192); // 现在可以开始画红线了: imageline ($im, 10, 20, 45, 85, $col_red); // 别急,这句完了以后你还看不到图象。 ImagePNG($im); // 这一句就输出图象了,ImagePNG()输出png图象,ImageJPEG输出jpeg图象, // ImageGIF输出gif图象…… // 不要忘记这里有一个参数,如果在屏幕显示, |