八宝书库 > 文学其他电子书 > 深入浅出MFC第2版(PDF格式) >

第85部分

深入浅出MFC第2版(PDF格式)-第85部分

小说: 深入浅出MFC第2版(PDF格式) 字数: 每页4000字

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!






                                              份菜单是否一开始就有功效,必须视你选 



                                              用哪一种View 而定,例如CEditView 



                                              就内建有剪贴簿功能。 



416 


…………………………………………………………Page 479……………………………………………………………

                                第7章    簡單而完整:MFC 骨幹程式 



                              标准MDI 程序应该具备的 



                               【Window】菜单 



                              【Help】菜单和About 对话框 



                              亦已备妥。 



此外,标准的工具栏和状态列也已备妥,并与菜单内容建立起映射关系。所谓工具栏, 



是将某几个常用的菜单项目以按钮型式呈现出来,有一点热键的味道。这个工具栏可以 



随处停驻(dockable )。所谓状态列,是主窗口最下方的文字显示区;只要菜单拉下,状 



态列就会显示鼠标座落的菜单项目的说明文字。状态列右侧有三个小窗口(可扩充个 



数),用来显示一些特殊按键的状态。 



                                                        417 


…………………………………………………………Page 480……………………………………………………………

               第篇    湷觥 FC  程式設計 



               打印与预视功能也已是半成品。【File 】菜单拉下来可以看到【Print。。。 】和【Print Preview 】 



               两项目: 



               骨干程序的Document 和View  目前都还是白纸一张,需要我们加工,所以一开始看不 



               出打印与预视的真正功能。但如果我们在AppWizard  中选用的View 类别是CEditView 



                (如同第4章292 页),使用者就可以打印其编辑成果,并可以在打印之前预视。也就 



               是说,一进程序代码都不必写,我们就获得了一个可以同时编辑多份文件的文字编辑软件。 



418 


…………………………………………………………Page 481……………………………………………………………

                                                 第7章    簡單而完整:MFC 骨幹程式 



Document/View 支撑你的应用程序 



      我已经多次强调,Document/View 是MFC 进化为Application Framework  的灵魂。这个特 



      征表现于程序设计技术上远多于表现在使用者接口上,因此使用者可能感觉不到什么是 



      Document/View 。程序员呢?程序员将因陌生而有一段阵痛期,然后开始享受它带来的便 



      利。 



      我们在OLE  中看到各对象(注)的集合称为一份Document ;在MDI  中看到子窗口所 



      掌握的资料称为一个Document ;现在在MFC 又看到Document 。〃Document〃 如今处处 



      可见,再过不多久八成也要和〃Object〃 一样地泛滥了。 



      OLE 对象指的是PaintBrush 完成的一张bitmap 、SoundRecorder 完成的一段Wave 声 



      音、Excel 完成的一份电子表格、Word 完成的一份文字等等等。为了恐怕与C++  的「对象」 



      混淆,有些书籍将OLE object 称为OLE item 。 



      在MFC 之中,你可以把Document 简单想作是「资料」。是的,只是资料,那么MFC 



      的CDocument 简单地说就是负责处理资料的类别。 



      问题是,一个预先写好的类别怎么可能管理未知的资料呢?MFC 设计之际那些伟大的天 



      才们并不知道我们的数据结构,不是吗?! 他怎么知道我的程序要处理的资料是简单 



      如: 



         char  name'20'; 

         char  address'30'; 

         int   age; 

         bool  sex; 



      或是复杂如: 



         struct dbllistnode 

                { 

                  struct dbllistnode *next; *prev; 

                  struct info_t 

                         { 

                          int left; 

                          int top; 



                                                                                  419 


…………………………………………………………Page 482……………………………………………………………

                           第篇    湷觥 FC  程式設計 



                                               int width; 

                                               int height; 

                                               void (*cursor)(); 

                                              } *item; 

                                     }; 



                         的确,预先处理未知的资料根本是不可能的。CDocument 只是把空壳做好,等君入瓮。 



                         它可以内嵌其它对象(用来处理基层数据类型如串行、数组等等),所以程序员可以在 



                         Document  中拼拼凑凑出实际想要表达的文件完整格式。下一章进入Scribble 程序的实际 



                         设计时,你就能够感受这一点。 



                         CDocument 的另一价值在于它搭配了另一个重要的类别:CView。 



                         不论什么型式,数据总是有体有面。实际的资料数值就是体,显示在屏幕上(甚而打印 



                         机上)的画面就是面(图7…3a )。「数值的处理」应该使用字节、整数、浮点数、串 



                         列、数组等数据结构,而「数值的表现」应该使用绘图工具如坐标系统、笔刷颜色、点 



                         线圆弧、字形。。。。CView 就是为了资料的表现而设计的。 



                            CMyDoc::Serialize(。。。) 

                                                         CMyView::OnDraw(。。。) 

                            { 

                                                         { 

                             // 把资料读出文件                   // 取得Document, 

                             // 放入Document 中              // 调用GDI 函数, 

                            }                             // 将资料表现出来。 



                                                         } 

                                          磁盘中的文件 



                                The C++ piler gen 

                                ings; all of which a 

                                are caused by the ol 

                                。。。 



                                Hello; I am J。J。Hou;  

                                a goodman。 

                                。。。 



                                The difference; omit 

                                lpCmdLine parameter 

                                。。。 



                             图7…3a Document 是资料的体, View 是资料的面。 



         420 



} 


