VB.net 2010 视频教程 VB.net 2010 视频教程 python基础视频教程
SQL Server 2008 视频教程 c#入门经典教程 Visual Basic从门到精通视频教程
当前位置:
首页 > 编程开发 > vb >
  • vb教程之VB编程实现两个可执行文件的绑定

Option Explicit 

Private Declare Function FindWindow Lib "user32" Alias "FindWindowA" (ByVal lpClassName As Long, ByVal lpWindowName As Long) As Long 
Private Declare Function GetParent Lib "user32" (ByVal hwnd As Long) As Long 
Private Declare Function SetParent Lib "user32" (ByVal hWndChild As Long, ByVal hWndNewParent As Long) As Long 
Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long 
Private Declare Function GetWindow Lib "user32" (ByVal hwnd As Long, ByVal wCmd As Long) As Long 
Private Declare Function LockWindowUpdate Lib "user32" (ByVal hwndLock As Long) As Long 
Private Declare Function GetDesktopWindow Lib "user32" () As Long 
Private Declare Function DestroyWindow Lib "user32" (ByVal hwnd As Long) As Long 
Private Declare Function TerminateProcess Lib "kernel32" (ByVal hProcess As Long, ByVal uExitCode As Long) As Long 
Private Declare Function GetCurrentProcess Lib "kernel32" () As Long 
Private Declare Function Putfocus Lib "user32" Alias "SetFocus" (ByVal hwnd As Long) As Long 
Const GW_HWNDNEXT = 2 
Dim mWnd As Long 
Function InstanceToWnd(ByVal target_pid As Long) As Long 
    Dim test_hwnd As Long, test_pid As Long, test_thread_id As Long 
    'Find the first window 
    test_hwnd = FindWindow(ByVal 0&, ByVal 0&) 
    Do While test_hwnd <> 0 
        'Check if the window isn't a child 
        If GetParent(test_hwnd) = 0 Then 
            'Get the window's thread 
            test_thread_id = GetWindowThreadProcessId(test_hwnd, test_pid) 
            If test_pid = target_pid Then 
                InstanceToWnd = test_hwnd 
                Exit Do 
            End If 
        End If 
        'retrieve the next window 
        test_hwnd = GetWindow(test_hwnd, GW_HWNDNEXT) 
    Loop 
End Function 
Private Sub Form_Load() 
    'KPD-Team 1999 
    'URL: http://www.allapi.net/ 
    'E-Mail: KPDTeam@Allapi.net 
    Dim Pid As Long 
    'Lock the window update 
    LockWindowUpdate GetDesktopWindow 
    'Execute notepad.Exe 
    Pid = Shell("c:\windows\notepad.exe", vbNormalFocus) 
    If Pid = 0 Then MsgBox "Error starting the app" 
    'retrieve the handle of the window 
    mWnd = InstanceToWnd(Pid) 
    'Set the notepad's parent 
    SetParent mWnd, Me.hwnd 
    'Put the focus on notepad 
    Putfocus mWnd 
    'Unlock windowupdate 
    LockWindowUpdate False 
End Sub 
Private Sub Form_Unload(Cancel As Integer) 
    'Unload notepad 
    DestroyWindow mWnd 
    'End this program 
    TerminateProcess GetCurrentProcess, 0 
End Sub

本栏文章均来自于互联网,版权归原作者和各发布网站所有,本站收集这些文章仅供学习参考之用。任何人都不能将这些文章用于商业或者其他目的。


相关教程