单文档多视图

合集下载

文档、视图、框架窗口、文档模板之间的相互关系

文档、视图、框架窗口、文档模板之间的相互关系

文档、视图、框架窗口、文档模板之间的相互关系要了解文档、视图、框架窗口、文档模板之间的相互关系,关键要理解他们的结构1、首先应该对 CWinApp类有充分的了解它包含并管理着应用程序的文档/视窗的所有信息。

它有一个成员变量CDocManager * m_pDocManager,此变量是文档/视窗的管理器,m_templateList是CDocManager里的一个列表,此列表里保存了所有文档模板的指针,当用户调用CWinApp::AddDocTemplate( pDocTemplate ) 后该pDocTemplate存入了CWinApp::m_pDocManager::m_templateList里。

CWinApp::GetFirstDocTemplatePosition()CWinApp::GetNextDocTemplate(POSITION& pos)是遍例所有的文档模板指针。

2、上面我们提到了文档模板(CMultiDocTemplate(我们主要针对对文档)),这是一个极重要的类。

CMultiDocTemplate::m_docList保存的所有该种文档的文档实例的指针列表。

下面两个函数用于维护CMultiDocTemplate::m_docList数据CMultiDocTemplate::AddDocument(CDocument* pDoc);CMultiDocTemplate::RemoveDocument(CDocument* pDoc);而CMultiDocTemplate::GetFirstDocPosition() const;CMultiDocTemplate::CDocument* GetNextDoc(POSITION& rPos ) const;用于遍例该文档类型所有文档实例。

3、上面提到文档(CDocument)CDocument 我们最熟悉不过了。

word的5种视图方式

word的5种视图方式

word的5种视图方式
1.页面。

这是Word的默认视图。

一般我们的大部分编辑操作比如新建文档、编辑文档都需要在这种模式下进行。

2.看风景。

这是一种视图模式,旨在方便阅读和浏览文档。

默认情况下,这种模式只保留便于在文档中跳转的导航窗口。

3.写作模式。

对我们来说是一种方便的写作模式。

这种模式很少用!
4.大纲视图。

它在2003版中非常流行,因为它易于查看和调整文档的层次结构,设置标题的大纲级别,并将文本段落移动到块中。

5.网页布局。

这是一个专为浏览和编辑web文档而设计的视图。

在这种模式下,您可以直接看到web文档是如何在浏览器中显示的。

word文档视图设置(word2010的视图方式有哪些)--

word文档视图设置(word2010的视图方式有哪些)--

word文档视图设置(word2010的视图方式有哪些)word怎么切换普通视图北京工商大学如何将页面视图转换为普通视图这是由于显示比例太大所致。

您可以使用以下方法使其恢复正常:选择视图选项卡:,单击按钮;然后单击“确定”。

单击单页按钮;两者都可以使页面显示恢复正常。

方法2:按住键并向下滚动鼠标滚轮以减小显示比例,并使页面显示恢复正常。

页面变得越来越好,如何变得越来越小。

上一个文档旁边有空白,但是现在不见了。

如何将其更改回以前的显示比例?另外,请查看文件页面设置。

边距是否已更改。

文档中的常用视图是什么?文档中的共同观点是什么?在文档中获取图表的最常见方法是书访方法。

共有五种类型:页面视图(最常用),普通视图,大纲视图,布局视图和阅读布局视图。

如何在参考中创建目录,选择目录,设置设置后,将自动编译目录。

提示:如果要拥有一个好的目录,则必须预先设置每个段落的格式。

步骤1.自动生成目录准备:近似索引。

如果要自动生成目录,则必须首先建立系统可以识别的轮廓索引。

这是自动生成目录的前提。

选择您的标题。

在开始选项卡中,选择格式,然后选择所需的目录格式结构。

选择后,将建立大纲索引,同时,它将具有默认的标题格式。

,以同样的方式,我们逐级设置标题,标题和其他目录结构索引。

以同样的方式,我们为整个文档中的所有标题构建了大纲索引。

第二步,自动生成和更新目录,已经进行了必要的准备,然后我们开始生成目录。

首先,将光标定位到目录的存储位置,然后单击自动引用目录或选项卡上的。

,目录将自动生成。

