图片处理渐变

  在网上看到一个关于图片处理的文章,用vb写的,翻译出来学习一下。
    在使用ASP的时候,我们时常要借助第三方控件来实现一些图象功能。而现在,ASP.NET的推出,我们已经没有必要再使用第三方控件来实现,因为ASP.NET 已经具有强大的功能来实现一些图象处理。现在,我们就来看看怎样使用ASP.NET的这一强大功能。
 
   一、System.Drawing的使用

   以下的举例将演示在内存中生成一张图片,然后,将这张图片通过网页显示出来。需要了解的是,我们这里输出的不是HTML效果,而是实实在在的图片(图象),我们可以使用“另存为…”将输出图象保存起来。

   我们先来看看效果:


0510300846123.jpg
我们看到,这张图片是一个渐变背景上有“看见了吗”几个字,当然,这个效果在PhotoShop等图象处理软件里面很容易实现,但是,一些与数据库结合的应用我们不可能将所有图片都事先设计出来,这时候,利用ASP.NET来实现这些功能就显得很重要了。我们来看源代码:
None.gif using  System;
None.gif
using  System.Drawing;
None.gif
using   System.Drawing.Imaging;
None.gif
using  System.Drawing.Drawing2D;
None.gif
None.gif            
// 清空Response
None.gif
            Response.Clear();
None.gif
None.gif            
// 建立一个120*30大小,24bit的BMP图像;
None.gif
            Bitmap imgOutput  =   new  Bitmap( 120 , 30 ,PixelFormat.Format24bppRgb);
None.gif        
None.gif            
// 根据以上BMP建立一个新图像
None.gif
            Graphics g  =  Graphics.FromImage(imgOutput);
None.gif
None.gif            g.Clear(Color.Green);
None.gif            
// 消除锯齿呈现
None.gif
            g.SmoothingMode  =  SmoothingMode.AntiAlias;
None.gif            g.DrawString(
" 看见了吗? " , new  Font( " 黑体 " , 16 ,FontStyle.Bold), new  SolidBrush(Color.White), new  PointF( 2 , 4 ));
None.gif
None.gif            g.FillRectangle(
new  LinearGradientBrush( new  Point( 0 , 0 ), new  Point( 120 , 30 ),Color.FromArgb( 0 , 0 , 0 , 0 ),Color.FromArgb( 255 , 255 , 255 , 255 )), 0 , 0 , 120 , 30 );
None.gif
None.gif            imgOutput.Save(Response.OutputStream,ImageFormat.Jpeg);
None.gif            g.Dispose();
None.gif            imgOutput.Dispose();
None.gif            Response.End();
None.gif

   在以上代码中,我们看到和数据库程序不同,这里专门引入了图象处理的名字空间system.drawing等。程序首先清空了Response,确保没有输出;然后,程序建立了一个120乘30大的BMP图象,再在这个基础上建立一个新图象,建立图象以后,我们首先“画”出了字符串“看见了吗”,该字符串为16大粗黑体,颜色为白色,位置为(2,4);最后,我们实现渐变效果。

   以上举例很简单,但是如果和数据库结合,我们可以实现很多使用ASP可能不敢想的效

转载于:https://www.cnblogs.com/guola/archive/2006/05/23/406901.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值