方法一:
CWnd *pWndPrev, *pWndChild;
if(pWndPrev=CWnd::FindWindow("#32770","DMTOOL")) //见说明1
{
if(pWndPrev->IsIconic())
{
pWndPrev->ShowWindow(SW_RESTORE);
pWndPrev->SetForegroundWindow();
}
else
{
pWndChild=pWndPrev->GetLastActivePopup();
pWndChild->SetForegroundWindow();
}
return FALSE;
}
if(pWndPrev=CWnd::FindWindow("#32770","DMTOOL")) //见说明1
{
if(pWndPrev->IsIconic())
{
pWndPrev->ShowWindow(SW_RESTORE);
pWndPrev->SetForegroundWindow();
}
else
{
pWndChild=pWndPrev->GetLastActivePopup();
pWndChild->SetForegroundWindow();
}
return FALSE;
}
这里有几点说明:
1、FindWindow函数。函数第一个参数是窗口的类名,第二个参数是窗口标题。窗口类名如何获得?使用SPY++里的查找功能,找到你所要看的窗口,窗口属性里面有一项就是类名,例如这里的“#32770”。
2、GetLastActivePopup
函数功能:该函数确定指定窗口中的哪一个弹出式窗口是最近活动的窗口。
函数原型:HWND GetLastActivePopup(HWND hWnd);
参数:hWnd(所有者窗口句柄)。
返回值:返回值标识了最近活动的弹出式窗口的句柄。如果满足下列任一条件,则返回值与参数hWnd相同:
由hWnd指定的窗口是最近活动的:由hWnd指定的窗口不拥有任何弹出式窗口;由hWnd指定的窗口不是顶层窗口或它属于其他窗口。
3、SetForegroundWindow()
函数功能:该函数将创建指定窗口的线程设置到前台,并且激活该窗口。键盘输入转向该窗口,并为用户改各种可视的记号。系统给创建前台窗口的线程分配的权限稍高于其他线程。
函数原型:BOOL SetForegroundWindow(HWND hWnd)
参数: hWnd(将被激活并被调入前台的窗口句柄)。
返回值:如果窗口设入了前台,返回值为非零;如果窗口未被设入前台,返回值为零。
备注:前台窗口是z序顶部的窗口,是用户的工作窗口。在一个多任务优先抢占环境中,应让用户控制前台窗口。
方法二:
CreateMutex
HANDLE CreateMutex(
LPSECURITY_ATTRIBUTES lpMutexAttributes,
BOOL bInitialOwner,
LPCTSTR lpName
);
LPSECURITY_ATTRIBUTES lpMutexAttributes,
BOOL bInitialOwner,
LPCTSTR lpName
);
参数
lpMutexAttributes
指向一个SECURITY_ATTRIBUTES结构的指针,这个结构决定互斥体句柄是否被子进程继承。
bInitialOwner
布尔类型,决定互斥体的创建者是否为拥有者
lpName 指向互斥体名字字符串的指针。互斥体可以有名字。
互斥体的好处是可以在进程间共享
布尔类型,决定互斥体的创建者是否为拥有者
lpName 指向互斥体名字字符串的指针。互斥体可以有名字。
互斥体的好处是可以在进程间共享
它的应用
实现程序实例的一个拷贝
在每次进入主函数时,显执行以下代码。
实现程序实例的一个拷贝
在每次进入主函数时,显执行以下代码。
HANDLE m_hMutex=CreateMutex(NULL,TRUE, m_pszAppName);
if(GetLastError()==ERROR_ALREADY_EXISTS)
{
AfxMessageBox("ERROR_ALREADY_EXISTS");
CloseHandle(m_hMutex);
m_hMutex = NULL;
return FALSE;
}
if(GetLastError()==ERROR_ALREADY_EXISTS)
{
AfxMessageBox("ERROR_ALREADY_EXISTS");
CloseHandle(m_hMutex);
m_hMutex = NULL;
return FALSE;
}