前言
最近在給應用程序添加一個新的高拍儀硬件工具,原本計劃是直接在應用程序中添加相關的驅動,直接進行硬件調用,試了幾天後發現這個驅動在應用程序中並不好使,並且這個應用程序邏輯很複雜,也不可能進行重寫,於是在撞了幾天牆之後想到了新思路,直接調用硬件工具現有的測試工具,這不就解決了麼~ ~爲榆木腦袋想哭
思路
直接說思路吧,比較簡單,在應用程序需要使用硬件工具的時候直接加載高拍儀測試exe,並且同步檢測交互接口,等待高拍儀拍攝圖像。當獲取到高拍儀圖像的時候應用程序繼續進行剩下的操作。 爲了美化應用效果,可以在高拍儀拍攝圖像後直接隱藏exe界面,轉爲應用程序界面。
代碼
1.應用程序調用硬件exe
HWND GetIVAWindowAndProcess(HANDLE& hProcess)
{
HWND hWnd = NULL;
hWnd = ::FindWindow(NULL,"ShootCapture");
//是否能找到,找不到就去啓動下
if(hWnd == NULL)
{
int nNumberDely = 10;
STARTUPINFO si;
PROCESS_INFORMATION pi;
ZeroMemory( &si, sizeof(si) );
si.cb = sizeof(si);
ZeroMemory( &pi, sizeof(pi) );
// Start the child process.
if( !CreateProcess( NULL, // No module name (use command line)
"xx.exe", // Command line
NULL, // Process handle not inheritable
NULL, // Thread handle not inheritable
FALSE, // Set handle inheritance to FALSE
0, // No creation flags
NULL, // Use parent's environment block
NULL, // Use parent's starting directory
&si, // Pointer to STARTUPINFO structure
&pi ) // Pointer to PROCESS_INFORMATION structure
)
{
AfxMessageBox(_T("啓動拍照功能失敗!"));
return NULL;
}
CloseHandle(pi.hThread);
WaitForInputIdle(pi.hProcess,INFINITE);
hProcess = pi.hProcess;
while((hWnd = ::FindWindow(NULL,"ShootCapture")) == NULL && nNumberDely > 0)
{
Sleep(500);
nNumberDely --;
}
}
else
{
DWORD dwProcessId = 0;
DWORD dwThreadId = 0;
dwThreadId = GetWindowThreadProcessId(hWnd,&dwProcessId);
hProcess = OpenProcess(PROCESS_ALL_ACCESS,NULL,dwProcessId);
}
::SetWindowPos(hWnd, HWND_TOPMOST, 0, 0, 0, 0, SWP_NOMOVE | SWP_NOSIZE | SWP_NOREPOSITION );
ShowWindow(hWnd,SW_SHOW);//展示在最前端展示界面
return hWnd;
}
- 測試工具拍照後隱藏界面
ShowWindow(SW_HIDE);
3.當應用程序結束後,在進程中銷燬測試工具exe
HWND hWnd = NULL;
hWnd = ::FindWindow(NULL,"ShootCapture");
//是否能找到,找不到就去啓動下
if(hWnd != NULL)
{
int kk=::SendMessage(hWnd,WM_CLOSE,0,0);
}
- 交互部分
此處比較簡單,即可以讓應用程序一直檢測某個文件夾目錄是否有新文件即可。
後話
整體思路還是挺簡單的,就是之前自己撞牆了,非要融合到一起去,搗鼓幾天,結果沒出來,倒是對高拍儀研究挺多,算是意外收穫吧,後來發現問題出在高拍儀提供的動態庫裏,這個沒源碼也改不了,後來纔想用這種方法。使用一段時間後發現,這樣兩個程序互不干擾,都很容易修改代碼,並且以後在應用程序上可以使用此種思路添加更多外接硬件。