在 vb 中我用,
1。
Private Sub Form_Load()
gHW = Me.hwnd ' 保存窗体的句柄
' 下面是关键,完成两个工作:1、将我们自己的全局函数替换为新的窗体回调函数
' 2、保存原来的 VB 默认窗户口函数地址
lpPrevWndProc = SetWindowLong(gHW, GWL_WNDPROC, AddressOf WindowProc)
End Sub2。
在模块中:
Public Const WM_COPYDATA = &H4A
Public Const WM_CLOSE = &H10Public Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As String, ByVal lpWindowName As String) As Long
Public 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
Public Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
Public Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As LongDim hwndWinamp As Long
Public Const GWL_WNDPROC = -4
Global lpPrevWndProc As Long
Global gHW As Long' 这里是关键,我自定义了一个窗口函数(回调函数),以替代 VB 窗体自己的默认窗口函数。' 窗口函数是干什么的?它就是负责处理 Windows 发送给它的消息,并加以过滤,筛选出它感兴趣' 的消息,映射成为事件供我们使用。VB 中每个窗口都有一个默认的窗口函数,我们是看不到的。' 有很多消息都被 VB 的默认窗口函数过滤掉了。了解 C/C++/Delphi 程序设计的朋友应该知道这些。
Function WindowProc(ByVal hw As Long, ByVal uMsg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
' 我们也进行消息过滤,不过我们指拦截我们感兴趣的消息
' 其他消息我们懒得处理,交给 VB 默认的窗口函数去处理吧。
Debug.Print ("dd==" & uMsg)
Select Case uMsg
    Case &H4A 'WM_COPYDATA = &H4A 消息
MsgBox ("dd")
End Select
' 这里又是关键,因为其他我们不关心的消息我们自己不处理,所以必须由 VB 的默认处理函数处理
' lpPrevWndProc 其实就是一个函数指针,它指向 VB 默认窗口函数
WindowProc = CallWindowProc(lpPrevWndProc, hw, uMsg, wParam, lParam)
End Function
=========================================================
在vc 中:
HWND  hwnd = ::FindWindow("ThunderFormDC","Form1"); 
if(hwnd == NULL)
return;
::SendMessage(hwnd, WM_COPYDATA,0,0);//如果传WM_CLOSE 可以关掉vb 程序我到底错在那里,请指教????

解决方案 »

  1.   

    应该没有问题啊。只要确认你VC发的和VB收的是同一消息就可以了。
      

  2.   

    注意以下代码:
    Select Case uMsg
        Case &H4A 'WM_COPYDATA = &H4A 消息
    MsgBox ("dd")
                      'Add:
                      WindowProc = 0
                      Exit Function
    End Select在处理完WM_COPYDATA后应立即返回,不要调用默认的处理函数
      

  3.   

    asklxf(xuefeng) 
    我加上 
    WindowProc = 0
    Exit Function
    还是不行,请问还有其他要注意的地方吗?
      

  4.   

    daviddivad(你真行,居然比我还快! Scorpio):我如果用 vb 
    hwndTest = FindWindow(vbNullString, "process")
    SendMessage hwndTest, &H4A, 0, 0vc 中
    BOOL CProcessDlg::OnCopyData(CWnd* pWnd, COPYDATASTRUCT* pCopyDataStruct) 
    {
    AfxMessageBox("ddd");
    return CDialog::OnCopyData(pWnd, pCopyDataStruct);
    }vc 可以获得消息
    从这点可以确认你VC发的和VB收的是同一消息吗?
    vb中还有那些要注意的地方???
      

  5.   

    现在问题已经解决了一部分,
    COPYDATASTRUCT问题出在
    ::SendMessage(hwnd, WM_COPYDATA,0,0);// 0,0 不能为 0但在vb 中怎样从 lParam 分析出数据????
      

  6.   

    "但在vb 中怎样从 lParam 分析出数据????"
    同问??