,如果您更新多篇文章或调整目录结构,则需要更新目录,单击目录,右键单击下拉菜单-更新字段。

,建议选择更新整个目录,以免丢失。

单击确定进行更新。

自定义目录格式调整如果您对系统的默认目录格式不满意,需要对其进行自定义,则也可以。

单击参考目录,以插入目录。

可以设置许多目录格式选项,例如是否显示页面,页面是否向右对齐,显示选项卡以及显示多个级别。

C++MFC教程

C++MFC教程

第1章Visual C++基础本章首先介绍了Visual C++ 6.0的安装,然后讨论了应用程序向导、类向导,以及文档视图结构、IDE、辅助工具等几方面的内容。

应用程序向导和类向导实际上是IDE的一部分,由于特别重要,故单独列出。

辅助工具讲的是第三方开发的辅助工具,它是集成开发环境的补充,有了它,编写程序将更加轻松快捷。

本章还将针对各个难点提供多个简单而实用的例子,可以帮助读者快速学习并掌握Visual C++开发基础。

1.1.1 Visual C++ 6.0的安装1.1.2 应用程序向导1.1.3 类向导1.1.4 文档视图结构1.1.5 IDE1.1.6 辅助工具1.2.1 新建工作空间1.2.2 增加消息映射项1.2.3 关联成员变量1.2.4 调试技巧1.2.5 单文档多视图1.2.6 多文档示例1.3.1VC项目文件说明1.3.2IDE使用技巧1.3.3常见问题1.1.2 应用程序向导使用应用程序向导可以快速生成程序框架。

选择菜单“File→New”命令,此时会弹出“New”对话框,下面对该对话框中的常用选项进行逐一说明。

1.文件(Files)属性页单击“Files”标签,打开“Files”属性页,如图1-3所示。

图1-3 文件属性页文件类型虽然多,但常用的只有两种:C/C++ Header File(C/C++头文件)和C/C++ Source File (C/C++源文件)。

新建一个文件,可以按照以下步骤操作。

(1)选择合适的文件类型。

(2)如果想把新文件加入到工程内,选中“Add to project”复选框,并在下面的组合框中选择合适的工程。

如果当前没有打开任何工程,“Add to project”会被禁用。

(3)在“File”编辑框中输入合适的文件名。

(4)在“Location”编辑框中输入文件存放位置。

2.工程(Projects)属性页单击“Projects”标签,弹出“Projects”属性页,如图1-4所示。

MFC多文档多视图编程

MFC多文档多视图编程

深入了解MFC中的文挡/视结构李泽宇金刚熊联欢姜军(华中理工大学图象识别与人工智能研究所)Visual C++ 5.0 以其功能强大、用户界面友好而倍受程序员们的青睐。

但是,在当前的Microsoft 基本类库4.2 版本中,大约有将近200 个类,数千个函数,加之Microsoft 公司隐藏了一些技术细节,使得人们深入学习MFC变得十分困难。

MFC的AppWizard可以生成三种类型的应用程序:基于对话框的应用、单文档应用(SDI)和多文档应用(MDI)。

前两者的结构较简单,本文不再赘叙。

笔者拟从MFC中的文档/视结构入手,分析一些函数的流程,并解决编制MDI 应用程序过程中的一些常见问题。

(一)、了解文档/视结构MFC应用程序模型历经多年以有了相当大的发展。

有一个时期,它只是个使用应用程序对象和主窗口对象的简单模型。

在这个模型中,应用程序的数据作为成员变量保持在框架窗口类中,在框架窗口的客户区中,该数据被提交显示器。

随着MFC2。

0的问世,一种应用程序结构的新方式----MFC文档/视结构出现了。

在这种结构中,CFrameWnd繁重的任务被委派给几个不同类,实现了数据存储和显示的分离。

一般情况下,采用文档/视结构的应用程序至少应由以下对象组成:。

应用程序是一个CwinApp派生对象,它充当全部应用程序的容器。

应用程序沿消息映射网络分配消息给它的所有子程序。

框架窗口是一CfrmeWnd派生对象。

文档是一个CDocument派生对象,它存储应用程序的数据,并把这些信息提供给应用程序的其余部分。

视窗是Cview派生对象,它与其父框架窗口用户区对齐。

视窗接受用户对应用程序的输入并显示相关联的文档数据。

