|
三、画图特效 如果只是将图片显示在网页上,这样未免显得简单。现在,我们来进一步感受ASP.NET的强大功能。我们将学习图象处理中常用的图象反转、图象切割、图象拉伸等技巧。 先来看看程序效果:
仔细看,我们可以找到各种图象处理效果。现在,我们来看看程序代码: <%@ Page Language="vb" Debug="True" %> <%@ import namespace="system.drawing" %> <%@ import namespace="system.drawing.imaging" %> <%@ import namespace="system.drawing.drawing2d" %> <% dim strFilename as string dim i as System.Drawing.Image strFilename = server.mappath("./chris-fsck.jpg") i = System.Drawing.Image.FromFile(strFilename) dim b as New system.drawing.bitmap(i.width, i.height, pixelformat.format24bpprgb) dim g as graphics = graphics.fromimage(b) g.clear(color.blue) '旋转图片 i.RotateFlip(System.Drawing.RotateFlipType.Rotate90FlipX) g.drawimage(i,New point(0,0)) i.RotateFlip(System.Drawing.RotateFlipType.Rotate270FlipY) g.RotateTransform(10) g.drawimage(i,New point(0,0)) g.RotateTransform(10) g.drawimage(i,New point(20,20)) g.RotateTransform(10) g.drawimage(i,New point(40,40)) g.RotateTransform(10) g.drawimage(i,New point(40,40)) g.RotateTransform(-40) g.RotateTransform(90) g.drawimage(i,New rectangle(100,-400,100,50),New rectangle(20,20,i.width-20,i.height-20),GraphicsUnit.Pixel) g.RotateTransform(-90) ' 拉伸图片 g.drawimage(i,New rectangle(10,10,50,50),New rectangle(20,20,i.width-20,i.height-20),GraphicsUnit.Pixel) g.drawimage(i,New rectangle(50,10,90,50),New rectangle(20,20,i.width-20,i.height-20),GraphicsUnit.Pixel) g.drawimage(i,New rectangle(110,10,150,50),New rectangle(20,20,i.width-20,i.height-20),GraphicsUnit.Pixel) '切割图片 g.drawimage(i,50,100,New rectangle(180,80,60,110),GraphicsUnit.Pixel) g.drawimage(i,140,100,New rectangle(180,80,60,110),GraphicsUnit.Pixel) '旋转图片 i.RotateFlip(System.Drawing.RotateFlipType.Rotate180FlipX) g.drawimage(i,230,100,New rectangle(180,110,60,110),GraphicsUnit.Pixel) response.contenttype="image/jpeg" b.save(response.outputstream, imageformat.jpeg) b.dispose() %> 在以上的程序中,我们看到实现图象处理的各种技巧,仔细观察,我们可以知道旋转图片其实是用了一个RotateFlip方法;而切割和拉伸图片,完全是通过设置DrawImage的不同参数来实现。 四、总结 ASP.NET的图象处理可以实现的功能很多,我们在这里其实只是简单的介绍,更多功能的应用,需要我们在实践中摸索、总结。
|