欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#中如何使用Winform實(shí)現(xiàn)炫酷的透明動(dòng)畫(huà)界面

 更新時(shí)間:2015年07月28日 16:45:08   投稿:lijiao  
這篇文章講解了如何使用Winform實(shí)現(xiàn)炫酷的透明動(dòng)畫(huà)界面,Winform相對(duì)于Wpf使用更簡(jiǎn)單一些,系統(tǒng)要求更低,需要了解的朋友可以參考下

做過(guò).NET Winform窗體美化的人應(yīng)該都很熟悉UpdateLayeredWindow吧,UpdateLayeredWindow可以實(shí)現(xiàn)窗體的任意透明,效果很好,不會(huì)有毛邊。不過(guò)使用這個(gè)API之后,會(huì)有一個(gè)問(wèn)題就是無(wú)法使用普通控件,而且沒(méi)有Paint消息。為了解決這個(gè)問(wèn)題,有兩種方法。

一、使用雙層窗體,底層窗體使用UpdateLayeredWindow作為背景,上層窗體用普通窗體,并且可以使用TransparencyKey或者Region來(lái)實(shí)現(xiàn)去除不需要的窗體內(nèi)容,讓上層窗體能看到底層的窗體。

二、直接單層窗體,使用控件的DrawToBitmap把控件圖像繪制到UpdateLayeredWindow 的窗體上,這樣就可以看到普通控件了。不過(guò)這個(gè)也有問(wèn)題:1.控件內(nèi)容不能自動(dòng)更新 2.效率低,很多控件使用DrawToBitmap繪制出的圖像不完整,甚至繪制不出圖像。比如TextBox無(wú)法顯示光標(biāo),WebBrowser無(wú)法 顯示內(nèi)容。

三、采用DirectUI技術(shù),重寫(xiě)所有基礎(chǔ)控件。效果最好,不過(guò)工作量巨大。

使用UpdateLayeredWindow時(shí),一般是需要對(duì)Bitmap緩存起來(lái),通過(guò)設(shè)置剪輯區(qū)域,局部重繪來(lái)提高效率。另外還可以異步重繪,模擬Winform的失效到重繪。

有些人會(huì)說(shuō)為什么不直接用WPF啊,Wpf和Winform各有優(yōu)缺點(diǎn),適應(yīng)不同的場(chǎng)合。Winform相對(duì)于使用更簡(jiǎn)單一些,系統(tǒng)要求更低。當(dāng)然需要看人的習(xí)慣了和擅長(zhǎng)的。

UpdateLayeredWindow 基本使用方法:

protected  override CreateParams CreateParams 
      { 
       get 
         { 
         CreateParams cp =  base .CreateParams; 
         cp.ExStyle |=  0x00080000 ; // WS_EX_LAYERED 擴(kuò)展樣式 
         return cp; 
       } 
     } 

重寫(xiě)窗體的 CreateParams 屬性

API調(diào)用:

public  void SetBitmap(Bitmap bitmap, byte opacity) 
  { 
   if (bitmap.PixelFormat != PixelFormat.Format32bppArgb) 
     throw  new ApplicationException( "位圖必須是32位包含alpha 通道" ); 
 
  IntPtr screenDc = Win32.GetDC(IntPtr.Zero); 
  IntPtr memDc = Win32.CreateCompatibleDC(screenDc); 
  IntPtr hBitmap = IntPtr.Zero; 
  IntPtr oldBitmap = IntPtr.Zero; 
 
   try 
     { 
    hBitmap = bitmap.GetHbitmap(Color.FromArgb( 0 ));  // 創(chuàng)建GDI位圖句柄,效率較低 
    oldBitmap = Win32.SelectObject(memDc, hBitmap); 
 
    Win32.Size size =  new Win32.Size(bitmap.Width, bitmap.Height); 
    Win32.Point pointSource =  new Win32.Point( 0 , 0 ); 
    Win32.Point topPos =  new Win32.Point(Left, Top); 
    Win32.BLENDFUNCTION blend =  new Win32.BLENDFUNCTION(); 
    blend.BlendOp       = Win32.AC_SRC_OVER; 
    blend.BlendFlags      =  0 ; 
    blend.SourceConstantAlpha = opacity; 
    blend.AlphaFormat     = Win32.AC_SRC_ALPHA; 
 
    Win32.UpdateLayeredWindow(Handle, screenDc, ref topPos, ref size, memDc, ref pointSource, 0 , ref blend, Win32.ULW_ALPHA); 
  } 
   finally 
     { 
    Win32.ReleaseDC(IntPtr.Zero, screenDc); 
     if (hBitmap != IntPtr.Zero) 
       { 
      Win32.SelectObject(memDc, oldBitmap); 
       
      Win32.DeleteObject(hBitmap); 
    } 
    Win32.DeleteDC(memDc); 
  } 
} 

