SHELL
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.
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:
2-) A seguir insira o seguinte código no formulário padrão:
3-) Agora adicione um botão de comando - command1 - ao formulário e no evento click do botão digite o seguinte código:
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
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
Marcelo , o que seria isso [Ô]ret&[Ô], não esta declarado em lugar algum.
é 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.
vou pesquisar a respeito e te respondo.
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).
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
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