…………………………………………………………Page 483……………………………………………………………

                                                第7章    簡單而完整:MFC 骨幹程式 



 除了负责显示,View 还负责程序与使用者之间的交谈接口。使用者对资料的编辑、修改 



 都需仰赖窗口上的鼠标与键盘动作才得完成,这些消息都将由View 接受后再通知 



 Document ( 图7…3b) 。 



   CMyDoc::Serialize(。。。)       CMyView::OnLButtonDown(。。。) 

   {                            { 

   //把资料从Document 写入文件           //记录鼠标位置为DWORD, 

                                 //并将DWORD 加入Document 

   }                            } 



                                                        当使用者在窗口中按下鼠标左键,LButtonDown 

                  磁盘中的文件文件 

                                                        消息会被窗口攫取,只要程序员曾对此消息设定 

          04 00 FF FF 01 00 07 

          43 53 74 72 6F 6B 65                          消息映射,CMyView::OnLButtonDown 就会被 

          00 02 00 26 00 08 00 

          。。。                                           调用. 



          00 08 00 01 80 05 00 

          00 26 00 1C 00 27 00 

          。。。 



          00 27 00 1C 00 01 80 

          。。。 



            图7…3b View 是Document 的第一线, 负责与使用者接触。 



Document/View  的价值在于,这些MFC 类别已经把一个应用程序所需的「数据处理与 



显示」的函数空壳都设计好了,这些函数都是虚拟函数,所以你可以(也应该)在衍生 



类别中改写它们。有关文件读写的动作在CDocument 的Serialize  函数进行,有关画面显 



示的动作在CView 的OnDraw 或OnPaint 函数进行。当我为自己衍生两个类别CMyDoc 



和CMyView,我只要把全付心思花在CMyDoc::Serialize 和CMyView::OnDraw 身上,其它 



琐事一概不必管,整个程序自动会运作得好好的。 



                                                                                  421 


…………………………………………………………Page 484……………………………………………………………

              第篇    湷觥 FC  程式設計 



              什么叫做「整个程序会自动运作良好」?以下是三个例子: 



                ■  如果按下【File/Open 】,Application Framework 会激活对话框让你指定文件名, 



                  然后自动调用CMyDoc::Serialize 读档。Application Framework 还会调用 



                  CMyView::OnDraw,把资料显示出来。 



                ■   如果屏幕状态改变, 产生了WM_PAINT  , Framework 会自动调用你的 



                  CMyView::OnDraw,传一个Display DC 让你重新绘制窗口内容。 



                ■   如果按下【File/Print。。。】,Framework 会自动调用你的CMyView::OnDraw,这 



                  次传进去的是个Printer DC ,因此绘图动作的输出对象就成了打印机。 



              MFC  已经把程序大架构完成了,模块与模块间的消息流动路径以及各函数的功能职司都 



               已确定好(这是MFC 之所以够格称为一个Framework  的原因),所以我们写程序的焦 



              点就放在那些必须改写的虚拟函数身上即可。软件界当初发展GUI 系统时,目的也是 



              希望把程序员的心力导引到应用软件的真正目标去,而不必花在使用者接口上。MFC  的 



              Document/View 架构希望更把程序员的心力导引到真正的数据结构设计以及真正的数据 



              显示动作上,而不要花在模块的沟通或消息的流动传递上。今天,程序员都对GUI 称 



               便,Document/View 也即将广泛地证明它的贡献。 



              Application Framework 使我们的程序写作犹如做填充题;Visual C++  的软件开发工具则 



              使我们的程序写作犹如做选择题。我们先做选择题,再在骨干程序中做填充题。的确, 



              程序员的生活愈来愈像侯捷所言「只是软件IC 装配厂里的男工女工」了。 



              现在让我们展开MFC 深度之旅,彻底把MFC 骨干程序的每一行都搞清楚。你应该已 



              经从上一章具体了解了MFC 程序从激活到结束的生命过程,这一章的例子虽然比较复 



              杂,程序的生命过程是一样的。我们看看新添了什么内容,以及它们如何运作。我将以 



              AppWizard 完成的Scribble Step0  (第4章)为解说对象,一行不改。然后我会做一点点 



              修改,使它成为一个多窗口文字编辑器。 



422 


…………………………………………………………Page 485……………………………………………………………

                                               

返回目录 上一页 下一页 回到顶部 0 0

你可能喜欢的