API聲明:

class Win32 
  { 
   public  enum Bool 
    { 
    False =  0 , 
    True 
  } ; 
 
 
  [StructLayout(LayoutKind.Sequential)] 
   public  struct Point 
     { 
     public Int32 x; 
     public Int32 y; 
 
     public Point(Int32 x, Int32 y) 
     { this .x = x; this .y = y; } 
  } 
 
 
  [StructLayout(LayoutKind.Sequential)] 
   public  struct Size 
     { 
     public Int32 cx; 
     public Int32 cy; 
 
     public Size(Int32 cx, Int32 cy) 
      { this .cx = cx; this .cy = cy; } 
  } 
 
 
  [StructLayout(LayoutKind.Sequential, Pack =  1 )] 
   struct ARGB 
    { 
     public  byte Blue; 
     public  byte Green; 
     public  byte Red; 
     public  byte Alpha; 
  } 
 
 
  [StructLayout(LayoutKind.Sequential, Pack =  1 )] 
   public  struct BLENDFUNCTION 
     { 
     public  byte BlendOp; 
     public  byte BlendFlags; 
     public  byte SourceConstantAlpha; 
     public  byte AlphaFormat; 
  } 
 
 
   public  const Int32 ULW_COLORKEY =  0x00000001 ; 
   public  const Int32 ULW_ALPHA =  0x00000002 ; 
   public  const Int32 ULW_OPAQUE =  0x00000004 ; 
 
   public  const  byte AC_SRC_OVER =  0x00 ; 
   public  const  byte AC_SRC_ALPHA =  0x01 ; 
 
 
  [DllImport( " user32.dll " , ExactSpelling =  true , SetLastError =  true )] 
   public  static  extern Bool UpdateLayeredWindow(IntPtr hwnd, IntPtr hdcDst, ref Point pptDst, ref Size psize, IntPtr hdcSrc, ref Point pprSrc, Int32 crKey, ref BLENDFUNCTION pblend, Int32 dwFlags); 
 
  [DllImport( " user32.dll " , ExactSpelling =  true , SetLastError =  true )] 
   public  static  extern IntPtr GetDC(IntPtr hWnd); 
 
  [DllImport( " user32.dll " , ExactSpelling =  true )] 
   public  static  extern  int ReleaseDC(IntPtr hWnd, IntPtr hDC); 
 
  [DllImport( " gdi32.dll " , ExactSpelling =  true , SetLastError =  true )] 
   public  static  extern IntPtr CreateCompatibleDC(IntPtr hDC); 
 
  [DllImport( " gdi32.dll " , ExactSpelling =  true , SetLastError =  true )] 
   public  static  extern Bool DeleteDC(IntPtr hdc); 
 
  [DllImport( " gdi32.dll " , ExactSpelling =  true )] 
   public  static  extern IntPtr SelectObject(IntPtr hDC, IntPtr hObject); 
 
  [DllImport( " gdi32.dll " , ExactSpelling =  true , SetLastError =  true )] 
   public  static  extern Bool DeleteObject(IntPtr hObject); 
 
  [DllImport( " user32.dll " , EntryPoint =  " SendMessage " )] 
   public  static  extern  int SendMessage( int hWnd, int wMsg, int wParam, int lParam); 
  [DllImport( " user32.dll " , EntryPoint =  " ReleaseCapture " )] 
 
   public  static  extern  int ReleaseCapture(); 
   public  const  int WM_SysCommand =  0x0112 ; 
   public  const  int SC_MOVE =  0xF012 ; 
 
   public  const  int SC_MAXIMIZE =  61488 ; 
   public  const  int SC_MINIMIZE =  61472 ; 
} 

