CDemoView* CDemoApp::GetCurrentView() // // This global function is used to get a pointer to the active view // object. { CMainFrame* pFrame = (CMainFrame*) m_pMainWnd; CMDIChildWnd* pChildWnd = pFrame->MDIGetActive(); if (pChildWnd == NULL){ return NULL; } CDemoView* pView = (CDemoView*)(pChildWnd->GetActiveView()); return pView; }
时间: 2024-04-19 11:25:26 浏览: 27
这段代码是一个全局函数 `CDemoView* CDemoApp::GetCurrentView()`,用于获取当前活动视图(view)对象的指针。
1. 首先,将应用程序的主窗口指针 `m_pMainWnd` 转换为 `CMainFrame*` 类型的指针 `pFrame`。
2. 然后,通过调用 `pFrame->MDIGetActive()` 获取当前活动的 MDI 子窗口指针 `pChildWnd`。
3. 如果 `pChildWnd` 为空,表示当前没有活动的子窗口,直接返回 `NULL`。
4. 否则,通过调用 `pChildWnd->GetActiveView()` 获取当前活动子窗口的活动视图指针,并将其转换为 `CDemoView*` 类型的指针 `pView`。
5. 最后,返回 `pView`,即当前活动视图的指针。
这个函数可以在应用程序中获取当前活动视图对象的指针,以便进行相关操作或访问视图的成员函数和成员变量。
相关问题
BOOL CDemoApp::InitInstance() { // Standard initialization // If you are not using these features and wish to reduce the size // of your final executable, you should remove from the following // the specific initialization routines you do not need. m_pszProfileName = strdup("PCTLDEMO.INI"); m_pszHelpFilePath = strdup("..\\docs\\vcet.hlp"); SetDialogBkColor(); // set dialog background color to gray LoadStdProfileSettings(); // Load standard INI file options (including MRU) // Register the application's document templates. Document templates // serve as the connection between documents, frame windows and views. AddDocTemplate(new CMultiDocTemplate(IDR_DEMOTYPE, RUNTIME_CLASS(CDemoDoc), RUNTIME_CLASS(CMyMDIChildWnd), // standard MDI child frame RUNTIME_CLASS(CDemoView))); // create main MDI Frame window CMainFrame* pMainFrame = new CMainFrame; if (!pMainFrame->LoadFrame(IDR_MAINFRAME)) return FALSE; // Initialise the controls PAN_LoadControls(NULL, NULL); pMainFrame->ShowWindow(m_nCmdShow); pMainFrame->UpdateWindow(); m_pMainWnd = pMainFrame; // create a new (empty) document OnFileNew(); // instanciate notification procedure *((FARPROC * ) &lpfnNotifyProc) = MakeProcInstance((FARPROC) NotifyWndProc, AfxGetInstanceHandle()); if (lpfnNotifyProc == NULL) { ::MessageBox((HWND) 0, "Cannot make procedure instance!", "INFO", MB_ICONINFORMATION); return FALSE; } if (m_lpCmdLine[0] != '\0') { // TODO: add command line processing here } return TRUE; }
这段代码是一个 MFC 应用程序的初始化函数 `BOOL CDemoApp::InitInstance()`,它包含了一些标准的初始化步骤和自定义的初始化操作。让我逐一解释一下:
1. `m_pszProfileName` 和 `m_pszHelpFilePath` 的赋值:
- `m_pszProfileName` 是应用程序的配置文件名,这里将其设置为 "PCTLDEMO.INI"。
- `m_pszHelpFilePath` 是应用程序的帮助文件路径,这里将其设置为 "..\\docs\\vcet.hlp"。
2. `SetDialogBkColor()`:设置对话框的背景颜色为灰色。
3. `LoadStdProfileSettings()`:加载标准的 INI 文件选项,包括最近使用的文件列表(MRU)等。
4. 注册应用程序的文档模板:
- `IDR_DEMOTYPE` 是资源 ID,表示该文档模板对应的资源。
- `CDemoDoc` 是文档类。
- `CMyMDIChildWnd` 是标准的 MDI 子窗口类。
- `CDemoView` 是视图类。
5. 创建主 MDI 框架窗口 `CMainFrame`,并加载框架窗口的资源。如果加载失败,则返回 FALSE。
6. `PAN_LoadControls(NULL, NULL)`:初始化控件。
7. 显示和更新主框架窗口。
8. `m_pMainWnd` 指向主框架窗口。
9. `OnFileNew()`:创建一个新的空文档。
10. `MakeProcInstance((FARPROC) NotifyWndProc, AfxGetInstanceHandle())`:创建一个用于处理通知的过程实例。
11. 检查 `lpfnNotifyProc` 是否为空,如果为空,则显示一个消息框,并返回 FALSE。
12. 如果命令行参数 `m_lpCmdLine` 不为空,则可以在这里添加命令行处理的代码。
最后,函数返回 TRUE,表示初始化成功。
void CDemoView::OnFileCreateCtl()
这是一个在 "Create Control" 命令被触发时被调用的函数,用于创建一个新的控件区域。
首先,它获取文档对象的指针 `pDoc`,然后检查当前区域是否为NULL。如果当前区域为NULL,则进入条件语句。
在条件语句中,首先创建一个矩形区域 `rect`,表示新控件的位置和大小。然后,通过使用 `new` 运算符创建一个新的 `CPanCtRgn` 控件区域对象,并传递当前视图对象、控件ID和矩形参数。
接下来,通过异常处理机制(TRY-CATCH)检查内存分配是否成功。如果分配失败,则弹出一个消息框显示 "Out of Memory",并返回。
如果内存分配成功,获取文档对象中的控件区域列表 `pList`。如果列表不为空,则将新的控件区域添加到列表的头部,并通过 `Select()` 函数选中新创建的区域。
总之,这个函数的作用是创建一个新的控件区域,并将其添加到文档对象的控件区域列表中,并选中新创建的区域。