Réponse acceptée !
Parler ?
Oui !
Mais tu auras bien deux applis (et pas une seule), bien que la deuxième s'exécutrera dans la première ...
Voilà commentr (exemple, donc) :
ACHTUNG !
Prends connaissance des commentaires mis en rouge dans ce qui suit (Muy importante !!!)
'ATTENTION :'
'' La ligne de code suivante :'
'TerminateProcess GetCurrentProcess, 0 ' on met ici fin à l'application appelante)>>
'met fin à l'application appelante.'
'Il convient donc bien évidemment de compiler la présente application puis de lancer 'son exécutable.
'Il est sinon bien clair que serait fermé VB.Exe (car c'est bien VB.exe qui est
'l'application en cours, au "design Time '
Il convient bien évidemment, par ailleurs, de remplacer la ligne :
' Shell("d:\monoutil\modeles\utut\util.exe", vbNormalFocus))
'en y mettant le chamin complet de l'application de ton choix,
'pour faire ton test !
Private Declare Function GetCurrentDirectory Lib "kernel32" Alias "GetCurrentDirectoryA" (ByVal nBufferLength As Long, ByVal lpBuffer As String) As Long
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
Private Sub Form_Activate()
Dim sSave As String
sSave = String(255, 0) ' création d'un buffer
GetCurrentDirectory 255, sSave ' extraction du répertoire en cours
MsgBox "le répertoire en cours est : " & sSave
Dim Pid As Long
LockWindowUpdate GetDesktopWindow ' verrouillage de la fenêtre principale
'Execution de l'exécutable Windows de votre choix
'Pid = Shell("c:\winnt\notepad.exe", vbNormalFocus)
Pid = Shell("d:\monoutil\modeles\utut\util.exe", vbNormalFocus)
If Pid = 0 Then MsgBox "Erreur / démarrage de l'application"
mWnd = InstanceToWnd(Pid) ' extraction du handle de la fenêtre
SetParent mWnd, Me.hwnd ' définition du parent de l'application à ouvrir
Putfocus mWnd ' on donne maintenant le focus à l'application ouverte
LockWindowUpdate False ' déverrouillage de la fenêtre principale
End Sub
Function InstanceToWnd(ByVal target_pid As Long) As Long
Dim test_hwnd As Long, test_pid As Long, test_thread_id As Long
test_hwnd = FindWindow(ByVal 0&, ByVal 0&) ' recherche de la premère fenêtre
Do While test_hwnd <> 0
If GetParent(test_hwnd) = 0 Then ' on vérifie que la fenêtre n'est pas une fenêtre fille
'on recherche le fil (thread) de la fenêtre
test_thread_id = GetWindowThreadProcessId(test_hwnd, test_pid)
If test_pid = target_pid Then
InstanceToWnd = test_hwnd
Exit Do
End If
End If
test_hwnd = GetWindow(test_hwnd, GW_HWNDNEXT) ' on extrait le handle de la fenêtre suivante
Loop
End Function
Private Sub Form_Unload(Cancel As Integer)
DestroyWindow mWnd ' déchargement de la fenêtre de l'application ouverte
TerminateProcess GetCurrentProcess, 0 ' on met ici fin à l'application appelante
End Sub
Voilà donc !
Lis tout bien et applique en connaissance de cause .
Une précision : tu restes responsable et seul responsable de tout geste inconsidéré, dans cette affaire. (alors lis bien)...