SHELLEXECUTEINFO 和 ShellExecuteEx的使用

第一篇 SHELLEXECUTEINFO ShellExecuteEx 的使用

       
使用 SHELLEXECUTEINFO ShellExecuteEx ,我也主要是在 cab 包的安装时使用的。基本上是这样使用的,如下:

 

     SHELLEXECUTEINFO ShellInfo ;

             

     memset (&ShellInfo , 0, sizeof (ShellInfo ));

     ShellInfo .cbSize = sizeof (ShellInfo );

     ShellInfo .hwnd = NULL ;

     ShellInfo .lpVerb = _T ("open" );

     ShellInfo .lpFile = szFilePath ;

     ShellInfo .nShow = SW_SHOWNORMAL ;

     ShellInfo .fMask = SEE_MASK_NOCLOSEPROCESS ;

 

     BOOL bResult = ShellExecuteEx (&ShellInfo );

一、 SHELLEXECUTEINFO 结构

MSDN 中,它这样定义:

Contains information used by ShellExecuteEx

原型如下:

typedef struct _SHELLEXECUTEINFO {
       DWORD cbSize;  
       ULONG fMask;
       HWND hwnd;
       LPCTSTR lpVerb;
       LPCTSTR lpFile;
       LPCTSTR lpParameters;
       LPCTSTR lpDirectory;
      int nShow;
       HINSTANCE hInstApp;
       LPVOID lpIDList;
       LPCTSTR lpClass;
      HKEY hkeyClass;
      DWORD dwHotKey;
       union {
          HANDLE hIcon;
          HANDLE hMonitor;
       } DUMMYUNIONNAME;
      HANDLE hProcess;
} SHELLEXECUTEINFO, *LPSHELLEXECUTEINFO;

参数详解:

cbSize

结构大小,以字节为单位。

fMask

一个标志数组,用来设置其他成员的有效性。

hwnd

可选。执行 ShellExecuteEx 的窗口句柄,可设为 NULL

lpVerb

指定执行的动作,包括: edit explore find open print properties

lpFile

/0 结尾的字符串,指出 lpVerb 的操作对象的路径,被系统支持的操作包括文本的 open print

lpParameters

可选。运行 / 打开程序的参数,如果打开的是一个文档,则该项无效

lpDirectory

可选。指明工作目录的名字,成员没有说明,则默认为当前目录

nShow

必须。指定打开的程序的显示方式,为 SW_ 值中的一个。

hInstApp

out 】如果设置 SEE_MASK_NOCLOSEPROCESS S 值并且 ShellExecuteEx 调用成功,则该项的值大于 32 ,如果调用失败,则将设置为 SE_ERR_XXX 的错误值。

lpIDList

一个 ITEMIDLIST 结构的地址,用来存储成员的特别标识符,当 fMask 不包括 SEE_MASK_IDLIST SEE_MASK_INVOKEIDLIST 时该项被忽略

lpClass

用以指明文件类别的名字或 GUID ,当 fMask 不包括 SEE_MASK_CLASSNAME 时该项被忽略

hkeyClass

获得已在系统注册的文件类型的 Handle ,当 fMask 不包括 SEE_MASK_HOTKEY 时该项被忽略

  dwHotKey

程序的热键关联,低位存储虚拟关键码( Key Code ),高位存储修改标志位 (HOTKEYF_) ,修改标志为( modifier flags )的详细列表请看 WM_SETHOTKEY 消息的描述,当 fmask 不包括 SEE_MASK_HOTKEY 时该项被忽略

DUMMYUNIONNAME

hIcon

取得对应文件类型的图标的 Handle ,当 fMask 不包括 SEE_MASK_ICON 时该项被忽略

hMonitor

将文档显示在显示器上的 Handle ,当 fMask 不包括 SEE_MASK_HMONITOR 时该项被忽略

hProcess

指向新启动的程序的句柄。若 fMask 不设为 SEE_MASK_NOCLOSEPROCESS 则该项值为 NULL 。但若程序没有启动,即使 fMask 设为 SEE_MASK_NOCLOSEPROCESS ,该值也仍为 NULL

二、 ShellExecuteEx

功能 Performs an operation on a specified file 对指定应用程序执行某个操作

原型: 
 

BOOL ShellExecuteEx(LPSHELLEXECUTEINFO lpExecInfo
);

参数

lpExecInfo

[in, out]  一个指向 SHELLEXECUTEINFO 结构的指针,用来传递和保存应用程序执行相关的信息。

返回值

如果函数成功执行就返回 TRUE ,否则返回 FALSE 。可调用 GetLastError 获取错误信息。

备注

由于 ShellExecuteEx 能够将执行委托给那些由组件对象模型 COM 激活的 Shell 扩展(数据源,上下文菜单句柄,动词实现),因此在调用 ShellExecuteEx 之前要先初始化 COM 。某些 Shell 扩展要求单线程单元模型的 COM ,在这种情况下,应当像下面一般初始化 COM

CoInitializeEx (NULL,COINIT_APARTMENTTHREADED | COINIT_DISABLE_OLE1DDE)

在某些情况下 ShellExecuteEx 并没有使用这种类型的 Shell 扩展,这时就无需初始化 COM 。虽然如此,总是在使用这个函数之前初始化 COM 是个不错的举措。

三、例子

1 、打开一个应用程序

     SHELLEXECUTEINFO ShellInfo ;

             

     memset (&ShellInfo , 0, sizeof (ShellInfo ));

     ShellInfo .cbSize = sizeof (ShellInfo );

     ShellInfo .hwnd = NULL ;

     ShellInfo .lpVerb = _T ("open" );

     ShellInfo .lpFile = szFilePath ; // 此处写执行文件的绝对路径

     ShellInfo .nShow = SW_SHOWNORMAL ;

     ShellInfo .fMask = SEE_MASK_NOCLOSEPROCESS ;

 

     BOOL bResult = ShellExecuteEx (&ShellInfo );

2 、如何打开一个文档

   程序代码如上

3 、如何打开一个网页

SHELLEXECUTEINFO ShellInfo ;

             

     memset (&ShellInfo , 0, sizeof (ShellInfo ));

     ShellInfo .cbSize = sizeof (ShellInfo );

     ShellInfo .hwnd = NULL ;

     ShellInfo .lpVerb = _T ("open" );

     ShellInfo .lpFile = _T ("http://www.sina.com" );

     ShellInfo .nShow = SW_SHOWNORMAL ;

     ShellInfo .fMask = SEE_MASK_NOCLOSEPROCESS ;

 

     BOOL bResult = ShellExecuteEx (&ShellInfo );

4 、如何启动一个程序,直到它运行结束?

SHELLEXECUTEINFO ShellInfo ;

             

     memset (&ShellInfo , 0, sizeof (ShellInfo ));

     ShellInfo .cbSize = sizeof (ShellInfo );

     ShellInfo .hwnd = NULL ;

     ShellInfo .lpVerb = _T ("open" );

     ShellInfo .lpFile = szFilePath ;

     ShellInfo .nShow = SW_SHOWNORMAL ;

     ShellInfo .fMask = SEE_MASK_NOCLOSEPROCESS ;

     ShellExecuteEx (&ShellInfo );

 

WaitForSingleObject(ShellInfo.hProcess,INFINITE);

你可能感兴趣的:(shell,properties,null,存储,文档,扩展)