README.TXT
上传用户:sesekoo
上传日期:2020-07-18
资源大小:21543k
文件大小:6k
源码类别:

界面编程

开发平台:

Visual C++

  1. This is a part of the Microsoft Foundation Classes C++ library.
  2. Copyright (C) 1992-1997 Microsoft Corporation
  3. All rights reserved.
  4. This source code is only intended as a supplement to the
  5. Microsoft Foundation Classes Reference and related
  6. electronic documentation provided with the library.
  7. See these sources for detailed information regarding the
  8. Microsoft Foundation Classes product.
  9. -------------------------------------------------------
  10. DRAWCLI Sample Microsoft Foundation Classes Application
  11. -------------------------------------------------------
  12. The DRAWCLI sample application illustrates the integration of OLE container
  13. support with application-specific features, effective use of polymorphism
  14. in C++, and Windows 95 logo compliance.
  15. OLE container support
  16. ---------------------
  17. The DRAWCLI was originally a stand-alone drawing application developed using
  18. the MFC classes. The stand-alone version of DRAWCLI was then integrated with
  19. a second skeleton version of DRAWCLI created using AppWizard's OLE Container
  20. feature. This process is similar to how the OLE Visual Editing server tutorial
  21. adds server support to create the Step 7 version of SCRIBBLE.
  22. The design of an MFC OLE container application should look essentially the same,
  23. regardless of whether you're adding OLE functionality to an existing stand-alone
  24. MFC (doc/view) application, or whether you're starting with an AppWizard-generated
  25. OLE container application. The following is a brief description of how DRAWCLI
  26. is separated into application-specific code and OLE container-specific code.
  27. Class CDrawObj, implemented in DRAWOBJ.CPP, is a base class for derived "shape"
  28. classes. This base class handles hit testing of shapes, moving of shapes, and
  29. resizing of shapes. Through the use of polymorphism, DRAWCLI can interact with
  30. objects of different classes through CDrawObj's interface.
  31. Classes CDrawRect and CDrawPoly are derived from CDrawObj. CDrawRect is used to
  32. draw rectangles, rounded rectangles, ellipses, and lines. CDrawPoly is used to
  33. draw polygons. These two classes are independent of DRAWCLI's OLE container
  34. functionality.
  35. Class CDrawOleObj is also derived from CDrawObj, and is used to represent OLE
  36. embedded objects. CDrawOleObj delegates any OLE-specific operation to a contained
  37. CDrawItem object (described below). For generic shape operations, OLE embedded
  38. objects are treated like other shape objects in DRAWCLI because CDrawOleObj is
  39. derived from CDrawObj.
  40. Class CDrawItem, derived from COleClientItem, handles all the OLE-specific behavior
  41. for the OLE embedded object. The implementation of CDrawItem is similar to the
  42. implementation of the COleClientItem-derived classes in the CONTAIN and OCLIENT
  43. samples.
  44. Class CDrawDoc is derived from COleDocument. The document object maintains a
  45. CObjList of CDrawObj objects. CDrawDoc delegates several OLE container-specific
  46. menu commands, such as Edit Paste, Paste Link, and Links, to the base class
  47. COleDocument.
  48. Class CDrawView is derived from CScrollView. The OLE-specific implementation of
  49. CDrawView is similar to the implementation of the view classes in the CONTAIN and
  50. OCLIENT samples. The bulk of DRAWCLI's drawing-specific user interface is also
  51. implemented in CDrawView.
  52. Windows 95 Logo compliance
  53. --------------------------
  54. All MFC applications meet some of the requirements for the Windows 95 logo:
  55. having a Win32 executable, support for long filenames, support for UNC pathnames,
  56. use of system colors and metrics, and compatibility with Windows NT. DRAWCLI
  57. meets the remaining requirements for the Windows 95 logo by including the
  58. following features:
  59.  - OLE support. DRAWCLI is an OLE container that stores its files in
  60. the compound file format, supports in-place activation, and acts as a drop
  61. target for drag-and-drop operations.
  62.  - MAPI support. DRAWCLI provides a "Send as Mail" message on its File menu,
  63. allowing the user to send a document as a mail attachment.
  64.  - Compliance with Win95 shell guidelines, including registration of large and
  65. small icons, use of the system registry instead of an .INI file, and having a
  66. setup and an uninstall program. For the latter, DRAWCLI includes a script
  67. compatible with InstallSHIELD, Stirling Software抯 toolkit for creating
  68. setup and uninstall programs.
  69. DRAWCLI also meets the following recommendations for Windows 95 applications:
  70.  - Use of tabbed property pages.
  71.  - Use of Windows 95 common controls.
  72.  - Displays a shortcut menu in response to a right-button mouse click.
  73.  - Storing Summary Information with its documents.
  74. In order to use the setup script (SETUP.RUL), you must first install
  75. InstallSHIELD from the ishield directory on the CD-ROM. Then create a directory
  76. tree with the following structure:
  77. +--+--DISK1
  78.    |
  79.    +--DATA
  80.   |
  81.   +--PROGRAM
  82.   |
  83.   +--SHARED
  84.   |
  85.   +--SAMPLES
  86.   |
  87.   +--HELP
  88. In the DATA directory, create a file named README.TXT (you can use this file).
  89. In the PROGRAM subdirectory, place a copy of DRAWCLI.EXE. In the SHARED
  90. subdirectory, place copies of MFC40.DLL, MFCO40.DLL, and MSVCRT40.DLL. In the
  91. SAMPLES subdirectory, create a file called SAMPLE.DRW. In the HELP subdirectory,
  92. create a file called DUMMY.HLP.(DRAWCLI does not currently support online help;
  93. this file is strictly a placeholder for demonstrating the setup program.)
  94. In the DISK1 directory, create an empty file named DISK1.ID. This acts as a
  95. disk identifier.
  96. Using InstallSHIELD's ICOMP.EXE, compress all the DRAWCLI files into a file
  97. named DATA.Z using the following command:
  98. > icomp data*.* disk1data.z -i
  99. Using InstallSHIELD's COMPILE.EXE, compile the script SETUP.RUL into SETUP.INS
  100. using the following command:
  101. > compile setup.rul
  102. Using InstallSHIELD's PACKLIST.EXE, compile the file SETUP.LST into SETUP.PKG
  103. using the following command:
  104. > packlist setup.lst
  105. Copy the following files to a floppy disk:
  106. (from Program FilesStirlingInstallSHIELDProgram)
  107. - SETUP.EXE
  108. - UNINST.EXE
  109. - _SETUP.DLL
  110. - _SETUP.LIB
  111. (from the directory where you placed DRAWCLI)
  112. - SETUP.INS
  113. - SETUP.PKG
  114. (from your DISK1 subdirectory)
  115. - DISK1.ID
  116. - DATA.Z
  117. The resulting floppy disk can be used to install DRAWCLI.
  118. See the InstallSHIELD documentation for more information.