By using this site, you agree to our updated Privacy Policy and our Terms of Use. Manage your Cookies Settings.
435,270 Members | 1,582 Online
Bytes IT Community
Submit an Article
Got Smarts?
Share your bits of IT knowledge by writing an article on Bytes.

How To Handle More events Visual Basic 6.0 Not Support

AHMEDYO
100+
P: 112
Hi Every one...

With this visual Basic 6.0 Code you can handle more event that visual basic Support as Mouse wheel and hover or you can control event before VB IDE Default Windows proc as WM_CREATE when windows start creation, this task is useful for some application , for example you can create new UI Control at run time using Form1.Control.add("vb.CommandButton","Cmd1") Function and you can handle command button event by WM_COMMAND Message and Command ID

Module1.bas

Expand|Select|Wrap|Line Numbers
  1. Option Explicit
  2.  
  3. Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long
  4. Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
  5. Private Declare Function CallWindowProc Lib "user32" Alias "CallWindowProcA" (ByVal lpPrevWndFunc As Long, ByVal hwnd As Long, ByVal Msg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
  6. Private Declare Sub CopyPtrToObj Lib "kernel32" Alias "RtlMoveMemory" (ByRef Destination As Object, ByRef Source As Long, Optional ByVal Length As Long = 4)
  7. Private Declare Sub CopyObjToPtr Lib "kernel32" Alias "RtlMoveMemory" (ByRef Destination As Long, ByRef Source As Object, Optional ByVal Length As Long = 4)
  8.  
  9.  
  10. Private Const GWL_USERDATA = (-21)
  11. Private Const GWL_WNDPROC = (-4)
  12.  
  13.  
  14. Private Const WM_MOUSEWHEEL As Long = &H20A
  15. Private Const WM_MOUSEHOVER As Long = &H21A
  16.  
  17. Public Sub ChangeWindowProc(ByVal WindowObject As Object)
  18. Dim LastFormProc As Long
  19. Dim WindowObjectPointer As Long
  20.     'Get Proc Address assigned by VB IDE
  21.     LastFormProc = GetWindowLong(WindowObject.hwnd, GWL_WNDPROC)
  22.     Call CopyObjToPtr(WindowObjectPointer, WindowObject)        'Copy Object memory Pointer to Long variable
  23.     WindowObject.Tag = LastFormProc                             'hold lastProc in tag property u can create public variable in each window and assign this value to it and use tag for ur work
  24.     'Save Last Window Object Pointer in Window Class User Extedned Data,now u can change proc for multiple form at one time
  25.     'sure user cant active 2 forms in same time, but because of timer event and winsock
  26.     Call SetWindowLong(WindowObject.hwnd, GWL_USERDATA, WindowObjectPointer)
  27.     'change VB IDE proc by new our Proc Address
  28.     Call SetWindowLong(WindowObject.hwnd, GWL_WNDPROC, AddressOf WindowExtendedEventProc)
  29. End Sub
  30.  
  31. 'Reset Window Proc To Orignal VB IDE Proc.
  32. Public Sub ResetWindowProc(ByVal WindowObject As Object)
  33. Dim LastFormProc As Long
  34.     LastFormProc = Val(WindowObject.Tag)
  35.     Call SetWindowLong(WindowObject.hwnd, GWL_USERDATA, LastFormProc)
  36. End Sub
  37.  
  38. 'Our New Window Defined proc
  39. Public Function WindowExtendedEventProc(ByVal hwnd As Long, ByVal Msg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
  40. 'this variable is static because visual basic will unallocate all objects and variables within function after excution complete
  41. 'try to change it to Dim FormObject as object your application will crash
  42. Static FormObject As Object
  43. Dim LastFormProc As Long
  44. Dim FormObjectPointer As Long
  45.     'get Object Pointer Again in long var
  46.     FormObjectPointer = GetWindowLong(hwnd, GWL_USERDATA)
  47.     Call CopyPtrToObj(FormObject, FormObjectPointer)    'this line seems as "Set FormObject=Form1" !!!!
  48.     LastFormProc = Val(FormObject.Tag)                  'retrieve LastProc Address From tag
  49.     Select Case Msg
  50.         Case WM_MOUSEWHEEL                  'if user Roll Mouse Wheel
  51.             Call FormObject.Form_MouseWheel
  52.             WindowExtendedEventProc = 0
  53.             Exit Function
  54.         Case WM_MOUSEHOVER
  55.             Call FormObject.Form_MouseWheel
  56.             WindowExtendedEventProc = 0
  57.             Exit Function
  58.     End Select
  59.     'call orignal VB IDE Proc with other windows messages
  60.     WindowExtendedEventProc = CallWindowProc(LastFormProc, hwnd, Msg, wParam, lParam)
  61. End Function
'================================================= =======
Form1.frm

Expand|Select|Wrap|Line Numbers
  1. Option Explicit
  2.  
  3. Private Sub Form_Activate()
  4.    Call ChangeWindowProc(Me)
  5. End Sub
  6.  
  7. Private Sub Form_Deactivate()
  8.    Call ResetWindowProc(Me)
  9. End Sub
  10.  
  11. Public Sub Form_MouseWheel()
  12.     MsgBox "mouse Wheel"
  13. End Sub
  14.  
  15. Public Sub Form_MouseHover()
  16.     MsgBox "mouse Wheel"
  17. End Sub
Good Luck
Nov 16 '07 #1
Share this Article
Share on Google+