En realidad no se bien como se llaman este tipo de formularios pero creo que se entiende.
Esta orientado a los dos lenguajes por que se utiliza principalmente el Framework que es el mismo para los 2.
Los códigos adjuntos están escritos en VS.Net 2008.
Primero el resultado final
VB.Net – - – CSharp.Net
Continue reading »
En varias ocaciones cuando se necesita ejecuta un programa dentro de otro, puede que se requiera espera que el programa ejecutado termine para continuar con la ejecucion del programa que lo a llamado.
Uppss
que raro quedo eso pero bueno, los que necesiten esto me van ha entender.
ShellAndWait
Creamos un modulo con el siguiente contenido.
estas funciones de la API nos sirven para obtener el ProcessID y luego con getExitCodeProcess podemos saber si salio o esta pendiente.
[vb]
Option Explicit
Private Declare Function OpenProcess Lib “kernel32″ _
(ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, _
ByVal dwProcessId As Long) As Long
Private Declare Function GetExitCodeProcess Lib “kernel32″ _
(ByVal hProcess As Long, lpExitCode As Long) As Long
Private Const STATUS_PENDING = &H103&
Private Const PROCESS_QUERY_INFORMATION = &H400
[/vb]
Pueden poner la funcion en el mismo modulo o en otro.
aqui el codigo.
[vb]
Public Function ShellandWait(ExeFullPath As String, _
Optional TimeOutValue As Long = 0) As Boolean
Dim lInst As Long
Dim lStart As Long
Dim lTimeToQuit As Long
Dim sExeName As String
Dim lProcessId As Long
Dim lExitCode As Long
Dim bPastMidnight As Boolean
On Error GoTo ErrorHandler
lStart = CLng(Timer)
sExeName = ExeFullPath
‘Deal with timeout being reset at Midnight
If TimeOutValue > 0 Then
If lStart + TimeOutValue < 86400 Then
lTimeToQuit = lStart + TimeOutValue
Else
lTimeToQuit = (lStart - 86400) + TimeOutValue
bPastMidnight = True
End If
End If
lInst = Shell(sExeName, vbMinimizedNoFocus)
lProcessId = OpenProcess(PROCESS_QUERY_INFORMATION, False, lInst) 'Optenemos el ProcessID
Do 'Aqui se genera un ciclo hasta que el proceso sea distinto de pendiente, o sea, Alla terminado.
Call GetExitCodeProcess(lProcessId, lExitCode) ' Optenemos el si hay exits code o todavia esta en ejecucion (pending)
DoEvents
If TimeOutValue And Timer > lTimeToQuit Then
If bPastMidnight Then
If Timer < lStart Then Exit Do
Else
Exit Do ‘ Se sale del ciclo si se acavo el tiemo de espera
End If
End If
Loop While lExitCode = STATUS_PENDING
ShellandWait = True
ErrorHandler:
ShellandWait = False
Exit Function
End Function
[/vb]
Ahora para ocupar esta funcion ponemos
ShellAndWait “import.exe “, 0
en esta llamado solo espera a que termine el proceso.
ShellAndWait “import.exe “, 1000
aqui espera 1000 milisegundos o el termino del proceso para salir.
