PERDRAW.TXT
上传用户:bangxh
上传日期:2007-01-31
资源大小:42235k
文件大小:10k
源码类别:

Windows编程

开发平台:

Visual C++

  1. PERDRAW - IPersistStorage Persistent Object Server
  2. SUMMARY
  3. =======
  4. PERDRAW is the third sample in a group of samples that illustrate various
  5. techniques for implementing COM object persistence. The first sample,
  6. PERSERVE, illustrates persistence by implementing the IPersistStream
  7. standard interface. The second sample, PERTEXT, illustrates persistence by
  8. implementing the IPersistStreamInit standard interface. This sample,
  9. PERDRAW, illustrates persistence by implementing the IPersistStorage
  10. standard interface. The fourth sample, PERCLIEN, shows how a client
  11. exploits the kinds of persistence provided by the PERSERVE, PERTEXT, and
  12. PERDRAW server components.
  13. The PERDRAW sample introduces the CODrawPage COM object, which models a
  14. sheet of white drawing paper. CODrawPage objects expose a set of features
  15. for free-form drawing on a virtual surface using "ink" of
  16. specified color and width. CODrawPage is based on the scribble-like
  17. functionality of the COPaper object from the STOSERVE sample.
  18. CODrawPage objects expose a set of interfaces whose methods make the
  19. objects connectable, persistent managers of the drawing data. Clients
  20. access this data through an IDrawPage custom interface exposed by
  21. CODrawPage.
  22. PERDRAW maintains a clear architectural distinction between client and
  23. server. Among other things, CODrawPage provides no graphical user
  24. interface (GUI); instead, the CODrawPage object relies on the client for
  25. all GUI behavior.
  26. The PERCLIEN client provides the GUI display and manages a list of pages,
  27. the contents of which are stored in a compound file that contains both the
  28. contents of the list and of each page in that list. The user of PERCLIEN
  29. can edit the content of two types of pages: text pages and drawing pages.
  30. Text pages have data that the user can edit using a simple windowed text
  31. editor. Drawing pages have drawing data that the user can edit using
  32. free-form, scribble-like functionality based on the earlier STOSERVE and
  33. STOCLIEN samples. Both kinds of editing are done in separate client
  34. windows. For more details see PERCLIEN.HTM.
  35. Storage in the compound file is achieved because the components provide
  36. persistent COM objects that encapsulate the page list and edited page
  37. data. PERSERVE houses a persistent object that encapsulates the single
  38. page list kept in each compound file containing such pages. PERTEXT houses
  39. a persistent object that encapsulates the edited text data for each text
  40. page. PERDRAW houses a persistent object that encapsulates the drawing
  41. data for each drawing page.
  42. The COPageList object in the PERSERVE sample encapsulates the persistent
  43. page list data. COPageList implements the IPersistStream standard
  44. interface to expose control of the page list storage located in the
  45. client-provided stream of a compound file. The COTextPage object in the
  46. previous PERTEXT sample encapsulates the data of an edited text page.
  47. COTextPage implements the IPersistStreamInit standard interface to expose
  48. control of the text data storage that is located in the client-provided
  49. stream of a compound file. In contrast to these stream-based persistent
  50. objects, the CODrawPage object in this PERDRAW sample encapsulates the
  51. persistent drawing-ink data that comprises a drawing. CODrawPage
  52. implements the IPersistStorage standard interface to expose control of the
  53. drawing-ink data storage located in the client-provided substorage of a
  54. compound file.
  55. This code sample focuses primarily on the CODrawPage implementation of the
  56. IPersistStorage interface to provide storage-based persistence for a COM
  57. object. PERDRAW works with the PERCLIEN sample to demonstrate the joint
  58. use by client and server of this IPersistStorage-based persistence.
  59. CODrawPage's support for object persistence is the primary means of
  60. storing the ink data of the drawing page. CODrawPage stores its ink data
  61. in client-provided substorages located in a structured storage compound
  62. file. The compound file has a unique format because of the various streams
  63. and storages used. The client identifies these compound files as page
  64. files with a .PAG file extension. The client controls the use of the
  65. containing compound file and provides CODrawPage with an IStorage pointer
  66. to load and save its drawing data in the compound file. The IStorage
  67. pointer is passed to CODrawPage in calls to the IPersistStorage interface
  68. methods.
  69. CODrawPage also exposes an IDrawPage custom interface to manipulate the
  70. drawing data that is encapsulated by the drawing page. IDrawPage exposes
  71. the InkStart, InkDraw, InkStop, Clear, Resize, and Redraw methods.
  72. CODrawPage also supports connectable object features. It exposes the
  73. IConnectionPointContainer interface, an appropriate connection point is
  74. implemented, and an outgoing custom IDrawPageSink interface is declared to
  75. send notifications to the client.
  76. The two IDrawPage and IDrawPageSink custom interfaces are declared in
  77. IPAGES.H, which is  located in the common INC directory. PAGEGUID.H, which
  78. contains the GUID definitions for the for the interfaces and objects, is
  79. in that same directory.
  80. The PERDRAW sample uses the CThreaded facility in APPUTIL to achieve thread
  81. safety in the server housing and the class factory. Because PERDRAW.DLL is
  82. generally accessed from a Single Threaded Apartment (STA) as an in-process
  83. server, CODrawPage instances are not coded as thread-safe using the
  84. CThreaded facility. The CLSID_DrawPage component is registered as
  85. supporting the apartment threading model.
  86. For functional descriptions and a tutorial code tour of the PERDRAW
  87. sample, see the Code Tour section in PERDRAW.HTM. For details on setting
  88. up the programmatic usage of PERDRAW.DLL, see the Usage section in
  89. PERDRAW.HTM. To read PERDRAW.HTM, run TUTORIAL.EXE in the main tutorial
  90. directory and click the PERDRAW lesson in the table of lessons. You can do
  91. the same thing by double-clicking the PERDRAW.HTM file after locating the
  92. main tutorial directory in Windows Explorer. For more details on the
  93. PERCLIEN client application and how it works with PERDRAW.DLL, see
  94. PERCLIEN.HTM in the main tutorial directory. You must build PERDRAW.DLL
  95. before running the PERCLIEN sample.
  96. The PERDRAW server provides a DrawPage component that can create instances
  97. of the CODrawPage COM object. CODrawPage is housed in the PERDRAW.DLL
  98. in-process server and is made publicly available as a custom COM
  99. component. Like all other servers in this tutorial series, PERDRAW.DLL is
  100. a self-registering COM server. It makes the CODrawPage object type
  101. available to clients as the DrawPage component in the PERDRAW server using
  102. a CLSID_DrawPage registration in the Registry.
  103. PERDRAW's makefile automatically registers its DrawPage COM component in
  104. the registry, which it must do before clients can use PERDRAW.DLL as a
  105. server for the DrawPage component. This self-registration is started in
  106. the makefile using the REGISTER.EXE utility built in the REGISTER sample.
  107. To build or run PERDRAW.DLL, you must build the REGISTER code sample
  108. first.
  109. For details on setting up your system to build and test the code samples
  110. in this COM Tutorial series, see TUTORIAL.HTM. The supplied MAKEFILE is
  111. Microsoft NMAKE-compatible. To create a debug build, issue the NMAKE
  112. command in the Command Prompt window.
  113. Usage
  114. -----
  115. To use PERDRAW.DLL, a client program does not need to include PERDRAW.H or
  116. link to PERDRAW.LIB. A COM client of PERDRAW.DLL obtains access solely
  117. through its object's CLSID and COM services. For PERDRAW, that CLSID is
  118. CLSID_DrawPage (defined in PAGEGUID.H in the common INC directory).
  119. The PERCLIEN code sample shows how the client obtains this access.
  120. PERDRAW.DLL is intended primarily as a COM server. Although it can be
  121. implicitly loaded by linking to its associated .LIB file, it is normally
  122. used after an explicit LoadLibrary call, usually from within COM's
  123. CoGetClassObject function. PERDRAW is a self-registering in-process
  124. server.
  125. The makefile that builds this sample automatically registers the server in
  126. the registry. You can manually initiate its self-registration by issuing
  127. the following command at the command prompt in the PERDRAW directory:
  128.   nmake register
  129. This assumes that you have a compilation environment set up. If not, you
  130. can also directly invoke the REGISTER.EXE command at the command prompt
  131. while in the PERDRAW directory.
  132.   ..registerregister.exe perdraw.dll
  133. These registration commands require a prior build of both the REGISTER
  134. sample and PERDRAW.DLL.
  135. In this series, the makefiles use the REGISTER.EXE utility from the
  136. REGISTER sample. Recent releases of the Microsoft Platform SDK and
  137. Visual C++ include a utility, REGSVR32.EXE, which can be used in a
  138. similar fashion to register in-process servers and marshaling DLLs.
  139. FILES
  140. =====
  141. Files         Description
  142. PERDRAW.TXT   This file.
  143. MAKEFILE      The generic makefile for building the PERDRAW.DLL
  144.               code sample of this lesson.
  145. PERDRAW.H     The include file for declaring as imported or defining as
  146.               exported the service functions in PERDRAW.DLL.
  147. PERDRAW.CPP   The main implementation file for PERDRAW.DLL. Has DllMain
  148.               and the COM server functions (for example, DllGetClassObject).
  149. PERDRAW.DEF   The module definition file. Exports server housing functions.
  150. PERDRAW.RC    The DLL resource definition file for the executable.
  151. PERDRAW.ICO   The icon resource for the executable.
  152. SERVER.H      The include file for the server control C++ object.
  153. SERVER.CPP    The implementation file for the server control C++ object.
  154. FACTORY.H     The include file for the server's class factory COM objects.
  155. FACTORY.CPP   The implementation file for the server's class factories.
  156. CONNECT.H     The include file for the connection point enumerator,
  157.               connection point, and connection enumerator classes.
  158. CONNECT.CPP   The implementation file for the connection point enumerator,
  159.               connection point, and connection enumerators objects.
  160. DRAWPAGE.H    The include file for the CODrawPage COM object class.
  161. DRAWPAGE.CPP  The implementation file for the CODrawPage COM object class
  162.               and the connection points.