我想走哪一步?
我有一个加速器表:
我已经在我的应用程序类中添加了一个成员变量:
HACCEL m_hAccel;
我添加了以下替代:
BOOL CMeetingScheduleAssistantApp::ProcessMessageFilter(int code, LPMSG lpMsg)
{
if (m_hAccel)
{
if (::TranslateAccelerator(m_pMainWnd->m_hWnd, m_hAccel, lpMsg))
{
AfxMessageBox(_T("Found"));
return(TRUE);
}
}
return CWinAppEx::ProcessMessageFilter(code, lpMsg);
}
我仅使用弹出消息框进行调试,它确认已检测到按键。
我的菜单资源已正确设置:
所以我的菜单是菜单处理程序的操作。而且我已经设置了加载加速器表的程序。如果我按,例如Ctrl+ Shift+ X,而它是由油门表检测为什么没有我弹出的对话框中实际处理呢?
我应该指出,我的主应用程序对话框显示两个编辑器之一。因此,当显示编辑器时,我将加载该编辑器的加速器表。
我想走哪一步?为什么对话框不处理加速器?
我找到了这个答案,如何使子控件处理父级CView的加速器命令。
我发现,如果HACCEL
直接在弹出对话框中添加一个,然后使用PreTranslateMessage
:
if (m_hAccelTable)
{
if (::TranslateAccelerator(GetSafeHwnd(), m_hAccelTable, pMsg))
return TRUE;
}
有用。
对于对话框中的键盘加速器,我这样做:
在OnInitDialog中
BOOL CMyDlg::OnInitDialog()
{
...
m_hAccel = LoadAccelerators ( AfxGetResourceHandle(), MAKEINTRESOURCE(IDR_DLGACCEL));
...
}
PreTranslateMessage
BOOL CMyDlg::PreTranslateMessage(MSG* pMsg)
{
if (m_hAccel)
{
if (::TranslateAccelerator(m_hWnd, m_hAccel, pMsg))
return(TRUE);
else
return CDialog::PreTranslateMessage(pMsg);
}
else
return CDialog::PreTranslateMessage(pMsg);
}
在OnDestroy
void CMyDlg::OnDestroy()
{
...
VERIFY(DestroyAcceleratorTable(m_hAccel)) ;
CDialog::OnDestroy();
}
消息图:
BEGIN_MESSAGE_MAP(CMyDlg, CDialog)
...
ON_COMMAND(IDC_SOMECOMMANDID, OnDoSomething)
ON_UPDATE_COMMAND_UI(IDC_SOMECOMMANDID, OnUpdateDoSomething)
...
END_MESSAGE_MAP()
命令处理程序
void CMyDlg::OnUpdateDoSomething(CCmdUI* pCmdUI)
{
...
pCmdUI->Enable(...) ;
}
void CMyDlg::OnDoSomething()
{
...
}
.rc文件中的加速器表
IDR_DLGACCEL ACCELERATORS
BEGIN
"A", IDC_SOMECOMMANDID, VIRTKEY, CONTROL, NOINVERT // Ctrl+A
...
END
就这样。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句