SHELLEXECUTEINFO 和 ShellExecuteEx的使用
SHELLEXECUTEINFO 和 ShellExecuteEx的使用
在日常工作中用到的一些知識,很久沒有總結(jié)過,前幾日參加一個會議,很是無聊。自己思索著自己這兩年來所做過的東西,寫著寫著居然也寫下了 100 個知識點(diǎn)。想把它一條一條總結(jié)下來,動筆總不是很容易。就拿這篇文章作為第一篇。
??????? 很多東西取之于網(wǎng)絡(luò),也有一些自己的心得。才疏學(xué)淺,就當(dāng)一個知識梳理的過程吧。
????????
? 第一篇 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 結(jié)構(gòu)
在 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;
?
參數(shù)詳解:
cbSize
結(jié)構(gòu)大小,以字節(jié)為單位。
fMask
一個標(biāo)志數(shù)組,用來設(shè)置其他成員的有效性。
hwnd
可選。執(zhí)行 ShellExecuteEx 的窗口句柄,可設(shè)為 NULL 。
lpVerb
指定執(zhí)行的動作,包括: edit , explore , find , open , print , properties
lpFile
以 /0 結(jié)尾的字符串,指出 lpVerb 的操作對象的路徑,被系統(tǒng)支持的操作包括文本的 open 、 print 等
lpParameters
可選。運(yùn)行 / 打開程序的參數(shù),如果打開的是一個文檔,則該項(xiàng)無效
lpDirectory
可選。指明工作目錄的名字,成員沒有說明,則默認(rèn)為當(dāng)前目錄
nShow
必須。指定打開的程序的顯示方式,為 SW_ 值中的一個。
hInstApp
【 out 】如果設(shè)置 SEE_MASK_NOCLOSEPROCESS S 值并且 ShellExecuteEx 調(diào)用成功,則該項(xiàng)的值大于 32 ,如果調(diào)用失敗,則將設(shè)置為 SE_ERR_XXX 的錯誤值。
lpIDList
一個 ITEMIDLIST 結(jié)構(gòu)的地址,用來存儲成員的特別標(biāo)識符,當(dāng) fMask 不包括 SEE_MASK_IDLIST 或 SEE_MASK_INVOKEIDLIST 時該項(xiàng)被忽略
lpClass
用以指明文件類別的名字或 GUID ,當(dāng) fMask 不包括 SEE_MASK_CLASSNAME 時該項(xiàng)被忽略
hkeyClass
獲得已在系統(tǒng)注冊的文件類型的 Handle ,當(dāng) fMask 不包括 SEE_MASK_HOTKEY 時該項(xiàng)被忽略
?dwHotKey
程序的熱鍵關(guān)聯(lián),低位存儲虛擬關(guān)鍵碼( Key Code ),高位存儲修改標(biāo)志位 (HOTKEYF_) ,修改標(biāo)志為( modifier flags )的詳細(xì)列表請看 WM_SETHOTKEY 消息的描述,當(dāng) fmask 不包括 SEE_MASK_HOTKEY 時該項(xiàng)被忽略
DUMMYUNIONNAME
hIcon
取得對應(yīng)文件類型的圖標(biāo)的 Handle ,當(dāng) fMask 不包括 SEE_MASK_ICON 時該項(xiàng)被忽略
hMonitor
將文檔顯示在顯示器上的 Handle ,當(dāng) fMask 不包括 SEE_MASK_HMONITOR 時該項(xiàng)被忽略
hProcess
指向新啟動的程序的句柄。若 fMask 不設(shè)為 SEE_MASK_NOCLOSEPROCESS 則該項(xiàng)值為 NULL 。但若程序沒有啟動,即使 fMask 設(shè)為 SEE_MASK_NOCLOSEPROCESS ,該值也仍為 NULL 。
二、ShellExecuteEx
功能 : Performs an operation on a specified file 。 對指定應(yīng)用程序執(zhí)行某個操作
原型:
?
?
?
?
BOOL?ShellExecuteEx(LPSHELLEXECUTEINFO?lpExecInfo
);
參數(shù) :
lpExecInfo
[in, out]? 一個指向 SHELLEXECUTEINFO 結(jié)構(gòu)的指針,用來傳遞和保存應(yīng)用程序執(zhí)行相關(guān)的信息。
返回值 :
如果函數(shù)成功執(zhí)行就返回 TRUE ,否則返回 FALSE ??烧{(diào)用 GetLastError 獲取錯誤信息。
備注:
由于 ShellExecuteEx 能夠?qū)?zhí)行委托給那些由組件對象模型 COM 激活的 Shell 擴(kuò)展(數(shù)據(jù)源,上下文菜單句柄,動詞實(shí)現(xiàn)),因此在調(diào)用 ShellExecuteEx 之前要先初始化 COM 。某些 Shell 擴(kuò)展要求單線程單元模型的 COM ,在這種情況下,應(yīng)當(dāng)像下面一般初始化 COM :
CoInitializeEx (NULL,COINIT_APARTMENTTHREADED | COINIT_DISABLE_OLE1DDE)
在某些情況下 ShellExecuteEx 并沒有使用這種類型的 Shell 擴(kuò)展,這時就無需初始化 COM 。雖然如此,總是在使用這個函數(shù)之前初始化 COM 是個不錯的舉措。
三、例子
1 、打開一個應(yīng)用程序
???? SHELLEXECUTEINFO ShellInfo ;
?????????????
???? memset (&ShellInfo , 0, sizeof (ShellInfo ));
???? ShellInfo .cbSize = sizeof (ShellInfo );
???? ShellInfo .hwnd = NULL ;
???? ShellInfo .lpVerb = _T ("open" );
???? ShellInfo .lpFile = szFilePath ; // 此處寫執(zhí)行文件的絕對路徑
???? ShellInfo .nShow = SW_SHOWNORMAL ;
???? ShellInfo .fMask = SEE_MASK_NOCLOSEPROCESS ;
?
???? BOOL bResult = ShellExecuteEx (&ShellInfo );
2 、如何打開一個文檔
?? 程序代碼如上
3 、如何打開一個網(wǎng)頁
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 、如何啟動一個程序,直到它運(yùn)行結(jié)束?
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);
四、參考文獻(xiàn)
1 、 MSDN
http://msdn.microsoft.com/en-us/library/bb759784(VS.85).aspx
http://msdn.microsoft.com/en-us/library/bb762154(VS.85).aspx
2 、 SHELLEXECUTEINFO 結(jié)構(gòu)
http://kaweh.candy.blog.163.com/blog/static/36818772200827352870/
SHELLEXECUTEINFO 結(jié)構(gòu)
在C++中其結(jié)構(gòu)為
typedef struct _SHELLEXECUTEINFO {
DWORD cbSize;
ULONG fMask;
HWND hwnd;
LPCTSTR lpVerb;