需要呈現(xiàn)圖像的時(shí)候調(diào)用 SetBitmap 方法。只要優(yōu)化好,呈現(xiàn)效率比普通的Paint重繪方式高很多,并且不卡不閃爍,支持任意透明。

下面是自己開(kāi)發(fā)出來(lái)的效果:

這個(gè)是用OpenGL繪制的

效果是不是很酷呀,通過(guò)以上內(nèi)容的介紹,希望對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • c# 快速排序算法

    c# 快速排序算法

    快速排序使用分治法(Divide and conquer)策略來(lái)把一個(gè)串行(list)分為兩個(gè)子串行(sub-lists)
    2013-10-10
  • c#線(xiàn)程Thread示例

    c#線(xiàn)程Thread示例

    這篇文章主要介紹了c#線(xiàn)程Thread示例,需要的朋友可以參考下
    2014-05-05
  • WPF如何自定義TabControl控件樣式示例詳解

    WPF如何自定義TabControl控件樣式示例詳解

    這篇文章主要給大家介紹了關(guān)于WPF如何自定義TabControl控件樣式的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-04-04
  • 編輯IL文件 修改DLL文件的方法

    編輯IL文件 修改DLL文件的方法

    下面小編就為大家?guī)?lái)一篇編輯IL文件 修改DLL文件的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-02-02
  • C#實(shí)現(xiàn)猜數(shù)字小游戲

    C#實(shí)現(xiàn)猜數(shù)字小游戲

    這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)猜數(shù)字小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • c#中利用委托反射將DataTable轉(zhuǎn)換為實(shí)體集的代碼

    c#中利用委托反射將DataTable轉(zhuǎn)換為實(shí)體集的代碼

    c#中利用委托反射將DataTable轉(zhuǎn)換為實(shí)體集的代碼,需要的朋友可以參考下
    2012-10-10
  • C#實(shí)現(xiàn)跑馬燈效果的示例代碼

    C#實(shí)現(xiàn)跑馬燈效果的示例代碼

    跑馬燈效果,功能效果大家應(yīng)該都知道,就是當(dāng)我們的文字過(guò)長(zhǎng),整個(gè)頁(yè)面放不下的時(shí)候(一般用于公告等),可以讓它自動(dòng)實(shí)現(xiàn)來(lái)回滾動(dòng)。本文將利用C#實(shí)現(xiàn)這一效果,感興趣的可以了解一下
    2022-11-11
  • C#正則表達(dá)式匹配HTML中的圖片路徑,圖片地址代碼

    C#正則表達(dá)式匹配HTML中的圖片路徑,圖片地址代碼

    最近的項(xiàng)目中有個(gè)關(guān)于網(wǎng)頁(yè)取圖的功能需要我自己開(kāi)發(fā),那就是用正則表達(dá)式來(lái)匹配圖片標(biāo)簽,這里簡(jiǎn)單介紹下實(shí)現(xiàn)方法,需要的朋友可以參考下
    2013-12-12
  • WPF開(kāi)發(fā)之實(shí)現(xiàn)一種三軸機(jī)械手控件

    WPF開(kāi)發(fā)之實(shí)現(xiàn)一種三軸機(jī)械手控件

    這篇文章主要為大家詳細(xì)介紹了如何利用WPF實(shí)現(xiàn)簡(jiǎn)單一種三軸機(jī)械手控件,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)或工作有一定幫助,感興趣的小伙伴可以了解一下
    2023-01-01
  • WinForm實(shí)現(xiàn)窗體最大化并遮蓋任務(wù)欄的方法

    WinForm實(shí)現(xiàn)窗體最大化并遮蓋任務(wù)欄的方法

    這篇文章主要介紹了WinForm實(shí)現(xiàn)窗體最大化并遮蓋任務(wù)欄的方法,涉及C#實(shí)現(xiàn)WinForm窗體全屏顯示的實(shí)現(xiàn)及調(diào)用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08

最新評(píng)論