我在CMyApp :: Initintance()中使用LoadMDIState()来加载/恢复以前的MDI-Doc窗口位置。
if (cmdInfo.m_nShellCommand == CCommandLineInfo::FileNew)
{
if (!pMainFrame->LoadMDIState(GetRegSectionPath()))
{
m_pStartDocTemplate->OpenDocumentFile(NULL); // Load previous Document
}
}
如果Serialize()期间的内部状态设置为
,则可以正常工作CMDIClientAreaWnd::m_bTabIsEnabled = FALSE;
但如果儿子内部状态是
,它会崩溃CMDIClientAreaWnd::m_bTabIsEnabled = TRUE;
我已在MFC源代码中调查此错误,并在
中查看递归调用void CMDIClientAreaWnd::EnableMDITabs(BOOL bEnable, const CMDITabInfo& params)
{
if (m_bIsMDITabbedGroup)
{
EnableMDITabbedGroups(FALSE, params);
}
:
}
void CMDIClientAreaWnd::EnableMDITabbedGroups(BOOL bEnable, const CMDITabInfo& mdiTabParams)
{
if (m_bTabIsEnabled)
{
EnableMDITabs(FALSE, mdiTabParams);
}
:
}
这是一个错误吗?以及如何为MDI选项卡式视图解决此问题?
答案 0 :(得分:2)
由MFC源代码本身的注释解决。
CMDIChildWndEx* CMainFrame::CreateDocumentWindow(LPCTSTR lpcszDocName, CObject* pObj)
{
return CMDIFrameWndEx::CreateDocumentWindow(lpcszDocName, pObj);
ASSERT(FALSE);
TRACE0("If you use save/load state for MDI tabs, you must override this method in a derived class!\n");
return NULL;
}
我已经在CMainframe中凌驾于此,并且它有效。
CMDIChildWndEx* CMainFrame::CreateDocumentWindow(LPCTSTR lpcszDocName, CObject* pObj)
{
CDocument* pDoc = NULL;
pDoc = AfxGetApp()->OpenDocumentFile(lpcszDocName);
if (pDoc != NULL)
{
POSITION pos = pDoc->GetFirstViewPosition();
if (pos != NULL)
{
CView* pView = pDoc->GetNextView(pos);
return DYNAMIC_DOWNCAST(CMDIChildWndEx, pView->GetParent());
}
}
}
return NULL;