Public Declare Function SetWindowLong Lib "user32" Alias _
"SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As LongPublic Declare Function GetWindowLong Lib "user32" Alias _
"GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As LongPublic 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 LongPublic Const GWL_WNDPROC = (-4)
Function WndProc(ByVal hwnd As Long, ByVal Msg As Long, ByVal wParam As Long, _
 ByVal lParam As Long) As Long
    Dim sMsg As String
    On Error Resume Next
    sMsg = LoadResString(Msg)
    Debug.Print sMsg & "(=&H" & Hex(Msg) & "("
     WndProc = CallWindowProc(prevWndProc, hwnd, Msg, wParam, lParam)
 End FunctionPrivate Sub Form_Load()
  prewndproc = GetWindowLong(Me.hwnd, GWL_WNDPROC)
  SetWindowLong Me.hwnd, GWL_WNDPRCO, AddressOf WndProc
   
End SubPrivate Sub Form_Unload(Cancel As Integer)
   SetWindowLong Me.hwnd, GWL_WNDPROC, prevWndProc
End Sub
这是我在一个文档上抄的,但不全,我也不懂callwindowproc的用法,所以到请教各位大侠我该怎么补充能在运行后立即窗口会显示所发生的一些事件,如鼠标移动,键盘按下等事件???  谢谢了!

解决方案 »

  1.   

    Public Const GWL_WNDPROC = (-4)
    SetWindowLong Me.hwnd, GWL_WNDPRCO, AddressOf WndProc
    ----------------
    SetWindowLong Me.hwnd, GWL_WNDPROC, prevWndProc
    ----------------
     WndProc = CallWindowProc(prevWndProc, hwnd, Msg, wParam, lParam)如果你在每个模块都加上Option Explicit就不会有这么多问题了.变量声明还是很好的.子类化在IDE还不能调试,想调试就去精华帖找看看