精华区 [关闭][返回]

当前位置:网易精华区>>讨论区精华>>编程开发>>● VB和Basic>>● VB和Basic(1)>>高级技巧>>用VB轻松调用其他程序

主题:用VB轻松调用其他程序
发信人: yingzi007()
整理人: fishy(2000-10-06 10:44:28), 站内信件
VB爱好者乐园,专业的VB网站,十多位网友共同维护,1000多个VB资料,分类详
细,每天更新
http://www.d1vb.com

用VB轻松调用其他程序
  我们编写程序时,有时会遇到在一个程序中调用并控制另一个程序执行的情
况,在一些编程语言中实现起来较为繁琐,但如果用VB编写时,则可轻松实现。
下面我就以在程序中调用“计算器”为例,总结了以下几种方法: 

  一、以异步方式来执行其他程序 

  Shell 函数是以异步方式来调用其他程序的。也就是说,用Shell启动的程序
可能还没有完成执行过程,就已经执行到 Shell 函数之后的语句。 

  语法:Shell(pathname[,windowstyle]) 

  说明:pathname:必要参数。Variant (String),要执行的程序名,以及任
何必需的参数或命令行变量,可能还包括目录或文件夹,以及驱动器。 

  例如:RetVal = Shell(″C:\WINDOWS\CALC.EXE″, 1) ′ 调用计算器。 


  二、以同步方式来执行其他程序 

  有时候,我们需要让VB在执行完外部程序后再执行下一语句,这就需要使用
API函数。 

  我们可通过OpenProcess和CloseHandle函数来检测调用软件的运行情况。这
两个函数的声明如下: 

  Declare Function OpenProcess Lib ″kernel32″ Alias ″OpenProcess″
 (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal d
wProcessId As Long) As Long 

  Declare Function CloseHandle Lib ″kernel32″ Alias ″CloseHandle″
 (ByVal hObject As Long) As Long 

  建立下面函数,用以判断程序是否在运行,如果是,则在运行时返回True。
 

  Function IsRunning(ByVal ProgramID) As Boolean  ′传入进程标识ID
 

    Dim hProgram As Long   ′被检测的程序进程句柄 

    hProgram=OpenProcess(0,False,ProgramID) 

    If Not hProgram=0 Then 

     IsRunning=True 

    Else 

     IsRunning=False 

    End If 

    CloseHandle hProgram 

  End Function 

  例如要调用计算器(CALC.EXE)并等到它运行完成后再执行下一语句,可以使
用以下代码: 

   Dim RetVal 

   MsgBox ″开始运行″ 

   RetVal = Shell(″C:\WINDOWS\CALC.EXE″, 1) 

   While IsRunning(RetVal) 

     DoEvents 

   Wend 

   MsgBox ″结束运行″ 

  三、关闭正在运行中的其他软件 

  如果要在程序中关闭正在运行中的其他程序,可以先使用FindWindow函数找
出相应的程序句柄,然后调用PostMessage函数关闭该程序即可。 

  这两个函数的声明如下: 

  Declare Function FindWindow Lib ″user32″ Alias ″FindWindowA″ (
ByVal lpClassName As String, ByVal lpWindowName As String) As Long 

  Declare Function PostMessage Lib ″user32″ Alias ″PostMessageA″
 (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByVal 
lParam As Long) As Long 

  例如要检测“计算器”程序是否正在运行,如果是则关闭它,可以使用如下
代码来实现: 

   Dim winHwnd As Long 

   Dim RetVal As Long 

   winHwnd=FindWindow(vbNullString,″计算器″) 

   If winHwnd〈〉0 Then 

     RetVal=PostMessage(winHwnd,&H10,0&,0&) 

     If RetVal=0 Then 

        MsgBox ″关闭计算器出错!″ 

     End If 

   Else 

     MsgBox ″计算器程序没有运行。″ 

   End If 

--
※ 来源:.月光软件站 http://www.moon-soft.com.[FROM: 202.110.173.200]

[关闭][返回]