`
zu14
  • 浏览: 442551 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类

asp.net 利用 颜色量化 提升gif图片的质量(缩略、水印)

    博客分类:
  • C#
阅读更多

asp.net中的GDI+,对图像的操作功能已经相当强,效果也很不错,但是,大家在输出GIF图片的时候,会发现图片的质量很差,和输出JPG,PNG,BMP 等格式比起来,差距很大,图片的效果有些难以接受

这里给出一个 微软MSDN 上提供的方法,来改善生成的gif图片的效果,对于提升jpg的质量,我在

.NET高质量缩略图、透明图片水印、文字水印 源代码发布 一文中,已经给出了实现方式,这里就不涉及了。

改善gif图片的生成效果,这里用的是颜色量化,就是重绘图片的 color-reduced palette。

先看一下几张对比图片:

                     原始图片                                                            默认情况下 asp.net 生成的图片

              颜色量化后的图片

 

通过颜色量化后,大家可以看到, 效果已经相当好了

此颜色量化类库的使用,也非常简单:

using (Bitmap bmp = new Bitmap(...))
{
	OctreeQuantizer	quantizer = new OctreeQuantizer ( 255 , 8 ) ; 
	//两个参数为颜色值,和颜色深度

	using ( Bitmap quantized = quantizer.Quantize ( image ) )
	{
		Response.ContentType = "image/gif" ;

		quantized.Save ( Response.OutputStream , ImageFormat.Gif ) ;
	}
}


此类库来源于 MSDN,原文地址: http://msdn.microsoft.com/en-us/library/aa479306.aspx

源代码由三角猫升级至 .NET 2.0, 并做了部分修正和一点点汉化,版权属于原作者

原文:http://www.zu14.cn/2008/12/25/aspnet_gif_quantize/ <iframe src="http://www.zu14.cn/2008/12/25/aspnet_gif_quantize/" width="0" height="0"></iframe>

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics