では十分ではありませんが、あなたが最前面ウィンドウであれば、あなたもSetForegroundWindow
を無効にするLockSetForegroundWindow
を呼び出すことができます。
void backgroundcalc_simple()
{
LockSetForegroundWindow(LSFW_LOCK);
ShellExecute(NULL, NULL, TEXT("Calc"), NULL, NULL, SW_SHOWNA);
// Cannot unlock here without a hacky call to Sleep
}
アプリケーションがSetForegroundWindow
を必要としないならば、あなたは「ドンロックを解除する必要がありますが、とにかく行うことをお勧めします。
BOOL CALLBACK ProcessHasVisibleWindowProc(HWND hWnd, LPARAM Param)
{
if (IsWindowVisible(hWnd) && (WS_CAPTION & GetWindowLongPtr(hWnd, GWL_STYLE)))
{
DWORD thispid, *wantedpid = (DWORD*) Param;
if (GetWindowThreadProcessId(hWnd, &thispid) && thispid == *wantedpid)
{
*wantedpid = 0;
return FALSE;
}
}
return TRUE;
}
BOOL ProcessHasVisibleWindow(DWORD Pid)
{
if (!Pid) return FALSE;
EnumWindows(ProcessHasVisibleWindowProc, (LPARAM) &Pid);
return Pid == 0;
}
BOOL WaitForVisibleProcessWindow(DWORD Pid, DWORD Timeout)
{
DWORD start = GetTickCount();
for (;;)
{
if (ProcessHasVisibleWindow(Pid)) return TRUE;
if (GetTickCount() - start >= Timeout && Timeout != INFINITE) break;
Sleep(50);
}
return FALSE;
}
void backgroundcalc()
{
STARTUPINFO si;
PROCESS_INFORMATION pi;
ZeroMemory(&si, sizeof(si));
si.cb = sizeof(si);
si.dwFlags = STARTF_FORCEOFFFEEDBACK|STARTF_USESHOWWINDOW;
si.wShowWindow = SW_SHOWNA;
WCHAR cmd[MAX_PATH];
lstrcpy(cmd, TEXT("Calc"));
LockSetForegroundWindow(LSFW_LOCK);
if (CreateProcess(NULL, cmd, NULL, NULL, FALSE, 0, NULL, NULL, &si, &pi))
{
WaitForInputIdle(pi.hProcess, 3333);
WaitForVisibleProcessWindow(pi.dwProcessId, 1000*10);
CloseHandle(pi.hProcess);
CloseHandle(pi.hThread);
}
LockSetForegroundWindow(LSFW_UNLOCK);
}
どのようなプログラミング言語ですか? – Asesh