1

我在 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 选项卡式视图的这个问题?

4

1 回答 1

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;
于 2016-09-26T14:23:43.237 回答