日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
你是否知道VB.NET借助API方法

#t#本人很喜歡VB.NET借助API,在工作中也很喜歡總結(jié)關(guān)于VB.NET借助API的經(jīng)驗教訓(xùn),在特殊窗體的應(yīng)用中,我們有時需要把窗體右上角標(biāo)題欄上的關(guān)閉按鈕屏幕,當(dāng)用戶點擊其它地方(比如說一個Button)退出,下面就這個問題來詳細(xì)說說吧。

我們還是來看一下在VB6中的實現(xiàn),VB6中實現(xiàn)(借助API函數(shù))

PrivateDeclareFunction GetSystemMenu Lib "user32" (ByVal hwnd AsLong, ByVal bRevert AsLong) AsLong
PrivateDeclareFunction GetMenuItemCount Lib "user32" (ByVal hMenu AsLong) AsLong
PrivateDeclareFunction DrawMenuBar Lib "user32" (ByVal hwnd AsLong) AsLong
PrivateDeclareFunction RemoveMenu Lib "user32" (ByVal hMenu AsLong, ByVal nPosition AsLong, ByVal wFlags AsLong) AsLong
Const MF_BYPOSITION = &H400&
Const MF_REMOVE = &H1000&
PrivateSub Form_Load()
Dim hSysMenu AsLong, nCnt AsLong
'Get handle to our form's system menu
'(Restore, Maximize, Move, close etc.)
hSysMenu = GetSystemMenu(Me.hwnd, False)
 
If hSysMenu Then
'Get System menu's menu count
nCnt = GetMenuItemCount(hSysMenu)
If nCnt Then
'Menu count is based on 0 (0, 1, 2, 3...)
RemoveMenu hSysMenu, nCnt - 1, MF_BYPOSITION Or MF_REMOVE
RemoveMenu hSysMenu, nCnt - 2, MF_BYPOSITION Or MF_REMOVE 'Remove the seperator
DrawMenuBar(Me.hwnd)
'Force caption bar's refresh. Disabling X button
Me.Caption = "Try to close me!"
EndIf
EndIf
EndSub
 
'如果還要屏蔽Alt+F4,加上
PrivateSub Form_QueryUnload(ByVal Cancel AsInteger, ByVal UnloadMode AsInteger)
Cancel = 1
EndSub

VB.NET借助API,因為系統(tǒng)沒有提供這樣的類,這個例子,同時給大家提供了一個API的使用范例。(因為系統(tǒng)類庫包裝了絕大部分API,所以不推薦使用)

以下是VB.NET的代碼:

 
 
 
  1. 'API聲明  
  2. PrivateDeclareFunction GetSystemMenu Lib "User32" (ByVal hwnd AsInteger, ByVal bRevert AsLong) AsInteger  
  3. PrivateDeclareFunction RemoveMenu Lib "User32" (ByVal hMenu AsInteger, ByVal nPosition AsInteger, ByVal wFlags AsInteger) AsInteger  
  4. PrivateDeclareFunction DrawMenuBar Lib "User32" (ByVal hwnd AsInteger) AsInteger  
  5. PrivateDeclareFunction GetMenuItemCount Lib "User32" (ByVal hMenu AsInteger) AsInteger  
  6. PrivateConst MF_BYPOSITION = &H400&  
  7. PrivateConst MF_DISABLED = &H2&  
  8.    
  9. PrivateSub disableX(ByVal wnd As Form)  
  10. Dim hMenu AsInteger, nCount AsInteger  
  11. '得到系統(tǒng)Menu  
  12. hMenu = GetSystemMenu(wnd.Handle.ToInt32, 0)  
  13. '得到系統(tǒng)Menu的個數(shù)  
  14. nCount = GetMenuItemCount(hMenu)  
  15. '去除系統(tǒng)Menu  
  16. Call RemoveMenu(hMenu, nCount - 1, MF_BYPOSITION Or MF_DISABLED)  
  17. '重畫MenuBar  
  18. DrawMenuBar(Me.Handle.ToInt32)  
  19. EndSub  
  20.    
  21. PrivateSub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) HandlesMyBase.Load  
  22. '使用X不能用  
  23. disableX(Me)  
  24. EndSub  
  25.    
  26. PrivateSub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click  
  27. '關(guān)閉窗口  
  28. Me.Close()  
  29. EndSub  
  30.    
  31. '如果還要屏蔽Alt+F4,加上  
  32. ProtectedOverridesSub WndProc(ByRef m As System.Windows.Forms.Message)  
  33. Dim SC_CLOSE AsInteger = 61536 
  34. Dim WM_SYSCOMMAND AsInteger = 274 
  35. '判斷是系統(tǒng)消息,是不是關(guān)閉窗體,使Alt+F4無效  
  36. If m.Msg = WM_SYSCOMMAND AndAlso m.WParam.ToInt32 = SC_CLOSE Then  
  37. ExitSub  
  38. EndIf  
  39. MyBase.WndProc(m)  
  40. EndSub 

本文名稱:你是否知道VB.NET借助API方法
網(wǎng)頁路徑:http://www.dlmjj.cn/article/dhjegso.html