SHELL

LUTEDIV 03/09/2009 13:41:18
#321836
Boa tarde pessoal , estou com um probleminha aqui, é o seguinte, Utilizo o shell para chamar um programa de terceiro e na linha abaixo da chamada faço uma verificação.Preciso que enquanto não finalizar este programa chamado , o sistema não faça nada, pare esperando eu finaliza-lo para continuar rodando.
MARCELO.TREZE 03/09/2009 14:36:34
#321842
Resposta escolhida
Quando você executa um programa externo ao seu aplicativo VB usando o comando Shell , é interessante que o seu programa VB saiba quando a aplicação executada foi encerrada ou terminou. Vamos mostrar como fazer isto.

1-) Inicie um novo projeto no VB e inclua um módulo no seu projeto. A inclua o seguinte código no módulo:

Public Type STARTUPINFO
cb As Long
lpReserved As String
lpDesktop As String
lpTitle As String
dwX As Long
dwY As Long
dwXSize As Long
dwYSize As Long
dwXCountChars As Long
dwYCountChars As Long
dwFillAttribute As Long
dwFlags As Long
wShowWindow As Integer
cbReserved2 As Integer
lpReserved2 As Long
hStdInput As Long
hStdOutput As Long
hStdError As Long
End Type

Public Type PROCESS_INFORMATION
hProcess As Long
hThread As Long
dwProcessID As Long
dwThreadID As Long
End Type

Public Declare Function WaitForSingleObject Lib _
[Ô]kernel32[Ô] (ByVal hHandle As Long, ByVal dwMilliseconds _
As Long) As Long

Declare Function CreateProcessA Lib [Ô]kernel32[Ô] _
(ByVal lpApplicationName As Long, ByVal lpCommandLine As _
String, ByVal lpProcessAttributes As Long, ByVal _
lpThreadAttributes As Long, ByVal bInheritHandles As Long, _
ByVal dwCreationFlags As Long, ByVal lpEnvironment As Long, _
ByVal lpCurrentDirectory As Long, lpStartupInfo As _
STARTUPINFO, lpProcessInformation As PROCESS_INFORMATION) _
As Long

Declare Function CloseHandle Lib [Ô]kernel32[Ô] (ByVal hObject _
As Long) As Long

Public Const NORMAL_PRIORITY_CLASS = &H20&
Public Const INFINITE = -1&


2-) A seguir insira o seguinte código no formulário padrão:

Public Sub ExecCmd(cmdline$)
Dim proc As PROCESS_INFORMATION
Dim start As STARTUPINFO

[ô]Inicia a strutura STARTUPINFO
start.cb = Len(start)

[ô]Inicia a aplicação escolhida para ser executada
ret& = CreateProcessA(0&, cmdline$, 0&, 0&, 1&, _
NORMAL_PRIORITY_CLASS, 0&, 0&, start, proc)

[ô]Aguarda a aplicação iniciada terminar
ret& = WaitForSingleObject(proc.hProcess, INFINITE)
ret& = CloseHandle(proc.hProcess)
End Sub


3-) Agora adicione um botão de comando - command1 - ao formulário e no evento click do botão digite o seguinte código:

Private Sub Command1_Click()


MsgBox [Ô]Vou iniciar o Notepad[Ô]

Call ExecCmd([Ô]c:\\windows\
otepad.exe[Ô])

MsgBox [Ô]O Notepad foi encerrado[Ô]

End Sub


O código acima irá executar o programa Bloco de notas ( NotePad.exe ) passando as informações para a sua aplicação quando for encerrado. Você executa o programa através da função ExecCmd informando o nome e local do aplicativo que quer executar...

fonte:www.macoratti.net
LUTEDIV 03/09/2009 15:05:23
#321847
Marcelo , o que seria isso [Ô]ret&[Ô], não esta declarado em lugar algum.
MARCELO.TREZE 03/09/2009 15:16:28
#321848
é uma boa pergunta como o código não é de minha autoria vou ficar te devendo uma explicação, só sei que sem estas linhas o código não funciona.

vou pesquisar a respeito e te respondo.
ASHKATCHUP 03/09/2009 16:20:51
#321856
Citação:

LUTEDIV escreveu:
Marcelo , o que seria isso [Ô]ret&[Ô], não esta declarado em lugar algum.



é uma variável long. As APIs do Windows geralmente retornam algum valor (nº do processo, etc).
MOACIRPFAU 04/09/2009 13:48:54
#321973
Use esta função:

Private Const SYNCHRONIZE = &H100000
Private Const INFINITE = -1&

Public Function ShellAndWait(ByVal program_name As String) As Boolean
Dim process_id As Long
Dim process_handle As Long

[ô] Inicia o programa
On Error GoTo ShellError
process_id = Shell(program_name, vbNormalFocus)
On Error GoTo 0

[ô] Oculta
Me.Visible = False
DoEvents

[ô] aguarda o programa terminar
[ô] pega o numero do manipulador
process_handle = OpenProcess(SYNCHRONIZE, 0, process_id)
If process_handle <> 0 Then
WaitForSingleObject process_handle, INFINITE
CloseHandle process_handle
End If

Me.Visible = True

Exit Function

ShellError:
[ô]MsgBox [Ô]Erro durante execução [ô][Ô] & program_name & [Ô][ô][Ô] & vbCrLf & Err.Description
End Function
Tópico encerrado , respostas não são mais permitidas