马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
也得学会了PHP。然后再学,见异思迁是最不可取的,狗熊掰玉米就是这个道理,如果经常中途放弃,只能是一无所获,还浪费了N多的时间和经历,得不偿失,最重要的是,你会被别人瞧不起。 前次说了一种复杂的躲避GD的作图办法,尔后又用GD作了最复杂的一幅“图”――直线。
此次我就接着画直线向下说。前次代码中具体注释过的局部,此次不再赘述。
<?
Header("Content-type: image/png");
$im = ImageCreate (200, 100);
$col_black = ImageColorAllocate($im, 0,0,0);
$col_orn = ImageColorAllocate($im, 255,192,0);
// 明天用橘色吧。
// 跟 imageline 函数完整不异的用法,
ImageDashedLine($im,0,100,199,100,$col_orn);
// 如许就画了一条虚线。
// 上面咱们来做个实验。用以申明一个成绩。
$col_yel = ImageColorAllocate($im, 255,255,0);
// 黄色。
ImageLine($im,0,99,199,99,$col_yel);
// 在图像的最下沿画了一条黄色的线。
ImageLine($im,200,0,200,100,$col_orn);
// 试图在图像最右沿画一条澄色的线,了局甚么也没有。
// 这标明,宽200,高100的图像,其坐标的局限是(0,0)到(199,99)。
ImagePNG($im);
ImageDestroy($im);
// 这一段先停止吧。
?>
接上去这个后果就爽了!我也是现学现卖。PHP4.0.6以上增添了这个用法――可以用瓜代的
色彩画线!示例以下:
<?
Header("Content-type: image/png");
$im = ImageCreate (200, 100);
$col_black = ImageColorAllocate($im, 0,0,0);
$col_orn = ImageColorAllocate($im, 255,192,0);
$col_red = ImageColorAllocate($im, 255,0,0);
$style=array($col_red,$col_red,$col_black,$col_orn,$col_orn,$col_orn,$col_black);
ImageSetStyle($im, $style);
ImageLine($im, 0, 50, 199, 50, IMG_COLOR_STYLED);
ImagePNG($im);
ImageDestroy($im);
?>
看看后果吧。
个中我用空行朋分开的那三行,申明一下。界说了一个数组 $style,它的成员是一系列的色彩;
然后履行了一个函数,尔后用 IMG_COLOR_STYLED “色彩”画出来的是这么奇异的“直线”――
白色、黑色、橙色瓜代的后果。细心看一下你就会发明,红、黑、橙瓜代的按次,就是咱们界说的
$style数构成员的序列:红、红、黑、橙、橙、橙、黑,然后循环往复……
看分明了吗?注重,这个函数在PHP4.0.6今后才撑持。
有了我具体解说的画线的基本,我想把画其他几何图形的函数一笔代过。需求提醒人人的是,不管
画哪一种几何图形,不过是捉住这类图形的几个要素。先不算色彩,各类图形的要素以下:
点,两个要素:横坐标、纵坐标
矩形,四个要素:左上角、右下角的横、纵坐标
弧,如许了解:弧可以包含圆弧、椭圆弧;画圆弧画他360度就能够成一个圆,画椭圆弧画他360度也就画
成一个椭圆;所以这个弧的要素有六:中间点横、纵坐标,横轴长、纵轴长、弧的始、起点。
看上面这段例子。
<?
Header("Content-type: image/png");
$im = ImageCreate (200, 100);
$col_blk = ImageColorAllocate($im, 0,0,0);
$col_orn = ImageColorAllocate($im, 255,192,0);
$col_red = ImageColorAllocate($im, 255,0,0);
$col_grn = ImageColorAllocate($im, 0,255,0);
$col_blu = ImageColorAllocate($im, 0,0,255);
ImageSetPixel($im,20,10,$col_orn);
// 小小一个点,不晓得可否看得见?
ImageRectangle($im,25,20,95,55,$col_blu);
// 蓝色的矩形。
ImageArc($im,20,85,50,40,225,360,$col_grn);
// 绿色的椭圆弧,中间在(20,85),横轴50,纵轴40,225度至360度。
// 因而可知,这里的圆弧始、起点是以角度计量,
// 是以程度向右的偏向为0度,顺时针盘算的。
ImageArc($im,160,60,40,40,0,360,$col_orn);
// 橙色的整圆。只需横轴长与纵轴长相等,就是正圆。
// 上高中咱们就学过:圆是椭圆的特例嘛!
// 最初再画一段圆弧。圆心可否在图像之外?
ImageArc($im,160,140,240,240,0,360,$col_red);
// 可以!
ImagePNG($im);
ImageDestroy($im);
?>
作图固然免不了要把某一区域涂成某种色彩。GD有三种着色体例,一种是矩形区域着色,
一种是指定的点所处的关闭区域着色,另外一种是指定的色彩所包抄的区域着色。看以下的例子:
<?
Header("Content-type: image/png");
$im = ImageCreate (200, 100);
$col_blk = ImageColorAllocate($im, 0,0,0);
$col_orn = ImageColorAllocate($im, 255,192,0);
$col_yel = ImageColorAllocate($im, 255,255,0);
$col_red = ImageColorAllocate($im, 255,0,0);
$col_grn = ImageColorAllocate($im, 0,255,0);
$col_blu = ImageColorAllocate($im, 0,0,255);
ImageFilledRectangle($im,20,10,100,50,$col_blu);
ImageFilledRectangle($im,5,40,50,90,$col_red);
ImageFilledRectangle($im,40,80,100,95,$col_orn);
ImageFilledRectangle($im,90,35,110,90,$col_yel);
// 以上是第一种着色。直接绘制矩形。
// 我居心用四个分歧色彩的矩形围起一小块区域,
// 用以申明第二种着色。
ImagePNG($im);
ImageDestroy($im);
// 看一下后果。
?>
接着:
<?
Header("Content-type: image/png");
$im = ImageCreate (200, 100);
$col_blk = ImageColorAllocate($im, 0,0,0);
$col_orn = ImageColorAllocate($im, 255,192,0);
$col_yel = ImageColorAllocate($im, 255,255,0);
$col_red = ImageColorAllocate($im, 255,0,0);
$col_grn = ImageColorAllocate($im, 0,255,0);
$col_blu = ImageColorAllocate($im, 0,0,255);
ImageFilledRectangle($im,20,10,100,50,$col_blu);
ImageFilledRectangle($im,5,40,50,90,$col_red);
ImageFilledRectangle($im,40,80,100,95,$col_orn);
ImageFilledRectangle($im,90,35,110,90,$col_yel);
// 以上是第一种着色。直接绘制矩形。
// 我居心用四个分歧色彩的矩形围起一小块区域,
// 用以申明第二种着色。
ImageFill($im,70,70,$col_grn);
// 这是第二种着色。
ImageRectangle($im,120,40,190,90,$col_grn);
// 暂且画一个矩形来做框吧。现实上任何模样的界限都可以做框。
ImageFilltoBorder($im,130,50,$col_grn,$col_orn);
// 把绿色矩形框内涂成橙色。
// 只需指定的点位于这个“框”的局限内便可,与该点在区域内的地位有关。
// 这个函数实际上是如许任务的:
// 从指定的点入手下手,向外,寻觅指定色彩的界限,假如找到,则中断,
// 找不到,就把路过的点涂成需求的色彩。
ImagePNG($im);
ImageDestroy($im);
// 看一下后果。
// 如今咱们作出的图已是花花绿绿了,可是在阅读器里,图片上,
// 右键->属性:只要 214 个字节!
?>
这一次说到这里吧先。
如果不会怎么办,我的视频教程里有个最简单的留言板 最开始离不开模仿, |