精选国内外互联网行业最新文章及报告,让网友获得最新的海内外互联网动态
当前位置:主页 > 网络编程 > Net编程 >

ASP.NET图象处理详解(3)

2015-01-26 16:32 来源: 编辑:admin

    三、画图特效
  
     如果只是将图片显示在网页上,这样未免显得简单。现在,我们来进一步感受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的图象处理可以实现的功能很多,我们在这里其实只是简单的介绍,更多功能的应用,需要我们在实践中摸索、总结。

标签