Linux中国 Linux中国门户站!
设为主页 设为主页
收藏本站 收藏本站
 
当前位置 :首页 ->编程语言 ->ASP.NET ->正文

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

来源:Linuxdby.com 作者:Webmaster 时间:2007-04-12 点击: [收藏] [投稿]

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





 如果您对本文有任何疑问或者建议,请到讨论区发表您的意见: >> 论坛入口 <<



上一篇: 在ASP.NET中值得注意的两个地方   下一篇: ASP.NET图象处理详解(2)

文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【我要投稿】 【论坛讨论
更多相关文章
Power by linux-cn.com 粤ICP备05006655号