通常,应用程序数据存在于简单模型中的框架窗口中。

在文档/视方式中,该数据移入称为document 的独立数据对象。

当然,文档不一定是文字,文档是可以表现应用程序使用的数据集的抽象术语。

而用户输入处理及图形输出功能从框架窗口转向视图。

如何在MFC单文档中创建多视图

如何在MFC单文档中创建多视图

u 一个文档可以有多个视图,由Document中成员变量CPtrList m_ViewList维护。
u CFrameWnd拥有一个成员变量CView* m_pActiveView指向当前活动的View。
u CView中拥有一个成员变量CDocument* m_pDocument指向该视图相关的Document。
!m_wndSplitter2.CreateView(1, 0, RUNTIME_CLASS(BottomLView), CSize(350, 240), pContext) ||
!m_wndSplitter2.CreateView(0, 1, RUNTIME_CLASS(TopRView), CSize(350, 240), pContext) ||
/wang_qingyuan/blog/item/60870400275c5b087bec2cbd.html
深入分析MFC文档视图结构
2008-10-16 19:40
文档视图结构(Document/View Architecture)是MFC的精髓,也是Observer模式的具体实现框架之一,Document/View Architecture通过将数据和其表示分开,提供了很好的数据层次和表现层次的解耦。然而,虽然我们使用MFC AppWizard就可以很轻松地获得一个支持Document/View Architecture的MFC程序框架,Document/View Architecture本身的复杂性加上VC产生的一系列代码足够让我们眼花缭乱,一时陷入云里雾里不可自拔。加上我们更多的人都没有经过Windows SDK Programming 的学习和经历就直接进行MFC Programming的学习和开发,更是面对一堆的代码不知所措。

MFC的窗口分割实例以及CSplitterWnd类

MFC的窗口分割实例以及CSplitterWnd类
在 MFC 的框架下,文档对象(CDocument)有一个保存其所有视图的列表,并提供了 增加视图(AddView)与删除视图(RemoveView)函数,以及当文档内容改变时通知其所 有视图的方法(UpdateAllViews)。通过多文档框架的窗口复制机制和单文档框架的分割窗 口机制是实现单文档多视图的主要方法。
3 分割窗口ቤተ መጻሕፍቲ ባይዱ
如图 1,把窗口分成三个视图,左视图基于 CView 类,可用来作几何图形;右上视图基 于 CEditView 类,用于显示文本消息;右下视图基于 CFormView 类,在此视图中做一个文 本框及发送、清除按钮,发送按钮用来向右上视图传送消息。
图 1 设计样式 打开 Microsoft VC++ 6.0,通过 MFC AppWizard(exe)新建名为 SplitWnd 的单文档(SDI) 工程,新建工程时所有选项均按默认设定。 工程建好后,把工程中的 CSplitWndView 视图类作为左视图所对应的类(该类的实现 与本文重点无关,故不阐述,有兴趣读者可与作者联系),由于需要三个视图窗口对应三个
视图类,因此需要手动创建右上视图、右下视图对应的类,可以通过 MFC 向导向应用程序 添加两个 MFC 类(菜单“Insert | New Class>”),因为在右上视图用于显示文本,故其基类选 CEditView,类名为 CLeftTopView;另一个 MFC 类的基类选 CFormView 类,取类名为 CLeftBttmView,该类即对应右下视图(由于该类基于 CFormView 类,需要有对话框与之对 应,故应先在资源中新建对话框,对话框中的控件如图 1)。
void CLeftBttmView::OnSendMsg() { UpdateData();//更新控件变量数据,文本框对应的变量为 m_sText //通过 CMainFrame 类中的 m_wndSplitterRight 变量获得右上视图类指针 CMainFrame * pMainFrm = (CMainFrame *)AfxGetApp()->GetMainWnd(); CWnd * pWnd = pMainFrm->m_wndSplitterRight.GetPane(0, 0); CLeftTopView* pLeftTopView = DYNAMIC_DOWNCAST(CLeftTopView, pWnd); pLeftTopView ->GetMsg( m_sText + "\r\n" );//CLeftTopView 成员函数,接收数据 } 右上视图类 CLeftTopView 的成员函数 GetMsg 则需保存接收到的消息并显示,主要代 码如下: void CLeftTopView::GetMsg(CString sMsg) { m_sAllMsg += sMsg; // m_sAllMsg 为成员变量,记录所有消息 int nTextLen = GetWindowTextLength(); GetEditCtrl().SetSel(nTextLen, nTextLen); GetEditCtrl().ReplaceSel( sMsg );//显示新消息 } 有了上面两个函数就可以实现右上视图类 CLeftTopView 与右上视图类 CLeftBttmView 之间的简单通讯,类似地,可以实现所有视图之间任意的数据传递。

c++考试题

c++考试题

VC习题1下列对于WinMain函数的描述中,错误的是()。

A)WinMain函数的名称是固定的B)WinMain函数是Windows程序的入口点C)WinMain函数不能有参数D)窗口函数与WinMain的关联是通过窗口类的注册实现的以下四个特性中哪一个不属于面向对象的三大特性()。

