首頁 > 後端開發 > C#.Net教程 > C#中把Image無損轉換為Icon的實例詳解

C#中把Image無損轉換為Icon的實例詳解

Y2J
發布: 2017-04-22 10:17:39
原創
2407 人瀏覽過

這篇文章主要為大家詳細介紹了C#無損轉換Image為Icon的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

如題,市面上常見的方法是:

var handle = bmp.GetHicon();  //得到图标句柄
return Icon.FromHandle(handle); //通过句柄得到图标
登入後複製

此法的問題是,如果影像是透明背景,那麼得到的Icon的邊緣就是毛糙的,像是先墊了一層背景色然後再去色的效果,很不如人意,用過的朋友都知道。尚未研究是bmp.GetHicon出的問題,還是Icon.FromHandle有問題,日後有閒心再搗鼓下。

下面給出完美轉換方法:

/// <summary>
/// 转换Image为Icon
/// </summary>
/// <param name="image">要转换为图标的Image对象</param>
/// <param name="nullTonull">当image为null时是否返回null。false则抛空引用异常</param>
/// <exception cref="ArgumentNullException" />
public static Icon ConvertToIcon(Image image, bool nullTonull = false)
{
  if (image == null)
  {
    if (nullTonull) { return null; }
    throw new ArgumentNullException("image");
  }

  using (MemoryStream msImg = new MemoryStream()
           , msIco = new MemoryStream())
  {
    image.Save(msImg, ImageFormat.Png);

    using (var bin = new BinaryWriter(msIco))
    {
      //写图标头部
      bin.Write((short)0);      //0-1保留
      bin.Write((short)1);      //2-3文件类型。1=图标, 2=光标
      bin.Write((short)1);      //4-5图像数量(图标可以包含多个图像)

      bin.Write((byte)image.Width); //6图标宽度
      bin.Write((byte)image.Height); //7图标高度
      bin.Write((byte)0);      //8颜色数(若像素位深>=8,填0。这是显然的,达到8bpp的颜色数最少是256,byte不够表示)
      bin.Write((byte)0);      //9保留。必须为0
      bin.Write((short)0);      //10-11调色板
      bin.Write((short)32);     //12-13位深
      bin.Write((int)msImg.Length); //14-17位图数据大小
      bin.Write(22);         //18-21位图数据起始字节

      //写图像数据
      bin.Write(msImg.ToArray());

      bin.Flush();
      bin.Seek(0, SeekOrigin.Begin);
      return new Icon(msIco);
    }
  }
}
登入後複製

如碼所示,方法的原理是:

1、先將image編碼為png
2、再將png原樣包裝成一個icon

第1步雖然是重編碼,但png是無損格式,影像品質不會有絲毫損失。然後在二進位層面原封不動的把轉換得到的png塞入圖示。所以整個方法負擔得起【無損】的說法,介意失真的朋友請放心使用。注意:方法中並未對原圖size做檢查、處理,所以請先確保原圖的尺寸符合圖示規格再傳入;另外,不負責銷毀原圖,請呼叫者在外部負責。

以上是C#中把Image無損轉換為Icon的實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板