使用Shell运行一个外部程序后,如何让VB程序中断Shell命令后面的代码,等调用的那个外部程序运行完后再继续运行,就像运行外部程序如打开一个模式窗体一样。关键在于如何得知调用的外部程序已运行完毕!使用API???
解决方案 »
- 怎样提取cad面域中的边界坐标
- 进者送分
- 定义程序运行,只允许指定程序运行,将系统正在运行的程序显示出来,并可强行关闭未注册的进程
- 如何控制摄像头采集图象的大小以进行网络传输?
- vb 实时错误 -2147217842(80040e4e):怎么解决?(
- ado连接无法在oracle下查询中文的问题
- 推荐对你帮助最大的有关数据库编程方面的两本书。
- 求教VB+ACCESS程序,换机后出错的问题
- #####大家来一起来指出VB的缺点~######
- VB6能不能直接读取IO端口,一定要调用dll吗?
- 如何放大鼠标所经过的区域?-----------高分
- 系统启动时自动调用自己的程序!如何做到?各位指点!
'先点击command3运行Notepad.exe
'然后再点点Command1
'如果在10秒之内关闭Notepad,则弹出提示框0
'如果10秒内未关闭Notepad.则弹出提示框258'in a Form
Option ExplicitDim ProcessID As LongPrivate Sub Command1_Click()
Dim WaitHandle As Long
Dim Ret As Long
WaitHandle = OpenProcess(SYNCHRONIZE, True, ProcessID)
Ret = WaitForSingleObject(WaitHandle, 3000)
CloseHandle WaitHandle
MsgBox Ret
End SubPrivate Sub Command3_Click()
ProcessID = Shell("notepad.exe")
End Sub'in a moduleOption ExplicitPublic Declare Function OpenProcess Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As Long
Public Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
Public Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As LongPublic Const SYNCHRONIZE = &H100000'///////////////////////////////////////////
'函数名称:ShellWait( Process , [Timeout] )
'函数功能:等待程序运行结束
'参数说明:
' [ProcessID]:程序进程ID(Shell函数返回值)
' [Timeout]:超时时间(单位:毫秒),缺省为20秒
'返回值(Long型):
' [258]超时(进程未结束)
' [0]进程已结束
' [-1]不存在的进程
'///////////////////////////////////////////
Public Function ShellWait(ProcessID As Long, Optional Timeout As Long = 20000) As Long
Dim WaitHandle As Long
WaitHandle = OpenProcess(SYNCHRONIZE, True, ProcessID)
ShellWait = WaitForSingleObject(WaitHandle, Timeout)
CloseHandle WaitHandle
End Function