A)封装性B)多态性C)抽象性D)继承性下列关键字中哪一个不是用于类的访问控制的()。

A)public B)friend C)private D)protected下面四个MFC类中哪一个是管理MFC应用程序的()。

A)CWinApp B)CMainFrame C)CDocument D)CView下列类中不属于MFC框架基本类的是()。

A)CWinApp B)CFrameWnd C)CView D)CObject传统的软件开发主要采用过程驱动的方法,而Windows程序的开发使用消息驱动模型,该模型靠事件机制来实现其功能。

主框架类是应用程序中负责控制菜单、工具栏和状态栏等界面元素的最主要的类。

命令视图类文档类文档模板类框架窗口类应用程序类VC习题2VC开发环境可以生成的基于MFC appwizard的应用程序类型有单文档/视图结构、多文档/视图结构和基本对话框。

包含类定义的文件称为头文件,包含类中成员函数实现代码的文件称为源文件,包含资源信息的文件称为资源文件。

ResourceView的主要功是编辑当前工程中的资源。

应用程序向导的主要功能是帮助生产应用程序。

类向导的主要功能是管理各个类中的消息。

项目工作区窗口一般在开发环境的左侧,它包含工程的多个方面,分别是classview 、fileview 和resource view 。

项目工作区文件的扩展名为.dsw 。

VC习题3下列选项中哪一个不是命令消息的触发途径:单击对话框中的按钮。

Windows应用程序的消息来源主要包括输入消息、控制消息和系统消息、用户消息。

发送消息可以采用的两个函数是postmessage 和sendmessage 。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

