asp.net 利用 顏色量化 提升gif圖片的品質(縮減、浮水印)

來源:互聯網
上載者:User

asp.net中的GDI+,對映像的操作功能已經相當強,效果也很不錯,但是,大家在輸出GIF圖片的時候,會發現圖片的品質很差,和輸出JPG,PNG,BMP 等格式比起來,差距很大,圖片的效果有些難以接受

這裡給出一個 微軟 的 MSDN 上提供的方法,來改善產生的gif圖片的效果,對於提升jpg的品質,我在

.NET高品質縮圖、透明圖片浮水印、文字浮水印 原始碼發布 一文中,已經給出了實現方式,這裡就不涉及了。

改善gif圖片的產生效果,這裡用的是顏色量化,就是重繪圖片的 color-reduced palette。

先看一下幾張對比圖片:

                     原始圖片                                                            預設情況下 asp.net 產生的圖片

              顏色量化後的圖片

 

通過顏色量化後,大家可以看到, 效果已經相當好了

此顏色量化類庫的使用,也非常簡單:

using (Bitmap bmp = new Bitmap(...)){OctreeQuantizerquantizer = 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/

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.