| 网站首页 | 硬件维修 | 应用学院 | 网络组建 | 网站制作 | 菜鸟黑客 | 编程之道 | 数码大全 | 娱乐休闲 | 软件下载 | 在线视频 | 请您留言 | 技术论坛 | 
专 题 栏 目
最 新 热 门
最 新 推 荐
相 关 文 章
  • PHP与javascript对多项选…

  • HTML之影像地图

  • 巧用CSS制作图象特效

  • CSS2盒模型的3D示意图

  • CSS滤镜之FlipH、FlipV属性

  • CSS滤镜之alpha属性

  • CSS滤镜:alpha属性

  • CSS滤镜:FlipH、FlipV属性

  • 巧用CSS制作图象特效

  • CSS2盒模型的3D示意图

  • Q
    您现在的位置: 我是IT人 >> 网站制作 >> php >> 文章正文
    说说PHP作图         
    说说PHP作图
    作者:网络 文章来源:转载 点击数: 更新时间:2005-8-13
    [ 字体:缩小 正常 放大 | 双击自动滚屏 ]
    请选择合适的字体颜色:
      // 产生了千变万化的色彩。上面我定义的这个颜色,红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图象……
      // 不要忘记这里有一个参数,如果在屏幕显示,而不是保存为文件,
      // 则省略这个参数——保存的文件名。如果这里是要把它保存为文件,
      // 就应该这样写:ImagePNG($im,"test.png");
      // 如果不指定路径,这个文件保存在你的web当前目录里。
      // 如果是JPEG,则再多一个参数,是JPEG质量(0~100)。
      // 如果要在屏幕显示,则 ImageJPEG($im,"",80);
      // 如果要保存,则 ImageJPEG($im,"test.jpg",80);
      // 注意,如果你要把这个图象保存为文件,
      // 就不能使用 Header("Content-type: image/png"); 传送意味着图象的HTTP头,
      // 因为一旦这样,就表示你将输出图象。
      
      ImageDestroy($im);
      // 毁掉内存里的图象,以释放内存空间。
      // 这样就好了:一幅最简单的GD作的图作成了。
      
      // 通过测试发现,生成这幅图象文件,用PNG格式只有131字节,
      // 而用JPEG格式,即便是用最差的质量(0),也需要855字节,图象质量糟糕得没法看。
      // 而最高的JPEG质量,则需要2360字节,色彩却仍不如用PNG时的鲜艳。
      // 由此可见,对于这种颜色数目少的图象,用PNG比JPEG划算得多。
    ?>
      
        这一次先说到这里,我会争取尽快继续写下去。
        上次说了一种简单的回避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)

    上一页  [1] [2] [3] [4] [5] [6] 下一页  

    文章录入:小秦    责任编辑:小秦 
  • 上一篇文章:

  • 下一篇文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    | 设为首页 | 加入收藏 | 联系站长 | 关于我们 | 友情链接 | 版权申明 |