相信这就是vc的弊病吧!项目作了很久发现应该用多视图,可是刚开始建立工程的时
候考虑不周阿,没办法,只能从网上搜了,竟搜到了一个不错的函数可以解决这个问题:void CMainFrame::SwitchToView(int nForm)
{
//CDocument* pDoc = GetActiveDocument();
CView *pOldActiveView=GetActiveView(); //保存旧视图
CView *pNewActiveView=(CView*)GetDlgItem(nForm); //取得新视图
if(pNewActiveView==NULL)
{
switch(nForm) //这些ID是对话框的标志符,但也可以用其他的标志
{
case IDD_PLANT_VIEW :
pNewActiveView=(CView*)new CPlantView;
break;
case IDD_HSUB_VIEW :
pNewActiveView=(CView*)new CHSubView;
break;
}
CCreateContext context; //将文挡和视图相连
context.m_pCurrentDoc=pOldActiveView->GetDocument();
pNewActiveView->Create(NULL,NULL,WS_BORDER|WS_CHILD,CFrameWnd::rectDefault,this,nForm, &context);
pNewActiveView->OnInitialUpdate();
}
SetActiveView(pNewActiveView); //改变活动的视图
pNewActiveView->ShowWindow(SW_SHOWMAXIMIZED); //显示新的视图
pOldActiveView->ShowWindow(SW_HIDE); //隐藏旧的视图
pNewActiveView->GetDocument()-SetTitle(\"。

\");
if(pOldActiveView->GetRuntimeClass() ==RUNTIME_CLASS(CHSubView))
pOldActiveView->SetDlgCtrlID(IDD_HSUB_VIEW);
else
if(pOldActiveView-GetRuntimeClass() ==RUNTIME_CLASS(CPlantView))
pOldActiveView-SetDlgCtrlID(IDD_PLANT_VIEW);
pNewActiveView-SetDlgCtrlID(AFX_IDW_PANE_FIRST);
delete pOldActiveView; //删除旧视图
RecalcLayout(); //调整框架窗口
};
这个函数很好用大家可以参考一下。

其中IDD_HSUB_VIEW 等都是新建立的FormView,也就是继承了CFormView类的新类。

注意将各个新类中的构造函数改成public,才能用此函数不出错。

由于最近做的一个程序用到了单文档多视图切换,所以把它总结一下。

内容如下:
单文档多视图的切换有两种情况,即分栏多视图切换和无分栏多视图切换,以下是两个对应情况的可重用函数:
分栏多视图切换:
Code:
1.BOOL CMainFrame::ReplaceView(int row, int col, CRuntimeClass *pViewClass, SI
ZE size)
2.{
3. CCreateContext context;
4. BOOL bSetActive;
5.
6.if ((this->m_wndSplitter.GetPane(row,col)->IsKindOf(pViewClass))==TRUE)
7.return FALSE;
8.
9.//获取文档对象的指针,以便在创建新视图的过程中能够使用它
10. CDocument * pDoc= ((CView *)m_wndSplitter.GetPane(row,col))->GetDocument
();
11.
12. CView * pActiveView=this->GetActiveView();
13.if (pActiveView==NULL || pActiveView==m_wndSplitter.GetPane(row,col))
14. bSetActive=TRUE;
15.else
16. bSetActive=FALSE;
17.
18. pDoc->m_bAutoDelete=FALSE; //设置标志,这样当视图销毁时不会删除文档
19. ((CView *) m_wndSplitter.GetPane(row,col))->DestroyWindow(); //删除存在
的视图
20. pDoc->m_bAutoDelete=TRUE; //设回默认的标志
21.
22.//创建新视图
23. context.m_pNewViewClass=pViewClass;
24. context.m_pCurrentDoc=pDoc;
25. context.m_pNewDocTemplate=NULL;
26. context.m_pLastView=NULL;
27. context.m_pCurrentFrame=NULL;
28. m_wndSplitter.CreateView(row,col,pViewClass,size, &context);
29.
30. CView * pNewView= (CView *)m_wndSplitter.GetPane(row,col);
31.
32.if (bSetActive==TRUE)
33.this->SetActiveView(pNewView);
34.
35. m_wndSplitter.RecalcLayout(); //重新计算位置
36. pNewView->OnInitialUpdate(); //调用初始化函数
37.return TRUE;
38.}
无分栏多视图切换
Code:
1.BOOL CMainFrame::ReplaceView(CRuntimeClass *pViewClass)
2.{
3. CCreateContext context;
4.
5. CDocument *pDoc = GetActiveView()->GetDocument();
6.
7.//销毁先前的视图窗口
8. pDoc->m_bAutoDelete = FALSE;
9. GetActiveView()->DestroyWindow();
10. pDoc->m_bAutoDelete = TRUE;
11.
12.//创建新视图
13. context.m_pNewViewClass = pViewClass;
14. context.m_pCurrentDoc = pDoc;
15. context.m_pNewDocTemplate = NULL;
16. context.m_pLastView = NULL;
17. context.m_pCurrentFrame = NULL;
18. CView *pNewView = (CView *)this->CreateView(&context);
19.
20.//设置新视图为活动状态
21.this->SetActiveView(pNewView);
22. RecalcLayout();
23.
24.//初始化新视图
25. pNewView->OnInitialUpdate();
26.
27.return TRUE;
28.
29.}
两种情况的原理一样,差别只在创建新视图后视图指针的获取。

一般情况下,这两个函数当中的一个放在CMainFrame里,然后在相应的响应函数里获得主窗口的指针来调用。

例如单文档无分栏情况下已经继承实现了一个视图类CDeviceTabView,切换视图的方法为:
Code:
1.//获得主窗口指针
2.CMainFrame *pFram = (CMainFrame *)AfxGetMainWnd();
3.//切换视图
4.pFram->ReplaceView(RUNTIME_CLASS(CDeviceTabView));
OK,这样就好了,希望以上内容与你有所帮助,Good luck!。

相关文档
最新文档