你是否知道VB.NET借助API方法

开发 后端
这里介绍VB.NET借助API,因为系统没有提供这样的类,这个例子,同时给大家提供了一个API的使用范例。(因为系统类库包装了绝大部分API,所以不推荐使用)

#t#本人很喜欢VB.NET借助API,在工作中也很喜欢总结关于VB.NET借助API的经验教训,在特殊窗体的应用中,我们有时需要把窗体右上角标题栏上的关闭按钮屏幕,当用户点击其它地方(比如说一个Button)退出,下面就这个问题来详细说说吧。

我们还是来看一下在VB6中的实现,VB6中实现(借助API函数)

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,因为系统没有提供这样的类,这个例子,同时给大家提供了一个API的使用范例。(因为系统类库包装了绝大部分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. '得到系统Menu  
  12. hMenu = GetSystemMenu(wnd.Handle.ToInt32, 0)  
  13. '得到系统Menu的个数  
  14. nCount = GetMenuItemCount(hMenu)  
  15. '去除系统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. '关闭窗口  
  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. '判断是系统消息,是不是关闭窗体,使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 
责任编辑:佚名 来源: CSDN
相关推荐

2009-11-02 09:43:01

VB.NET构造函数

2009-11-10 16:27:45

VB.NET指针

2009-10-23 11:33:52

VB.NET集成开发环

2009-11-02 16:05:51

VB.NET安装工程

2009-10-26 10:44:27

VB.NET API函

2010-01-18 18:20:49

VB.NET使用API

2009-10-29 14:04:48

VB.NET Deri

2009-11-03 09:26:13

VB.NET方法

2009-10-12 12:54:58

VB.NET声明API

2009-11-03 12:52:38

VB.NET Wind

2009-11-10 16:55:05

VB.NET调用API

2009-11-02 10:42:04

VB.NET EXCE

2009-10-15 17:50:48

VB.NET调用API

2009-10-27 11:32:42

VB.NET Disp

2010-01-21 10:48:18

VB.NET扩展方法

2009-11-03 10:51:33

VB.NET共享

2009-10-14 16:46:25

VB.NET OnSt

2010-01-07 15:25:11

VB.NET数组

2011-03-10 13:45:24

VB.NET

2009-10-30 15:37:23

VB.NET Sub创
点赞
收藏

51CTO技术栈公众号