]>
Commit | Line | Data |
---|---|---|
15b6757b | 1 | ///////////////////////////////////////////////////////////////////////////// |
d54cf7ff | 2 | // Name: docview.h |
15b6757b FM |
3 | // Purpose: topic overview |
4 | // Author: wxWidgets team | |
5 | // RCS-ID: $Id$ | |
6 | // Licence: wxWindows license | |
7 | ///////////////////////////////////////////////////////////////////////////// | |
8 | ||
9 | /*! | |
36c9828f | 10 | |
d54cf7ff FM |
11 | @page overview_docview Document/view overview |
12 | ||
98ba1eee FM |
13 | Classes: wxDocument, wxView, wxDocTemplate, wxDocManager, wxDocParentFrame, |
14 | wxDocChildFrame, wxDocMDIParentFrame, wxDocMDIChildFrame, | |
15 | wxCommand, wxCommandProcessor | |
36c9828f | 16 | |
15b6757b FM |
17 | The document/view framework is found in most application frameworks, because it |
18 | can dramatically simplify the code required to build many kinds of application. | |
d54cf7ff | 19 | |
15b6757b FM |
20 | The idea is that you can model your application primarily in terms of @e documents to store data |
21 | and provide interface-independent operations upon it, and @e views to visualise and manipulate | |
22 | the data. Documents know how to do input and output given stream objects, and views are responsible | |
23 | for taking input from physical windows and performing the manipulation on the document data. | |
d54cf7ff | 24 | |
15b6757b | 25 | If a document's data changes, all views should be updated to reflect the change. |
d54cf7ff FM |
26 | The framework can provide many user-interface elements based on this model. |
27 | ||
28 | Once you have defined your own classes and the relationships between them, the framework | |
29 | takes care of popping up file selectors, opening and closing files, asking the user to save | |
15b6757b FM |
30 | modifications, routing menu commands to appropriate (possibly default) code, even |
31 | some default print/preview functionality and support for command undo/redo. | |
d54cf7ff | 32 | |
15b6757b FM |
33 | The framework is highly modular, allowing overriding and replacement of functionality |
34 | and objects to achieve more than the default behaviour. | |
36c9828f | 35 | |
d54cf7ff FM |
36 | These are the overall steps involved in creating an application based on the |
37 | document/view framework: | |
38 | ||
39 | @li Define your own document and view classes, overriding a minimal set of | |
40 | member functions e.g. for input/output, drawing and initialization. | |
41 | @li Define any subwindows (such as a scrolled window) that are needed for the view(s). | |
42 | You may need to route some events to views or documents, for example OnPaint needs | |
43 | to be routed to wxView::OnDraw. | |
44 | @li Decide what style of interface you will use: Microsoft's MDI (multiple | |
45 | document child frames surrounded by an overall frame), SDI (a separate, unconstrained frame | |
46 | for each document), or single-window (one document open at a time, as in Windows Write). | |
47 | @li Use the appropriate wxDocParentFrame and wxDocChildFrame classes. Construct an instance | |
48 | of wxDocParentFrame in your wxApp::OnInit, and a wxDocChildFrame (if not single-window) when | |
49 | you initialize a view. Create menus using standard menu ids (such as wxID_OPEN, wxID_PRINT). | |
50 | @li Construct a single wxDocManager instance at the beginning of your wxApp::OnInit, and then | |
51 | as many wxDocTemplate instances as necessary to define relationships between documents and | |
52 | views. For a simple application, there will be just one wxDocTemplate. | |
36c9828f | 53 | |
15b6757b FM |
54 | If you wish to implement Undo/Redo, you need to derive your own class(es) from wxCommand |
55 | and use wxCommandProcessor::Submit instead of directly executing code. The framework will | |
56 | take care of calling Undo and Do functions as appropriate, so long as the wxID_UNDO and | |
57 | wxID_REDO menu items are defined in the view menu. | |
d54cf7ff | 58 | |
15b6757b FM |
59 | Here are a few examples of the tailoring you can do to go beyond the default framework |
60 | behaviour: | |
36c9828f | 61 | |
d54cf7ff FM |
62 | @li Override wxDocument::OnCreateCommandProcessor to define a different Do/Undo strategy, |
63 | or a command history editor. | |
98ba1eee | 64 | @li Override wxView::OnCreatePrintout to create an instance of a derived wxPrintout |
d54cf7ff FM |
65 | class, to provide multi-page document facilities. |
66 | @li Override wxDocManager::SelectDocumentPath to provide a different file selector. | |
67 | @li Limit the maximum number of open documents and the maximum number of undo commands. | |
36c9828f | 68 | |
15b6757b | 69 | Note that to activate framework functionality, you need to use some or all of |
58fa97d1 | 70 | the wxWidgets @ref overview_docview_predefid in your menus. |
36c9828f | 71 | |
d54cf7ff FM |
72 | @beginWxPerlOnly |
73 | The document/view framework is available in wxPerl. To use it, | |
74 | you will need the following statements in your application code: | |
36c9828f | 75 | |
15b6757b FM |
76 | @code |
77 | use Wx::DocView; | |
78 | use Wx ':docview'; # import constants (optional) | |
79 | @endcode | |
d54cf7ff | 80 | @endWxPerlOnly |
36c9828f | 81 | |
d54cf7ff FM |
82 | @li @ref overview_docview_wxdoc |
83 | @li @ref overview_docview_wxview | |
84 | @li @ref overview_docview_wxdoctemplate | |
85 | @li @ref overview_docview_wxdocmanager | |
86 | @li @ref overview_docview_wxcommand | |
87 | @li @ref overview_docview_wxcommandproc | |
88 | @li @ref overview_docview_filehistory | |
89 | @li @ref overview_docview_predefid | |
36c9828f | 90 | |
36c9828f | 91 | |
d54cf7ff | 92 | <hr> |
36c9828f | 93 | |
36c9828f | 94 | |
d54cf7ff FM |
95 | @section overview_docview_wxdoc wxDocument overview |
96 | ||
98ba1eee | 97 | Class: wxDocument |
d54cf7ff | 98 | |
15b6757b FM |
99 | The wxDocument class can be used to model an application's file-based |
100 | data. It is part of the document/view framework supported by wxWidgets, | |
98ba1eee | 101 | and cooperates with the wxView, wxDocTemplate and wxDocManager classes. |
15b6757b | 102 | Using this framework can save a lot of routine user-interface programming, |
d54cf7ff FM |
103 | since a range of menu commands -- such as open, save, save as -- are supported |
104 | automatically. | |
105 | ||
15b6757b FM |
106 | The programmer just needs to define a minimal set of classes and member functions |
107 | for the framework to call when necessary. Data, and the means to view and edit | |
d54cf7ff FM |
108 | the data, are explicitly separated out in this model, and the concept of multiple |
109 | @e views onto the same data is supported. | |
110 | ||
15b6757b FM |
111 | Note that the document/view model will suit many but not all styles of application. |
112 | For example, it would be overkill for a simple file conversion utility, where there | |
113 | may be no call for @e views on @e documents or the ability to open, edit and save | |
114 | files. But probably the majority of applications are document-based. | |
d54cf7ff | 115 | |
15b6757b FM |
116 | See the example application in @c samples/docview. |
117 | To use the abstract wxDocument class, you need to derive a new class and override | |
118 | at least the member functions SaveObject and LoadObject. SaveObject and | |
119 | LoadObject will be called by the framework when the document needs to be saved | |
120 | or loaded. | |
d54cf7ff | 121 | |
15b6757b FM |
122 | Use the macros DECLARE_DYNAMIC_CLASS and IMPLEMENT_DYNAMIC_CLASS in order |
123 | to allow the framework to create document objects on demand. When you create | |
98ba1eee | 124 | a wxDocTemplate object on application initialization, you |
15b6757b FM |
125 | should pass CLASSINFO(YourDocumentClass) to the wxDocTemplate constructor |
126 | so that it knows how to create an instance of this class. | |
d54cf7ff | 127 | |
15b6757b FM |
128 | If you do not wish to use the wxWidgets method of creating document |
129 | objects dynamically, you must override wxDocTemplate::CreateDocument | |
130 | to return an instance of the appropriate class. | |
36c9828f | 131 | |
36c9828f | 132 | |
d54cf7ff FM |
133 | |
134 | @section overview_docview_wxview wxView overview | |
135 | ||
98ba1eee | 136 | Class: wxView |
d54cf7ff | 137 | |
15b6757b | 138 | The wxView class can be used to model the viewing and editing component of |
d54cf7ff | 139 | an application's file-based data. It is part of the document/view framework |
98ba1eee FM |
140 | supported by wxWidgets, and cooperates with the wxDocument, wxDocTemplate |
141 | and wxDocManager classes. | |
d54cf7ff | 142 | |
15b6757b | 143 | See the example application in @c samples/docview. |
d54cf7ff | 144 | |
15b6757b FM |
145 | To use the abstract wxView class, you need to derive a new class and override |
146 | at least the member functions OnCreate, OnDraw, OnUpdate and OnClose. You will probably | |
147 | want to respond to menu commands from the frame containing the view. | |
d54cf7ff | 148 | |
15b6757b FM |
149 | Use the macros DECLARE_DYNAMIC_CLASS and IMPLEMENT_DYNAMIC_CLASS in order |
150 | to allow the framework to create view objects on demand. When you create | |
98ba1eee | 151 | a wxDocTemplate object on application initialization, you |
15b6757b FM |
152 | should pass CLASSINFO(YourViewClass) to the wxDocTemplate constructor |
153 | so that it knows how to create an instance of this class. | |
d54cf7ff | 154 | |
15b6757b FM |
155 | If you do not wish to use the wxWidgets method of creating view |
156 | objects dynamically, you must override wxDocTemplate::CreateView | |
157 | to return an instance of the appropriate class. | |
36c9828f | 158 | |
36c9828f | 159 | |
d54cf7ff FM |
160 | |
161 | @section overview_docview_wxdoctemplate wxDocTemplate overview | |
162 | ||
98ba1eee | 163 | Class: wxDocTemplate |
d54cf7ff | 164 | |
15b6757b FM |
165 | The wxDocTemplate class is used to model the relationship between a |
166 | document class and a view class. The application creates a document | |
167 | template object for each document/view pair. The list of document | |
168 | templates managed by the wxDocManager instance is used to create | |
169 | documents and views. Each document template knows what file filters | |
170 | and default extension are appropriate for a document/view combination, | |
171 | and how to create a document or view. | |
d54cf7ff | 172 | |
15b6757b FM |
173 | For example, you might write a small doodling application that can load |
174 | and save lists of line segments. If you had two views of the data -- graphical, | |
175 | and a list of the segments -- then you would create one document class DoodleDocument, | |
176 | and two view classes (DoodleGraphicView and DoodleListView). You would also | |
177 | need two document templates, one for the graphical view and another for the | |
178 | list view. You would pass the same document class and default file extension to both | |
179 | document templates, but each would be passed a different view class. When | |
180 | the user clicks on the Open menu item, the file selector is displayed | |
181 | with a list of possible file filters -- one for each wxDocTemplate. Selecting | |
d54cf7ff FM |
182 | the filter selects the wxDocTemplate, and when a file is selected, that template |
183 | will be used for creating a document and view. | |
184 | ||
15b6757b FM |
185 | For the case where an application has one document type and one view type, |
186 | a single document template is constructed, and dialogs will be appropriately | |
187 | simplified. | |
d54cf7ff | 188 | |
15b6757b | 189 | wxDocTemplate is part of the document/view framework supported by wxWidgets, |
98ba1eee | 190 | and cooperates with the wxView, wxDocument and wxDocManager classes. |
d54cf7ff | 191 | |
15b6757b | 192 | See the example application in @c samples/docview. |
d54cf7ff | 193 | |
15b6757b | 194 | To use the wxDocTemplate class, you do not need to derive a new class. |
d54cf7ff FM |
195 | Just pass relevant information to the constructor including CLASSINFO(YourDocumentClass) |
196 | and CLASSINFO(YourViewClass) to allow dynamic instance creation. | |
197 | ||
15b6757b FM |
198 | If you do not wish to use the wxWidgets method of creating document |
199 | objects dynamically, you must override wxDocTemplate::CreateDocument | |
200 | and wxDocTemplate::CreateView to return instances of the appropriate class. | |
36c9828f | 201 | |
d54cf7ff FM |
202 | @note The document template has nothing to do with the C++ template construct. |
203 | ||
204 | ||
205 | ||
206 | @section overview_docview_wxdocmanager wxDocManager overview | |
36c9828f | 207 | |
98ba1eee | 208 | Class: wxDocManager |
d54cf7ff | 209 | |
15b6757b | 210 | The wxDocManager class is part of the document/view framework supported by wxWidgets, |
98ba1eee | 211 | and cooperates with the wxView, wxDocument and wxDocTemplate classes. |
d54cf7ff FM |
212 | |
213 | A wxDocManager instance coordinates documents, views and document templates. | |
214 | It keeps a list of document and template instances, and much functionality is routed | |
215 | through this object, such as providing selection and file dialogs. | |
216 | The application can use this class 'as is' or derive a class and override some members | |
217 | to extend or change the functionality. | |
218 | ||
15b6757b FM |
219 | Create an instance of this class near the beginning of your application initialization, |
220 | before any documents, views or templates are manipulated. | |
d54cf7ff | 221 | |
15b6757b FM |
222 | There may be multiple wxDocManager instances in an application. |
223 | See the example application in @c samples/docview. | |
36c9828f | 224 | |
36c9828f | 225 | |
d54cf7ff FM |
226 | |
227 | @section overview_docview_wxcommand wxCommand overview | |
228 | ||
98ba1eee | 229 | Classes: wxCommand, wxCommandProcessor |
d54cf7ff | 230 | |
15b6757b FM |
231 | wxCommand is a base class for modelling an application command, |
232 | which is an action usually performed by selecting a menu item, pressing | |
233 | a toolbar button or any other means provided by the application to | |
234 | change the data or view. | |
d54cf7ff | 235 | |
15b6757b FM |
236 | Instead of the application functionality being scattered around |
237 | switch statements and functions in a way that may be hard to | |
238 | read and maintain, the functionality for a command is explicitly represented | |
239 | as an object which can be manipulated by a framework or application. | |
d54cf7ff | 240 | |
15b6757b | 241 | When a user interface event occurs, the application @e submits a command |
98ba1eee | 242 | to a wxCommandProcessor object to execute and store. |
d54cf7ff | 243 | |
15b6757b FM |
244 | The wxWidgets document/view framework handles Undo and Redo by use of |
245 | wxCommand and wxCommandProcessor objects. You might find further uses | |
246 | for wxCommand, such as implementing a macro facility that stores, loads | |
247 | and replays commands. | |
d54cf7ff | 248 | |
15b6757b FM |
249 | An application can derive a new class for every command, or, more likely, use |
250 | one class parameterized with an integer or string command identifier. | |
36c9828f | 251 | |
36c9828f | 252 | |
d54cf7ff FM |
253 | |
254 | @section overview_docview_wxcommandproc wxCommandProcessor overview | |
255 | ||
98ba1eee | 256 | Classes: wxCommandProcessor, wxCommand |
d54cf7ff | 257 | |
15b6757b FM |
258 | wxCommandProcessor is a class that maintains a history of wxCommand |
259 | instances, with undo/redo functionality built-in. Derive a new class from this | |
260 | if you want different behaviour. | |
36c9828f | 261 | |
36c9828f | 262 | |
d54cf7ff FM |
263 | |
264 | @section overview_docview_filehistory wxFileHistory overview | |
265 | ||
98ba1eee | 266 | Classes: wxFileHistory, wxDocManager |
d54cf7ff | 267 | |
15b6757b FM |
268 | wxFileHistory encapsulates functionality to record the last few files visited, and |
269 | to allow the user to quickly load these files using the list appended to the File menu. | |
270 | Although wxFileHistory is used by wxDocManager, it can be used independently. You may wish | |
271 | to derive from it to allow different behaviour, such as popping up a scrolling | |
272 | list of files. | |
d54cf7ff FM |
273 | |
274 | By calling wxFileHistory::UseMenu() you can associate a file menu with the file history. | |
275 | The menu will then be used for appending filenames that are added to the history. | |
276 | ||
277 | Please notice that currently if the history already contained filenames when UseMenu() | |
278 | is called (e.g. when initializing a second MDI child frame), the menu is not automatically | |
15b6757b | 279 | initialized with the existing filenames in the history and so you need to call |
98ba1eee | 280 | wxFileHistory::AddFilesToMenu() after UseMenu() explicitly in order to initialize the menu with |
d54cf7ff FM |
281 | the existing list of MRU files (otherwise an assertion failure is raised in debug builds). |
282 | ||
283 | The filenames are appended using menu identifiers in the range @c wxID_FILE1 to @c wxID_FILE9. | |
284 | ||
15b6757b FM |
285 | In order to respond to a file load command from one of these identifiers, |
286 | you need to handle them using an event handler, for example: | |
36c9828f | 287 | |
15b6757b FM |
288 | @code |
289 | BEGIN_EVENT_TABLE(wxDocParentFrame, wxFrame) | |
290 | EVT_MENU(wxID_EXIT, wxDocParentFrame::OnExit) | |
291 | EVT_MENU_RANGE(wxID_FILE1, wxID_FILE9, wxDocParentFrame::OnMRUFile) | |
292 | END_EVENT_TABLE() | |
36c9828f | 293 | |
15b6757b FM |
294 | void wxDocParentFrame::OnExit(wxCommandEvent& WXUNUSED(event)) |
295 | { | |
296 | Close(); | |
297 | } | |
36c9828f | 298 | |
15b6757b FM |
299 | void wxDocParentFrame::OnMRUFile(wxCommandEvent& event) |
300 | { | |
d54cf7ff | 301 | wxString f(m_docManager->GetHistoryFile(event.GetId() - wxID_FILE1)); |
15b6757b FM |
302 | if (!f.empty()) |
303 | (void)m_docManager-CreateDocument(f, wxDOC_SILENT); | |
304 | } | |
305 | @endcode | |
36c9828f FM |
306 | |
307 | ||
308 | ||
d54cf7ff | 309 | @section overview_docview_predefid wxWidgets predefined command identifiers |
36c9828f | 310 | |
15b6757b FM |
311 | To allow communication between the application's menus and the |
312 | document/view framework, several command identifiers are predefined for you | |
313 | to use in menus. | |
36c9828f | 314 | |
d54cf7ff | 315 | @verbatim |
15b6757b FM |
316 | wxID_OPEN (5000) |
317 | wxID_CLOSE (5001) | |
318 | wxID_NEW (5002) | |
319 | wxID_SAVE (5003) | |
320 | wxID_SAVEAS (5004) | |
321 | wxID_REVERT (5005) | |
322 | wxID_EXIT (5006) | |
323 | wxID_UNDO (5007) | |
324 | wxID_REDO (5008) | |
325 | wxID_HELP (5009) | |
326 | wxID_PRINT (5010) | |
327 | wxID_PRINT_SETUP (5011) | |
328 | wxID_PREVIEW (5012) | |
d54cf7ff | 329 | @endverbatim |
36c9828f | 330 | |
d54cf7ff | 331 | */ |
36c9828f | 332 |