]> git.saurik.com Git - wxWidgets.git/blob - docs/latex/proplist/classes.tex
(start of) wxCustomDataObject docs
[wxWidgets.git] / docs / latex / proplist / classes.tex
1 \chapter{Alphabetical class reference}\label{classref}
2 \setheader{{\it CHAPTER \thechapter}}{}{}{}{}{{\it CHAPTER \thechapter}}%
3 \setfooter{\thepage}{}{}{}{}{\thepage}%
4
5 \overview{Property classes overview}{propertyoverview}
6
7 \section{\class{wxBoolFormValidator}: wxPropertyFormValidator}\label{wxboolformvalidator}
8
9 \overview{Validator classes}{validatorclasses}
10
11 This class validates a boolean value for a form view. The associated panel item must be a wxCheckBox.
12
13 \membersection{wxBoolFormValidator::wxBoolFormValidator}
14
15 \func{void}{wxBoolFormValidator}{\param{long }{flags=0}}
16
17 Constructor.
18
19 \section{\class{wxBoolListValidator}: wxPropertyListValidator}\label{wxboollistvalidator}
20
21 \overview{Validator classes}{validatorclasses}
22
23 This class validates a boolean value for a list view.
24
25 \membersection{wxBoolListValidator::wxBoolListValidator}
26
27 \func{void}{wxBoolListValidator}{\param{long }{flags=0}}
28
29 Constructor.
30
31 \section{\class{wxIntegerFormValidator}: wxPropertyFormValidator}\label{wxintegerformvalidator}
32
33 \overview{Validator classes}{validatorclasses}
34
35 This class validates a range of integer values for a form view. The associated panel item must be a wxText
36 or wxSlider.
37
38 \membersection{wxIntegerFormValidator::wxIntegerFormValidator}
39
40 \func{void}{wxIntegerFormValidator}{\param{long }{min=0}, \param{long }{max=0},
41 \param{long}{ flags=0}}
42
43 Constructor. Assigning zero to minimum and maximum values indicates that there is no range to check.
44
45
46 \section{\class{wxIntegerListValidator}: wxPropertyListValidator}\label{wxintegerlistvalidator}
47
48 \overview{Validator classes}{validatorclasses}
49
50 This class validates a range of integer values for a list view.
51
52 \membersection{wxIntegerListValidator::wxIntegerListValidator}
53
54 \func{void}{wxIntegerListValidator}{\param{long }{min=0}, \param{long }{max=0},
55 \param{long}{ flags=wxPROP\_ALLOW\_TEXT\_EDITING}}
56
57 Constructor. Assigning zero to minimum and maximum values indicates that there is no range to check.
58
59 \section{\class{wxFilenameListValidator}: wxPropertyListValidator}\label{wxfilenamelistvalidator}
60
61 \overview{Validator classes}{validatorclasses}
62
63 This class validates a filename for a list view, allowing the user to edit it textually and also popping up
64 a file selector in ``detailed editing" mode.
65
66 \membersection{wxFilenameListValidator::wxFilenameListValidator}
67
68 \func{void}{wxFilenameListValidator}{\param{wxString }{message = ``Select a file"}, \param{wxString }{wildcard = ``*.*"},
69 \param{long}{ flags=0}}
70
71 Constructor. Supply an optional message and wildcard.
72
73 \section{\class{wxListOfStringsListValidator}: wxPropertyListValidator}\label{wxlistofstringslistvalidator}
74
75 \overview{Validator classes}{validatorclasses}
76
77 This class validates a list of strings for a list view. When editing the property,
78 a dialog box is presented for adding, deleting or editing entries in the list.
79 At present no constraints may be supplied.
80
81 You can construct a string list property value by constructing a wxStringList object.
82
83 For example:
84
85 \begin{verbatim}
86 myListValidatorRegistry.RegisterValidator((wxString)"stringlist",
87 new wxListOfStringsListValidator);
88
89 wxStringList *strings = new wxStringList("earth", "fire", "wind", "water", NULL);
90
91 sheet->AddProperty(new wxProperty("fred", strings, "stringlist"));
92 \end{verbatim}
93
94 \membersection{wxListOfStringsListValidator::wxListofStringsListValidator}
95
96 \func{void}{wxListOfStringsListValidator}{\param{long}{ flags=0}}
97
98 Constructor.
99
100 \section{\class{wxProperty}: wxObject}\label{wxproperty}
101
102 The {\bf wxProperty} class represents a property, with a \helpref{wxPropertyValue}{wxpropertyvalue}\rtfsp
103 containing the actual value, a name a role, an optional validator, and
104 an optional associated window.
105
106 A property might correspond to an actual C++ data member, or it
107 might correspond to a conceptual property, such as the width of a window.
108 There is no explicit data member {\it wxWindow::width}, but it may be convenient
109 to invent such a property for the purposes of editing attributes of the window.
110 The properties in the property sheet can be mapped to ``reality" by
111 whatever means (in this case by calling wxWindow::SetSize when the user has
112 finished editing the property sheet).
113
114 A validator may be associated with the property in order to ensure that this and
115 only this validator will be used for editing and validating the property.
116 An alternative method is to use the {\it role} parameter to specify what kind
117 of validator would be appropriate; for example, specifying ``filename" for the role
118 would allow the property view to find an appropriate validator at edit time.
119
120
121 \membersection{wxProperty::wxProperty}
122
123 \func{void}{wxProperty}{\void}
124
125 \func{void}{wxProperty}{\param{wxProperty\& }{prop}}
126
127 \func{void}{wxProperty}{\param{wxString}{ name}, \param{wxString}{ role}, \param{wxPropertyValidator *}{validator=NULL}}
128
129 \func{void}{wxProperty}{\param{wxString}{ name}, \param{const wxPropertyValue\&}{ val}, \param{wxString}{ role}, \param{wxPropertyValidator *}{validator=NULL}}
130
131 Constructors.
132
133 \membersection{wxProperty::\destruct{wxProperty}}
134
135 \func{void}{\destruct{wxProperty}}{\void}
136
137 Destructor. Destroys the wxPropertyValue, and the property validator if there is one. However, if the
138 actual C++ value in the wxPropertyValue is a pointer, the data in that variable is not destroyed.
139
140 \membersection{wxProperty::GetValue}
141
142 \func{wxPropertyValue\&}{GetValue}{\void}
143
144 Returns a reference to the property value.
145
146 \membersection{wxProperty::GetValidator}
147
148 \func{wxPropertyValidator *}{GetValidator}{\void}
149
150 Returns a pointer to the associated property validator (if any).
151
152 \membersection{wxProperty::GetName}
153
154 \func{wxString\&}{GetName}{\void}
155
156 Returns the name of the property.
157
158 \membersection{wxProperty::GetRole}
159
160 \func{wxRole\&}{GetRole}{\void}
161
162 Returns the role of the property, to be used when choosing an appropriate validator.
163
164 \membersection{wxProperty::GetWindow}
165
166 \func{wxWindow *}{GetWindow}{\void}
167
168 Returns the window associated with the property (if any).
169
170 \membersection{wxProperty::SetValue}
171
172 \func{void}{SetValue}{\param{wxPropertyValue\&}{ val}}
173
174 Sets the value of the property.
175
176 \membersection{wxProperty::SetName}
177
178 \func{void}{SetName}{\param{wxString\&}{ name}}
179
180 Sets the name of the property.
181
182 \membersection{wxProperty::SetRole}
183
184 \func{void}{SetRole}{\param{wxString\&}{ role}}
185
186 Sets the role of the property.
187
188 \membersection{wxProperty::SetValidator}
189
190 \func{void}{SetValidator}{\param{wxPropertyValidator *}{validator}}
191
192 Sets the validator: this will be deleted when the property is deleted.
193
194 \membersection{wxProperty::SetWindow}
195
196 \func{void}{SetWindow}{\param{wxWindow *}{win}}
197
198 Sets the window associated with the property.
199
200 \membersection{wxProperty::operator $=$}
201
202 \func{void}{operator $=$}{\param{const wxPropertyValue\&}{ val}}
203
204 Assignment operator.
205
206 \section{\class{wxPropertyFormValidator}: wxPropertyValidator}\label{wxpropertyformvalidator}
207
208 The {\bf wxPropertyFormValidator} abstract class is the root of classes that define validation
209 for a wxPropertyFormView.
210
211
212 \section{\class{wxPropertyFormDialog}: wxDialogBox}\label{wxpropertyformdialog}
213
214 The {\bf wxPropertyFormDialog} class is a prepackaged dialog which can
215 be used for viewing a form property sheet. Pass a property form view object, and the dialog
216 will pass OnClose and OnDefaultAction listbox messages to the view class for
217 processing.
218
219 \membersection{wxPropertyFormDialog::wxPropertyFormDialog}
220
221 \func{void}{wxPropertyFormDialog}{\param{wxPropertyFormView *}{view}, \param{wxWindow *}{parent}, \param{char *}{title},
222 \param{Bool}{ modal=FALSE}, \param{int}{ x=-1}, \param{int}{ y=-1}, \param{int}{ width=-1}, \param{int}{height=-1},
223 \param{long}{ style=wxDEFAULT\_DIALOG\_STYLE}, \param{char *}{name=``dialogBox"}}
224
225 Constructor.
226
227 \membersection{wxPropertyFormDialog::\destruct{wxPropertyFormDialog}}
228
229 \func{void}{\destruct{wxPropertyFormDialog}}{\void}
230
231 Destructor.
232
233
234 \section{\class{wxPropertyFormFrame}: wxFrame}\label{wxpropertyformframe}
235
236 The {\bf wxPropertyFormFrame} class is a prepackaged frame which can
237 be used for viewing a property form. Pass a property form view object, and the frame
238 will pass OnClose messages to the view class for processing.
239
240 Call Initialize to create the panel and associate the view; override OnCreatePanel
241 if you wish to use a panel class other than the default wxPropertyFormPanel.
242
243 \membersection{wxPropertyFormFrame::wxPropertyFormFrame}
244
245 \func{void}{wxPropertyFormFrame}{\param{wxPropertyFormView *}{view}, \param{wxFrame *}{parent}, \param{char *}{title},
246 \param{int}{ x=-1}, \param{int}{ y=-1}, \param{int}{ width=-1}, \param{int}{height=-1},
247 \param{long}{ style=wxSDI $\|$ wxDEFAULT\_FRAME}, \param{char *}{name=``frame"}}
248
249 Constructor.
250
251 \membersection{wxPropertyFormFrame::\destruct{wxPropertyFormFrame}}
252
253 \func{void}{\destruct{wxPropertyFormFrame}}{\void}
254
255 Destructor.
256
257 \membersection{wxPropertyFormFrame::GetPropertyPanel}
258
259 \func{wxPanel *}{GetPropertyPanel}{\void}
260
261 Returns the panel associated with the frame.
262
263 \membersection{wxPropertyFormFrame::Initialize}
264
265 \func{Bool}{Initialize}{\void}
266
267 Must be called to create the panel and associate the view with the panel and frame.
268
269 \membersection{wxPropertyFormFrame::OnCreatePanel}
270
271 \func{wxPanel *}{OnCreatePanel}{\param{wxFrame *}{parent}, \param{wxPropertyFormView *}{view}}
272
273 Creates a panel. Override this to create a panel type other than wxPropertyFormPanel.
274
275
276 \section{\class{wxPropertyFormPanel}: wxPanel}\label{wxpropertyformpanel}
277
278 The {\bf wxPropertyFormPanel} class is a prepackaged panel which can
279 be used for viewing a property form. Pass a property form view object, and the panel
280 will pass OnDefaultAction listbox messages to the view class for
281 processing.
282
283 \membersection{wxPropertyFormPanel::wxPropertyFormPanel}
284
285 \func{void}{wxPropertyFormPanel}{\param{wxPropertyFormView *}{view}, \param{wxWindow *}{parent},
286 \param{int}{ x=-1}, \param{int}{ y=-1}, \param{int}{ width=-1}, \param{int}{height=-1},
287 \param{long}{ style=0}, \param{char *}{name=``panel"}}
288
289 Constructor.
290
291 \membersection{wxPropertyFormPanel::\destruct{wxPropertyFormPanel}}
292
293 \func{void}{\destruct{wxPropertyFormPanel}}{\void}
294
295 Destructor.
296
297
298
299 \section{\class{wxPropertyFormValidator}: wxPropertyValidator}\label{wxpropertyformvalidatir}
300
301 \overview{wxPropertyFormValidator overview}{wxpropertyformvalidatoroverview}
302
303 The {\bf wxPropertyFormValidator} class defines a base class for form validators. By overriding virtual functions,
304 the programmer can create custom behaviour for kinds of property.
305
306 \membersection{wxPropertyFormValidator::wxPropertyFormValidator}
307
308 \func{void}{wxPropertyFormValidator}{\param{long}{ flags = 0}}
309
310 Constructor.
311
312 \membersection{wxPropertyFormValidator::\destruct{wxPropertyFormValidator}}
313
314 \func{void}{\destruct{wxPropertyFormValidator}}{\void}
315
316 Destructor.
317
318 \membersection{wxPropertyFormValidator::OnCommand}
319
320 \func{Bool}{OnCommand}{\param{wxProperty *}{property}, \param{wxPropertyFormView *}{view},
321 \param{wxWindow *}{parentWindow}, \param{wxCommandEvent\& }{event}}
322
323 Called when the control corresponding to the property receives a command (if not intercepted
324 by a callback associated with the actual control).
325
326 \membersection{wxPropertyFormValidator::OnCheckValue}
327
328 \func{Bool}{OnCheckValue}{\param{wxProperty *}{property}, \param{wxPropertyFormView *}{view},
329 \param{wxWindow *}{parentWindow}}
330
331 Called when the view checks the property value. The value checked by this validator should be taken from the
332 panel item corresponding to the property.
333
334 \membersection{wxPropertyFormValidator::OnDisplayValue}
335
336 \func{Bool}{OnDisplayValue}{\param{wxProperty *}{property}, \param{wxPropertyFormView *}{view},
337 \param{wxWindow *}{parentWindow}}
338
339 Should display the property value in the appropriate control.
340
341 \membersection{wxPropertyFormValidator::OnDoubleClick}
342
343 \func{Bool}{OnDoubleClick}{\param{wxProperty *}{property}, \param{wxPropertyFormView *}{view},
344 \param{wxWindow *}{parentWindow}}
345
346 Called when the control corresponding to the property is double clicked (listboxes only).
347
348 \membersection{wxPropertyFormValidator::OnRetrieveValue}
349
350 \func{Bool}{OnRetrieveValue}{\param{wxProperty *}{property}, \param{wxPropertyFormView *}{view},
351 \param{wxWindow *}{parentWindow}}
352
353 Should do the transfer from the property editing area to the property itself.
354
355
356 \section{\class{wxPropertyFormView}: wxPropertyView}\label{wxpropertyformview}
357
358 \overview{wxPropertyFormView overview}{wxpropertyformviewoverview}
359
360 The {\bf wxPropertyFormView} class shows a wxPropertySheet as a view onto a panel or dialog
361 box which has already been created.
362
363 \membersection{wxPropertyFormView::wxPropertyFormView}
364
365 \func{void}{wxPropertyFormView}{\param{long}{ flags = 0}}
366
367 Constructor.
368
369 \membersection{wxPropertyFormView::\destruct{wxPropertyFormView}}
370
371 \func{void}{\destruct{wxPropertyFormView}}{\void}
372
373 Destructor.
374
375 \membersection{wxPropertyFormView::AssociateNames}\label{wxpropertyformviewassociatenames}
376
377 \func{void}{AssociateNames}{\void}
378
379 Associates the properties with the controls on the panel. For each panel item, if the
380 panel item name is the same as a property name, the two objects will be associated.
381 This function should be called manually since the programmer may wish to do the
382 association manually.
383
384 \membersection{wxPropertyFormView::Check}\label{wxpropertyformviewcheck}
385
386 \func{Bool}{Check}{\void}
387
388 Checks all properties by calling the appropriate validators; returns FALSE if a validation failed.
389
390 \membersection{wxPropertyFormView::GetPanel}\label{wxpropertyformviewgetpanel}
391
392 \func{wxPanel *}{GetPanel}{\void}
393
394 Returns the panel associated with the view.
395
396 \membersection{wxPropertyFormView::GetManagedWindow}\label{wxpropertyformviewgetmanagedwindow}
397
398 \func{wxWindow *}{GetManagedWindow}{\void}
399
400 Returns the managed window (a frame or dialog) associated with the view.
401
402 \membersection{wxPropertyFormView::OnOk}\label{wxpropertyformviewonok}
403
404 \func{void}{OnOk}{\void}
405
406 Virtual function that will be called when the OK button on the physical window is pressed.
407 By default, checks and updates the form values, closes and deletes the frame or dialog, then deletes the view.
408
409 \membersection{wxPropertyFormView::OnCancel}\label{wxpropertyformviewoncancel}
410
411 \func{void}{OnCancel}{\void}
412
413 Virtual function that will be called when the Cancel button on the physical window is pressed.
414 By default, closes and deletes the frame or dialog, then deletes the view.
415
416 \membersection{wxPropertyFormView::OnHelp}\label{wxpropertyformviewonhelp}
417
418 \func{void}{OnHelp}{\void}
419
420 Virtual function that will be called when the Help button on the physical window is pressed.
421 This needs to be overridden by the application for anything interesting to happen.
422
423 \membersection{wxPropertyFormView::OnRevert}\label{wxpropertyformviewonrevert}
424
425 \func{void}{OnRevert}{\void}
426
427 Virtual function that will be called when the Revert button on the physical window is pressed.
428 By default transfers the wxProperty values to the panel items (in effect
429 undoing any unsaved changes in the items).
430
431 \membersection{wxPropertyFormView::OnUpdate}\label{wxpropertyformviewonupdate}
432
433 \func{void}{OnUpdate}{\void}
434
435 Virtual function that will be called when the Update button on the physical window is pressed.
436 By defaults transfers the displayed values to the wxProperty objects.
437
438 \membersection{wxPropertyFormView::SetManagedWindow}\label{wxpropertyformviewsetmanagedwindow}
439
440 \func{void}{SetManagedWindow}{\param{wxWindow *}{win}}
441
442 Sets the managed window (a frame or dialog) associated with the view.
443
444 \membersection{wxPropertyFormView::TransferToDialog}\label{wxpropertyformviewtransfertodialog}
445
446 \func{Bool}{TransferToDialog}{\void}
447
448 Transfers property values to the controls in the dialog.
449
450 \membersection{wxPropertyFormView::TransferToPropertySheet}\label{wxpropertyformviewtransfertopropertysheet}
451
452 \func{Bool}{TransferToPropertySheet}{\void}
453
454 Transfers property values from the controls in the dialog to the property sheet.
455
456
457 \section{\class{wxPropertyListDialog}: wxDialogBox}\label{wxpropertylistdialog}
458
459 The {\bf wxPropertyListDialog} class is a prepackaged dialog which can
460 be used for viewing a property list. Pass a property list view object, and the dialog
461 will pass OnClose and OnDefaultAction listbox messages to the view class for
462 processing.
463
464 \membersection{wxPropertyListDialog::wxPropertyListDialog}
465
466 \func{void}{wxPropertyListDialog}{\param{wxPropertyListView *}{view}, \param{wxWindow *}{parent}, \param{char *}{title},
467 \param{Bool}{ modal=FALSE}, \param{int}{ x=-1}, \param{int}{ y=-1}, \param{int}{ width=-1}, \param{int}{height=-1},
468 \param{long}{ style=wxDEFAULT\_DIALOG\_STYLE}, \param{char *}{name=``dialogBox"}}
469
470 Constructor.
471
472 \membersection{wxPropertyListDialog::\destruct{wxPropertyListDialog}}
473
474 \func{void}{\destruct{wxPropertyListDialog}}{\void}
475
476 Destructor.
477
478
479 \section{\class{wxPropertyListFrame}: wxFrame}\label{wxpropertylistframe}
480
481 The {\bf wxPropertyListFrame} class is a prepackaged frame which can
482 be used for viewing a property list. Pass a property list view object, and the frame
483 will pass OnClose messages to the view class for processing.
484
485 Call Initialize to create the panel and associate the view; override OnCreatePanel
486 if you wish to use a panel class other than the default wxPropertyListPanel.
487
488 \membersection{wxPropertyListFrame::wxPropertyListFrame}
489
490 \func{void}{wxPropertyListFrame}{\param{wxPropertyListView *}{view}, \param{wxFrame *}{parent}, \param{char *}{title},
491 \param{int}{ x=-1}, \param{int}{ y=-1}, \param{int}{ width=-1}, \param{int}{height=-1},
492 \param{long}{ style=wxSDI $\|$ wxDEFAULT\_FRAME}, \param{char *}{name=``frame"}}
493
494 Constructor.
495
496 \membersection{wxPropertyListFrame::\destruct{wxPropertyListFrame}}
497
498 \func{void}{\destruct{wxPropertyListFrame}}{\void}
499
500 Destructor.
501
502 \membersection{wxPropertyListFrame::GetPropertyPanel}
503
504 \func{wxPanel *}{GetPropertyPanel}{\void}
505
506 Returns the panel associated with the frame.
507
508 \membersection{wxPropertyListFrame::Initialize}
509
510 \func{Bool}{Initialize}{\void}
511
512 Must be called to create the panel and associate the view with the panel and frame.
513
514 \membersection{wxPropertyListFrame::OnCreatePanel}
515
516 \func{wxPanel *}{OnCreatePanel}{\param{wxFrame *}{parent}, \param{wxPropertyListView *}{view}}
517
518 Creates a panel. Override this to create a panel type other than wxPropertyListPanel.
519
520
521 \section{\class{wxPropertyListPanel}: wxPanel}\label{wxpropertylistpanel}
522
523 The {\bf wxPropertyListPanel} class is a prepackaged panel which can
524 be used for viewing a property list. Pass a property list view object, and the panel
525 will pass OnDefaultAction listbox messages to the view class for
526 processing.
527
528 \membersection{wxPropertyListPanel::wxPropertyListPanel}
529
530 \func{void}{wxPropertyListPanel}{\param{wxPropertyListView *}{view}, \param{wxWindow *}{parent},
531 \param{int}{ x=-1}, \param{int}{ y=-1}, \param{int}{ width=-1}, \param{int}{height=-1},
532 \param{long}{ style=0}, \param{char *}{name=``panel"}}
533
534 Constructor.
535
536 \membersection{wxPropertyListPanel::\destruct{wxPropertyListPanel}}
537
538 \func{void}{\destruct{wxPropertyListPanel}}{\void}
539
540 Destructor.
541
542
543
544
545 \section{\class{wxPropertyListValidator}: wxPropertyValidator}\label{wxpropertylistvalidator}
546
547 \overview{wxPropertyListValidator overview}{wxpropertylistvalidatoroverview}
548
549 The {\bf wxPropertyListValidator} abstract class is the base class for
550 deriving validators for property lists.
551
552 \membersection{wxPropertyListValidator::wxPropertyListValidator}
553
554 \func{void}{wxPropertyListValidator}{\param{long}{ flags = wxPROP\_ALLOW\_TEXT\_EDITING}}
555
556 Constructor.
557
558 \membersection{wxPropertyListValidator::\destruct{wxPropertyListValidator}}
559
560 \func{void}{\destruct{wxPropertyListValidator}}{\void}
561
562 Destructor.
563
564 \membersection{wxPropertyListValidator::OnCheckValue}
565
566 \func{Bool}{OnCheckValue}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
567 \param{wxWindow *}{parentWindow}}
568
569 Called when the Tick (Confirm) button is pressed or focus is list. Return FALSE if the value
570 was invalid, which is a signal restores the old value. Return TRUE if the value was valid.
571
572 \membersection{wxPropertyListValidator::OnClearControls}
573
574 \func{Bool}{OnClearControls}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
575 \param{wxWindow *}{parentWindow}}
576
577 Allows the clearing (enabling, disabling) of property list controls, when the focus leaves the current property.
578
579 \membersection{wxPropertyListValidator::OnClearDetailControls}
580
581 \func{Bool}{OnClearDetailControls}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
582 \param{wxWindow *}{parentWindow}}
583
584 Called when the focus is lost, if the validator is in detailed editing mode.
585
586 \membersection{wxPropertyListValidator::OnDisplayValue}
587
588 \func{Bool}{OnDisplayValue}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
589 \param{wxWindow *}{parentWindow}}
590
591 Should display the value in the appropriate controls. The default implementation gets the
592 textual value from the property and inserts it into the text edit control.
593
594 \membersection{wxPropertyListValidator::OnDoubleClick}
595
596 \func{Bool}{OnDoubleClick}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
597 \param{wxWindow *}{parentWindow}}
598
599 Called when the property is double clicked. Extra functionality can be provided,
600 such as cycling through possible values.
601
602 \membersection{wxPropertyListValidator::OnEdit}
603
604 \func{Bool}{OnEdit}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
605 \param{wxWindow *}{parentWindow}}
606
607 Called when the Edit (detailed editing) button is pressed. The default implementation
608 calls wxPropertyListView::BeginDetailedEditing; a filename validator (for example) overrides
609 this function to show the file selector.
610
611 \membersection{wxPropertyListValidator::OnPrepareControls}
612
613 \func{Bool}{OnPrepareControls}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
614 \param{wxWindow *}{parentWindow}}
615
616 Called to allow the validator to setup the display, such enabling or disabling buttons, and
617 setting the values and selection in the standard listbox control (the one optionally used for displaying
618 value options).
619
620 \membersection{wxPropertyListValidator::OnPrepareDetailControls}
621
622 \func{Bool}{OnPrepareDetailControls}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
623 \param{wxWindow *}{parentWindow}}
624
625 Called when the property is edited `in detail', i.e. when the Edit button is pressed.
626
627 \membersection{wxPropertyListValidator::OnRetrieveValue}
628
629 \func{Bool}{OnRetrieveValue}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
630 \param{wxWindow *}{parentWindow}}
631
632 Called when Tick (Confirm) is pressed or focus is lost or view wants to update
633 the property list. Should do the transfer from the property editing area to the property itself
634
635 \membersection{wxPropertyListValidator::OnSelect}
636
637 \func{Bool}{OnSelect}{\param{Bool}{ select}, \param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
638 \param{wxWindow *}{parentWindow}}
639
640 Called when the property is selected or deselected: typically displays the value
641 in the edit control (having chosen a suitable control to display: (non)editable text or listbox).
642
643 \membersection{wxPropertyListValidator::OnValueListSelect}
644
645 \func{Bool}{OnValueListSelect}{\param{wxProperty *}{property}, \param{wxPropertyListView *}{view},
646 \param{wxWindow *}{parentWindow}}
647
648 Called when the value listbox is selected. The default behaviour is to copy
649 string to text control, and retrieve the value into the property.
650
651
652
653 \section{\class{wxPropertyListView}: wxPropertyView}\label{wxpropertylistview}
654
655 \overview{wxPropertyListView overview}{wxpropertylistviewoverview}
656
657 The {\bf wxPropertyListView} class shows a wxPropertySheet as a Visual Basic-style property list.
658
659 \membersection{wxPropertyListView::wxPropertyListView}
660
661 \func{void}{wxPropertyListView}{\param{long}{ flags = wxPROP\_BUTTON\_DEFAULT}}
662
663 Constructor.
664
665 The {\it flags} argument can be a bit list of the following:
666
667 \begin{itemize}\itemsep=0pt
668 \item wxPROP\_BUTTON\_CLOSE
669 \item wxPROP\_BUTTON\_OK
670 \item wxPROP\_BUTTON\_CANCEL
671 \item wxPROP\_BUTTON\_CHECK\_CROSS
672 \item wxPROP\_BUTTON\_HELP
673 \item wxPROP\_DYNAMIC\_VALUE\_FIELD
674 \item wxPROP\_PULLDOWN
675 \end{itemize}
676
677 \membersection{wxPropertyListView::\destruct{wxPropertyListView}}
678
679 \func{void}{\destruct{wxPropertyListView}}{\void}
680
681 Destructor.
682
683 \membersection{wxPropertyListView::AssociatePanel}\label{wxpropertylistviewassociatepanel}
684
685 \func{void}{AssociatePanel}{\param{wxPanel *}{panel}}
686
687 Associates the window on which the controls will be displayed, with the view (sets an internal pointer to the window).
688
689 \membersection{wxPropertyListView::BeginShowingProperty}\label{wxpropertylistviewbeginshowingproperty}
690
691 \func{Bool}{BeginShowingProperty}{\param{wxProperty *}{property}}
692
693 Finds the appropriate validator and loads the property into the controls, by calling
694 wxPropertyValidator::OnPrepareControls and then wxPropertyListView::DisplayProperty.
695
696 \membersection{wxPropertyListView::DisplayProperty}\label{wxpropertylistviewdisplayproperty}
697
698 \func{Bool}{DisplayProperty}{\param{wxProperty *}{property}}
699
700 Calls wxPropertyValidator::OnDisplayValue for the current property's validator. This function
701 gets called by wxPropertyListView::BeginShowingProperty, which is in turn called
702 from ShowProperty, called by OnPropertySelect, called by the listbox callback when selected.
703
704 \membersection{wxPropertyListView::EndShowingProperty}\label{wxpropertylistviewendshowingproperty}
705
706 \func{Bool}{EndShowingProperty}{\param{wxProperty *}{property}}
707
708 Finds the appropriate validator and unloads the property from the controls, by calling
709 wxPropertyListView::RetrieveProperty, wxPropertyValidator::OnClearControls and (if we're in
710 detailed editing mdoe) wxPropertyValidator::OnClearDetailControls.
711
712 \membersection{wxPropertyListView::GetPanel}\label{wxpropertylistviewgetpanel}
713
714 \func{wxPanel *}{GetPanel}{\void}
715
716 Returns the panel associated with the view.
717
718 \membersection{wxPropertyListView::GetManagedWindow}\label{wxpropertylistviewgetmanagedwindow}
719
720 \func{wxWindow *}{GetManagedWindow}{\void}
721
722 Returns the managed window (a frame or dialog) associated with the view.
723
724 \membersection{wxPropertyListView::GetWindowCancelButton}\label{wxpropertylistviewgetwindowcancelbutton}
725
726 \func{wxButton *}{GetWindowCancelButton}{\void}
727
728 Returns the window cancel button, if any.
729
730 \membersection{wxPropertyListView::GetWindowCloseButton}\label{wxpropertylistviewgetwindowclosebutton}
731
732 \func{wxButton *}{GetWindowCloseButton}{\void}
733
734 Returns the window close or OK button, if any.
735
736 \membersection{wxPropertyListView::GetWindowHelpButton}\label{wxpropertylistviewgetwindowhelpbutton}
737
738 \func{wxButton *}{GetWindowHelpButton}{\void}
739
740 Returns the window help button, if any.
741
742 \membersection{wxPropertyListView::SetManagedWindow}\label{wxpropertylistviewsetmanagedwindow}
743
744 \func{void}{SetManagedWindow}{\param{wxWindow *}{win}}
745
746 Sets the managed window (a frame or dialog) associated with the view.
747
748 \membersection{wxPropertyListView::UpdatePropertyDisplayInList}\label{wxpropertylistviewupdatepropdisplay}
749
750 \func{Bool}{UpdatePropertyDisplayInList}{\param{wxProperty *}{property}}
751
752 Updates the display for the given changed property.
753
754 \membersection{wxPropertyListView::UpdatePropertyList}\label{wxpropertylistviewupdateproplist}
755
756 \func{Bool}{UpdatePropertyList}{\param{Bool }{clearEditArea = TRUE}}
757
758 Updates the whole property list display.
759
760
761 \section{\class{wxPropertySheet}: wxObject}\label{wxpropertysheet}
762
763 \overview{wxPropertySheet overview}{wxpropertysheetoverview}
764
765 The {\bf wxPropertySheet} class is used for storing a number of
766 wxProperty objects (essentially names and values).
767
768 \membersection{wxPropertySheet::wxPropertySheet}
769
770 \func{void}{wxPropertySheet}{\param{const wxString}{ name = ""}}
771
772 Constructor. Sets property sheet's name to name if present.
773
774 \membersection{wxPropertySheet::\destruct{wxPropertySheet}}
775
776 \func{void}{\destruct{wxPropertySheet}}{\void}
777
778 Destructor. Destroys all contained properties.
779
780 \membersection{wxPropertySheet::AddProperty}\label{wxpropertysheetaddproperty}
781
782 \func{void}{AddProperty}{\param{wxProperty *}{property}}
783
784 Adds a property to the sheet.
785
786 \membersection{wxPropertySheet::Clear}\label{wxpropertysheetclear}
787
788 \func{void}{Clear}{\void}
789
790 Clears all the properties from the sheet (deleting them).
791
792 \membersection{wxPropertySheet::GetName}\label{wxpropertysheetgetname}
793
794 \func{wxString}{GetName}{\void}
795
796 Gets the sheet's name.
797
798 \membersection{wxPropertySheet::GetProperty}\label{wxpropertysheetgetproperty}
799
800 \func{wxProperty *}{GetProperty}{\param{wxString}{ name}}
801
802 Gets a property by name.
803
804 \membersection{wxPropertySheet::GetProperties}\label{wxpropertysheetgetproperties}
805
806 \func{wxList\&}{GetProperties}{\void}
807
808 Returns a reference to the internal list of properties.
809
810 \membersection{wxPropertySheet::HasProperty}\label{wxpropertysheethasproperty}
811
812 \func{bool}{HasProperty}{\param{wxString}{ propname}}
813
814 Returns true if sheet contains property propname.
815
816 \membersection{wxPropertySheet::RemoveProperty}\label{wxpropertysheetremoveproperty}
817
818 \func{void}{RemoveProperty}{\param{wxString}{ propname}}
819
820 Removes property propname from sheet, deleting it.
821
822 \membersection{wxPropertySheet::SetName}\label{wxpropertysheetsetname}
823
824 \func{void}{SetName}{\param{wxString}{ sheetname}}
825
826 Set the sheet's name to sheetname
827
828 \membersection{wxPropertySheet::SetProperty}\label{wxpropertysheetsetproperty}
829
830 \func{bool}{SetProperty}{\param{wxString}{ propname}, \param{wxPropertyValue}{ value}}
831
832 Sets property propname to value. Returns false if property is not a member of sheet.
833
834 \membersection{wxPropertySheet::SetAllModified}
835
836 \func{void}{SetAllModified}{\param{Bool}{ flag}}
837
838 Sets the `modified' flag of each property value.
839
840
841
842 \section{\class{wxPropertyValidator}: wxEvtHandler}\label{wxpropertyvalidator}
843
844 \overview{wxPropertyValidator overview}{wxpropertyvalidatoroverview}
845
846 The {\bf wxPropertyValidator} abstract class is the base class for deriving
847 validators for properties.
848
849 \membersection{wxPropertyValidator::wxPropertyValidator}
850
851 \func{void}{wxPropertyValidator}{\param{long}{ flags = 0}}
852
853 Constructor.
854
855 \membersection{wxPropertyValidator::\destruct{wxPropertyValidator}}
856
857 \func{void}{\destruct{wxPropertyValidator}}{\void}
858
859 Destructor.
860
861 \membersection{wxPropertyValidator::GetFlags}
862
863 \func{long}{GetFlags}{\void}
864
865 Returns the flags for the validator.
866
867 \membersection{wxPropertyValidator::GetValidatorProperty}
868
869 \func{wxProperty *}{GetValidatorProperty}{\void}
870
871 Gets the property for the validator.
872
873 \membersection{wxPropertyValidator::SetValidatorProperty}
874
875 \func{void}{SetValidatorProperty}{\param{wxProperty *}{property}}
876
877 Sets the property for the validator.
878
879
880 \section{\class{wxPropertyValidatorRegistry}: wxHashTable}\label{wxpropertyvalidatorregistry}
881
882 The {\bf wxPropertyValidatorRegistry} class is used for storing validators,
883 indexed by the `role name' of the property, by which groups of property
884 can be identified for the purpose of validation and editing.
885
886 \membersection{wxPropertyValidatorRegistry::wxPropertyValidatorRegistry}
887
888 \func{void}{wxPropertyValidatorRegistry}{\void}
889
890 Constructor.
891
892 \membersection{wxPropertyValidatorRegistry::\destruct{wxPropertyValidatorRegistry}}
893
894 \func{void}{\destruct{wxPropertyValidatorRegistry}}{\void}
895
896 Destructor.
897
898 \membersection{wxPropertyValidatorRegistry::Clear}
899
900 \func{void}{ClearRegistry}{\void}
901
902 Clears the registry, deleting the validators.
903
904 \membersection{wxPropertyValidatorRegistry::GetValidator}
905
906 \func{wxPropertyValidator *}{GetValidator}{\param{wxString\& }{roleName}}
907
908 Retrieve a validator by the property role name.
909
910 \membersection{wxPropertyValidatorRegistry::RegisterValidator}\label{wxpropertyvalidatorregistervalidator}
911
912 \func{void}{RegisterValidator}{\param{wxString\& }{roleName}, \param{wxPropertyValidator *}{validator}}
913
914 Register a validator with the registry. {\it roleName} is a name indicating the
915 role of the property, such as ``filename''. Later, when a validator is chosen for
916 editing a property, this role name is matched against the class names of the property,
917 if the property does not already have a validator explicitly associated with it.
918
919
920 \section{\class{wxPropertyValue}: wxObject}\label{wxpropertyvalue}
921
922 The {\bf wxPropertyValue} class represents the value of a property,
923 and is normally associated with a wxProperty object.
924
925 A wxPropertyValue has one of the following types:
926
927 \begin{itemize}\itemsep=0pt
928 \item wxPropertyValueNull
929 \item wxPropertyValueInteger
930 \item wxPropertyValueReal
931 \item wxPropertyValueBool
932 \item wxPropertyValueString
933 \item wxPropertyValueList
934 \item wxPropertyValueIntegerPtr
935 \item wxPropertyValueRealPtr
936 \item wxPropertyValueBoolPtr
937 \item wxPropertyValueStringPtr
938 \end{itemize}
939
940 \membersection{wxPropertyValue::wxPropertyValue}
941
942 \func{void}{wxPropertyValue}{\void}
943
944 Default constructor.
945
946 \func{void}{wxPropertyValue}{\param{const wxPropertyValue\& }{copyFrom}}
947
948 Copy constructor.
949
950 \func{void}{wxPropertyValue}{\param{char *}{val}}
951
952 Construction from a string value.
953
954 \func{void}{wxPropertyValue}{\param{long}{ val}}
955
956 Construction from an integer value. You may need to cast to (long) to
957 avoid confusion with other constructors (such as the Bool constructor).
958
959 \func{void}{wxPropertyValue}{\param{Bool}{ val}}
960
961 Construction from a boolean value.
962
963 \func{void}{wxPropertyValue}{\param{float}{ val}}
964
965 Construction from a floating point value.
966
967 \func{void}{wxPropertyValue}{\param{double}{ val}}
968
969 Construction from a floating point value.
970
971 \func{void}{wxPropertyValue}{\param{wxList *}{ val}}
972
973 Construction from a list of wxPropertyValue objects. The
974 list, but not each contained wxPropertyValue, will be deleted
975 by the constructor. The wxPropertyValues will be assigned to
976 this wxPropertyValue list. In other words, so do not delete wxList or
977 its data after calling this constructor.
978
979 \func{void}{wxPropertyValue}{\param{wxStringList *}{ val}}
980
981 Construction from a list of strings. The list (including the strings
982 contained in it) will be deleted by the constructor, so do not
983 destroy {\it val} explicitly.
984
985 \func{void}{wxPropertyValue}{\param{char **}{val}}
986
987 Construction from a string pointer.
988
989 \func{void}{wxPropertyValue}{\param{long *}{val}}
990
991 Construction from an integer pointer.
992
993 \func{void}{wxPropertyValue}{\param{Bool *}{val}}
994
995 Construction from an boolean pointer.
996
997 \func{void}{wxPropertyValue}{\param{float *}{val}}
998
999 Construction from a floating point pointer.
1000
1001 The last four constructors use pointers to various C++ types, and do not
1002 store the types themselves; this allows the values to stand in for actual
1003 data values defined elsewhere.
1004
1005 \membersection{wxPropertyValue::\destruct{wxPropertyValue}}
1006
1007 \func{void}{\destruct{wxPropertyValue}}{\void}
1008
1009 Destructor.
1010
1011 \membersection{wxPropertyValue::Append}
1012
1013 \func{void}{Append}{\param{wxPropertyValue *}{expr}}
1014
1015 Appends a property value to the list.
1016
1017 \membersection{wxPropertyValue::BoolValue}
1018
1019 \func{Bool}{BoolValue}{\void}
1020
1021 Returns the boolean value.
1022
1023 \membersection{wxPropertyValue::BoolValuePtr}
1024
1025 \func{Bool *}{BoolValuePtr}{\void}
1026
1027 Returns the pointer to the boolean value.
1028
1029 \membersection{wxPropertyValue::ClearList}
1030
1031 \func{void}{ClearList}{\void}
1032
1033 Deletes the contents of the list.
1034
1035 \membersection{wxPropertyValue::Delete}
1036
1037 \func{void}{Delete}{\param{wxPropertyValue *}{expr}}
1038
1039 Deletes {\it expr} from this list.
1040
1041 \membersection{wxPropertyValue::GetFirst}
1042
1043 \func{wxPropertyValue *}{GetFirst}{\void}
1044
1045 Gets the first value in the list.
1046
1047 \membersection{wxPropertyValue::GetLast}
1048
1049 \func{wxPropertyValue *}{GetFirst}{\void}
1050
1051 Gets the last value in the list.
1052
1053 \membersection{wxPropertyValue::GetModified}
1054
1055 \func{Bool}{GetModified}{\void}
1056
1057 Returns TRUE if the value was modified since being created
1058 (or since SetModified was called).
1059
1060 \membersection{wxPropertyValue::GetNext}
1061
1062 \func{wxPropertyValue *}{GetNext}{\void}
1063
1064 Gets the next value in the list (the one after `this').
1065
1066 \membersection{wxPropertyValue::GetStringRepresentation}
1067
1068 \func{wxString}{GetStringRepresentation}{\void}
1069
1070 Gets a string representation of the value.
1071
1072 \membersection{wxPropertyValue::IntegerValue}
1073
1074 \func{long}{IntegerValue}{\void}
1075
1076 Returns the integer value.
1077
1078 \membersection{wxPropertyValue::Insert}
1079
1080 \func{void}{Insert}{\param{wxPropertyValue *}{expr}}
1081
1082 Inserts a property value at the front of a list.
1083
1084 \membersection{wxPropertyValue::IntegerValuePtr}
1085
1086 \func{long *}{IntegerValuePtr}{\void}
1087
1088 Returns the pointer to the integer value.
1089
1090 \membersection{wxPropertyValue::Nth}
1091
1092 \func{wxPropertyValue *}{Nth}{\param{int}{ n}}
1093
1094 Returns the nth value of a list expression (starting from zero).
1095
1096 \membersection{wxPropertyValue::Number}
1097
1098 \func{int}{Number}{\void}
1099
1100 Returns the number of elements in a list expression.
1101
1102 \membersection{wxPropertyValue::RealValue}
1103
1104 \func{float}{RealValue}{\void}
1105
1106 Returns the floating point value.
1107
1108 \membersection{wxPropertyValue::RealValuePtr}
1109
1110 \func{float *}{RealValuePtr}{\void}
1111
1112 Returns the pointer to the floating point value.
1113
1114 \membersection{wxPropertyValue::SetModified}
1115
1116 \func{void}{SetModified}{\param{Bool}{ flag}}
1117
1118 Sets the `modified' flag.
1119
1120 \membersection{wxPropertyValue::StringValue}
1121
1122 \func{char *}{StringValue}{\void}
1123
1124 Returns the string value.
1125
1126 \membersection{wxPropertyValue::StringValuePtr}
1127
1128 \func{char **}{StringValuePtr}{\void}
1129
1130 Returns the pointer to the string value.
1131
1132 \membersection{wxPropertyValue::Type}
1133
1134 \func{wxPropertyValueType}{Type}{\void}
1135
1136 Returns the value type.
1137
1138 \membersection{wxPropertyValue::operator $=$}
1139
1140 \func{void}{operator $=$}{\param{const wxPropertyValue\& }{val}}
1141
1142 \func{void}{operator $=$}{\param{const char *}{val}}
1143
1144 \func{void}{operator $=$}{\param{const long }{val}}
1145
1146 \func{void}{operator $=$}{\param{const Bool }{val}}
1147
1148 \func{void}{operator $=$}{\param{const float }{val}}
1149
1150 \func{void}{operator $=$}{\param{const char **}{val}}
1151
1152 \func{void}{operator $=$}{\param{const long *}{val}}
1153
1154 \func{void}{operator $=$}{\param{const Bool *}{val}}
1155
1156 \func{void}{operator $=$}{\param{const float *}{val}}
1157
1158 Assignment operators.
1159
1160
1161
1162 \section{\class{wxPropertyView}: wxEvtHandler}\label{wxpropertyview}
1163
1164 \overview{wxPropertyView overview}{wxpropertyviewoverview}
1165
1166 The {\bf wxPropertyView} abstract class is the base class for views
1167 of property sheets, acting as intermediaries between properties and
1168 actual windows.
1169
1170 \membersection{wxPropertyView::wxPropertyView}
1171
1172 \func{void}{wxPropertyView}{\param{long}{ flags = wxPROP\_BUTTON\_DEFAULT}}
1173
1174 Constructor.
1175
1176 The {\it flags} argument can be a bit list of the following:
1177
1178 \begin{itemize}\itemsep=0pt
1179 \item wxPROP\_BUTTON\_CLOSE
1180 \item wxPROP\_BUTTON\_OK
1181 \item wxPROP\_BUTTON\_CANCEL
1182 \item wxPROP\_BUTTON\_CHECK\_CROSS
1183 \item wxPROP\_BUTTON\_HELP
1184 \item wxPROP\_DYNAMIC\_VALUE\_FIELD
1185 \item wxPROP\_PULLDOWN
1186 \end{itemize}
1187
1188 \membersection{wxPropertyView::\destruct{wxPropertyView}}
1189
1190 \func{void}{\destruct{wxPropertyView}}{\void}
1191
1192 Destructor.
1193
1194 \membersection{wxPropertyView::AddRegistry}\label{wxpropertyviewaddregistry}
1195
1196 \func{void}{AddRegistry}{\param{wxPropertyValidatorRegistry *}{registry}}
1197
1198 Adds a registry (list of property validators) the view's list of registries, which is initially empty.
1199
1200 \membersection{wxPropertyView::FindPropertyValidator}\label{wxpropertyviewfindpropertyvalidator}
1201
1202 \func{wxPropertyValidator *}{FindPropertyValidator}{\param{wxProperty *}{property}}
1203
1204 Finds the property validator that is most appropriate to this property.
1205
1206 \membersection{wxPropertyView::GetPropertySheet}\label{wxpropertyviewgetpropertysheet}
1207
1208 \func{wxPropertySheet *}{GetPropertySheet}{\void}
1209
1210 Gets the property sheet for this view.
1211
1212 \membersection{wxPropertyView::GetRegistryList}\label{wxpropertyviewgetregistrylist}
1213
1214 \func{wxList\&}{GetRegistryList}{\void}
1215
1216 Returns a reference to the list of property validator registries.
1217
1218 \membersection{wxPropertyView::OnOk}\label{wxpropertyviewonok}
1219
1220 \func{void}{OnOk}{\void}
1221
1222 Virtual function that will be called when the OK button on the physical window is pressed (if it exists).
1223
1224 \membersection{wxPropertyView::OnCancel}\label{wxpropertyviewoncancel}
1225
1226 \func{void}{OnCancel}{\void}
1227
1228 Virtual function that will be called when the Cancel button on the physical window is pressed (if it exists).
1229
1230 \membersection{wxPropertyView::OnClose}\label{wxpropertyviewonclose}
1231
1232 \func{Bool}{OnClose}{\void}
1233
1234 Virtual function that will be called when the physical window is closed. The default implementation returns FALSE.
1235
1236 \membersection{wxPropertyView::OnHelp}\label{wxpropertyviewonhelp}
1237
1238 \func{void}{OnHelp}{\void}
1239
1240 Virtual function that will be called when the Help button on the physical window is pressed (if it exists).
1241
1242 \membersection{wxPropertyView::OnPropertyChanged}\label{wxpropertyviewonpropertychanged}
1243
1244 \func{void}{OnPropertyChanged}{\param{wxProperty *}{property}}
1245
1246 Virtual function called by a view or validator when a property's value changed. Validators
1247 must be written correctly for this to be called. You can override this function
1248 to respond immediately to property value changes.
1249
1250 \membersection{wxPropertyView::OnUpdateView}\label{wxpropertyviewonupdateview}
1251
1252 \func{Bool}{OnUpdateView}{\void}
1253
1254 Called by the viewed object to update the view. The default implementation just returns
1255 FALSE.
1256
1257 \membersection{wxPropertyView::SetPropertySheet}\label{wxpropertyviewsetpropertysheet}
1258
1259 \func{void}{SetPropertySheet}{\param{wxPropertySheet *}{sheet}}
1260
1261 Sets the property sheet for this view.
1262
1263 \membersection{wxPropertyView::ShowView}\label{wxpropertyviewshowview}
1264
1265 \func{void}{ShowView}{\param{wxPropertySheet *}{sheet}, \param{wxPanel *}{panel}}
1266
1267 Associates this view with the given panel, and shows the view.
1268
1269 \section{\class{wxRealFormValidator}: wxPropertyFormValidator}\label{wxrealformvalidator}
1270
1271 \overview{Validator classes}{validatorclasses}
1272
1273 This class validates a range of real values for form views. The associated panel item must be a wxText.
1274
1275 \membersection{wxRealFormValidator::wxRealFormValidator}
1276
1277 \func{void}{wxRealFormValidator}{\param{float }{min=0.0}, \param{float }{max=0.0},
1278 \param{long}{ flags=0}}
1279
1280 Constructor. Assigning zero to minimum and maximum values indicates that there is no range to check.
1281
1282
1283 \section{\class{wxStringFormValidator}: wxPropertyFormValidator}\label{wxstringformvalidator}
1284
1285 \overview{Validator classes}{validatorclasses}
1286
1287 This class validates a string value for a form view, with an optional choice of possible values.
1288 The associated panel item must be a wxText, wxListBox or wxChoice. For wxListBox and wxChoice items,
1289 if the item is empty, the validator attempts to initialize the item from the strings in
1290 the validator. Note that this does not happen for XView wxChoice items since XView cannot reinitialize a wxChoice.
1291
1292 \membersection{wxStringFormValidator::wxStringFormValidator}
1293
1294 \func{void}{wxStringFormValidator}{\param{wxStringList *}{list=NULL}, \param{long}{ flags=0}}
1295
1296 Constructor. Supply a list of strings to indicate a choice, or no strings to allow the
1297 user to freely edit the string. The string list will be deleted when the validator is deleted.
1298
1299
1300 \section{\class{wxRealListValidator}: wxPropertyListValidator}\label{wxreallistvalidator}
1301
1302 \overview{Validator classes}{validatorclasses}
1303
1304 This class validates a range of real values for property lists.
1305
1306 \membersection{wxRealListValidator::wxreallistvalidator}
1307
1308 \func{void}{wxRealListValidator}{\param{float }{min=0.0}, \param{float }{max=0.0},
1309 \param{long}{ flags=wxPROP\_ALLOW\_TEXT\_EDITING}}
1310
1311 Constructor. Assigning zero to minimum and maximum values indicates that there is no range to check.
1312
1313
1314 \section{\class{wxStringListValidator}: wxPropertyListValidator}\label{wxstringlistvalidator}
1315
1316 \overview{Validator classes}{validatorclasses}
1317
1318 This class validates a string value, with an optional choice of possible values.
1319
1320 \membersection{wxStringListValidator::wxStringListValidator}
1321
1322 \func{void}{wxStringListValidator}{\param{wxStringList *}{list=NULL}, \param{long}{ flags=0}}
1323
1324 Constructor. Supply a list of strings to indicate a choice, or no strings to allow the
1325 user to freely edit the string. The string list will be deleted when the validator is deleted.
1326
1327
1328 \chapter{Classes by category}\label{classesbycat}
1329
1330 A classification of property sheet classes by category.
1331
1332 \section{Data classes}
1333
1334 \begin{itemize}\itemsep=0pt
1335 \item \helpref{wxProperty}{wxproperty}
1336 \item \helpref{wxPropertyValue}{wxpropertyvalue}
1337 \item \helpref{wxPropertySheet}{wxpropertysheet}
1338 \end{itemize}
1339
1340
1341 \section{Validator classes}\label{validatorclasses}
1342
1343 Validators check that the values the user has entered for a property are
1344 valid. They can also define specific ways of entering data, such as a
1345 file selector for a filename, and they are responsible for transferring
1346 values between the wxProperty and the physical display.
1347
1348 Base classes:
1349
1350 \begin{itemize}\itemsep=0pt
1351 \item \helpref{wxPropertyValidator}{wxproperty}
1352 \item \helpref{wxPropertyListValidator}{wxpropertylistvalidator}
1353 \item \helpref{wxPropertyFormValidator}{wxpropertyformvalidator}
1354 \end{itemize}
1355
1356 List view validators:
1357
1358 \begin{itemize}\itemsep=0pt
1359 \item \helpref{wxBoolListValidator}{wxboollistvalidator}
1360 \item \helpref{wxFilenameListValidator}{wxfilenamelistvalidator}
1361 \item \helpref{wxIntegerListValidator}{wxintegerlistvalidator}
1362 \item \helpref{wxListOfStringsListValidator}{wxlistofstringslistvalidator}
1363 \item \helpref{wxRealListValidator}{wxreallistvalidator}
1364 \item \helpref{wxStringListValidator}{wxstringlistvalidator}
1365 \end{itemize}
1366
1367 Form view validators:
1368
1369 \begin{itemize}\itemsep=0pt
1370 \item \helpref{wxBoolFormValidator}{wxboolformvalidator}
1371 \item \helpref{wxIntegerFormValidator}{wxintegerformvalidator}
1372 \item \helpref{wxRealFormValidator}{wxrealformvalidator}
1373 \item \helpref{wxStringFormValidator}{wxstringformvalidator}
1374 \end{itemize}
1375
1376 \section{View classes}\label{viewclasses}
1377
1378 View classes mediate between a property sheet and a physical window.
1379
1380 \begin{itemize}\itemsep=0pt
1381 \item \helpref{wxPropertyView}{wxpropertyview}
1382 \item \helpref{wxPropertyListView}{wxpropertylistview}
1383 \item \helpref{wxPropertyFormView}{wxpropertyformview}
1384 \end{itemize}
1385
1386 \section{Window classes}\label{windowclasses}
1387
1388 The class library defines some window classes that can be used as-is with a suitable
1389 view class and property sheet.
1390
1391 \begin{itemize}\itemsep=0pt
1392 \item \helpref{wxPropertyFormFrame}{wxpropertyformframe}
1393 \item \helpref{wxPropertyFormDialog}{wxpropertyformdialog}
1394 \item \helpref{wxPropertyFormPanel}{wxpropertyformpanel}
1395 \item \helpref{wxPropertyListFrame}{wxpropertylistframe}
1396 \item \helpref{wxPropertyListDialog}{wxpropertylistdialog}
1397 \item \helpref{wxPropertyListPanel}{wxpropertylistpanel}
1398 \end{itemize}
1399
1400 \section{Registry classes}
1401
1402 A validator registry is a list of validators that can be applied to properties in a property sheet.
1403 There may be one or more registries per property view.
1404
1405 \begin{itemize}\itemsep=0pt
1406 \item \helpref{wxPropertyValidatorRegistry}{wxpropertyvalidatorregistry}
1407 \end{itemize}
1408
1409
1410 \chapter{Topic overviews}\label{overviews}
1411
1412 This chapter contains a selection of topic overviews.
1413
1414 \section{Property classes overview}\label{propertyoverview}
1415
1416 The property classes help a programmer to express relationships between
1417 data and physical windows, in particular:
1418
1419 \begin{itemize}\itemsep=0pt
1420 \item the transfer of data to and from the physical controls;
1421 \item the behaviour of various controls and custom windows for particular
1422 types of data;
1423 \item the validation of data, notifying the user when incorrect data is entered,
1424 or even better, constraining the input so only valid data can be entered.
1425 \end{itemize}
1426
1427 With a consistent framework, the programmer should be able to use existing
1428 components and design new ones in a principled manner, to solve many data entry
1429 requirements.
1430
1431 Each datum is represented in a \helpref{wxProperty}{wxproperty}, which has a name and a value.
1432 Various C++ types are permitted in the value of a property, and the property can store a pointer
1433 to the data instead of a copy of the data. A \helpref{wxPropertySheet}{wxpropertysheet} represents a number of these properties.
1434
1435 These two classes are independent from the way in which the data is visually manipulated. To
1436 mediate between property sheets and windows, the abstract class \helpref{wxPropertyView}{wxpropertyview} is
1437 available for programmers to derive new kinds of view. One kind of view that is available is the \helpref{wxPropertyListView}{wxpropertylistview},
1438 which displays the data in a Visual Basic-style list, with a small number of controls for editing
1439 the currently selected property. Another is \helpref{wxPropertyFormView}{wxpropertyformview} which
1440 mediates between an existing dialog or panel and the property sheet.
1441
1442 The hard work of mediation is actually performed by validators, which are instances of classes
1443 derived from \helpref{wxPropertyValidator}{wxpropertyvalidator}. A validator is associated with
1444 a particular property and is responsible for
1445 responding to user interface events, and displaying, updating and checking the property value.
1446 Because a validator's behaviour depends largely on the kind of view being used, there has to be
1447 a separate hierarchy of validators for each class of view. So for wxPropertyListView, there is
1448 an abstract class \helpref{wxPropertyListValidator}{wxpropertylistvalidator} from which concrete
1449 classes are derived, such as \helpref{wxRealListValidator}{wxreallistvalidator} and
1450 \rtfsp\helpref{wxStringListValidator}{wxstringlistvalidator}.
1451
1452 A validator can be explicitly set for a property, so there is no doubt which validator
1453 should be used to edit that property. However, it is also possible to define a registry
1454 of validators, and have the validator chosen on the basis of the {\it role} of the property.
1455 So a property with a ``filename" role would match the ``filename" validator, which pops
1456 up a file selector when the user double clicks on the property.
1457
1458 You don't have to define your own frame or window classes: there are some predefined
1459 that will work with the property list view. See \helpref{Window classes}{windowclasses} for
1460 further details.
1461
1462 \subsection{Example 1: Property list view}
1463
1464 The following code fragment shows the essentials of creating a registry of
1465 standard validators, a property sheet containing some properties, and
1466 a property list view and dialog or frame. RegisterValidators will be
1467 called on program start, and PropertySheetTest is called in response to a
1468 menu command.
1469
1470 Note how some properties are created with an explicit reference to
1471 a validator, and others are provided with a ``role'' which can be matched
1472 against a validator in the registry.
1473
1474 The interface generated by this test program is shown in the section \helpref{Appearance and
1475 behaviour of a property list view}{appearance}.
1476
1477 \begin{verbatim}
1478 void RegisterValidators(void)
1479 {
1480 myListValidatorRegistry.RegisterValidator((wxString)"real", new wxRealListValidator);
1481 myListValidatorRegistry.RegisterValidator((wxString)"string", new wxStringListValidator);
1482 myListValidatorRegistry.RegisterValidator((wxString)"integer", new wxIntegerListValidator);
1483 myListValidatorRegistry.RegisterValidator((wxString)"bool", new wxBoolListValidator);
1484 }
1485
1486 void PropertyListTest(Bool useDialog)
1487 {
1488 wxPropertySheet *sheet = new wxPropertySheet;
1489
1490 sheet->AddProperty(new wxProperty("fred", 1.0, "real"));
1491 sheet->AddProperty(new wxProperty("tough choice", (Bool)TRUE, "bool"));
1492 sheet->AddProperty(new wxProperty("ian", (long)45, "integer", new wxIntegerListValidator(-50, 50)));
1493 sheet->AddProperty(new wxProperty("bill", 25.0, "real", new wxRealListValidator(0.0, 100.0)));
1494 sheet->AddProperty(new wxProperty("julian", "one", "string"));
1495 sheet->AddProperty(new wxProperty("bitmap", "none", "string", new wxFilenameListValidator("Select a bitmap file", "*.bmp")));
1496 wxStringList *strings = new wxStringList("one", "two", "three", NULL);
1497 sheet->AddProperty(new wxProperty("constrained", "one", "string", new wxStringListValidator(strings)));
1498
1499 wxPropertyListView *view =
1500 new wxPropertyListView(NULL,
1501 wxPROP_BUTTON_CHECK_CROSS|wxPROP_DYNAMIC_VALUE_FIELD|wxPROP_PULLDOWN);
1502
1503 wxDialogBox *propDialog = NULL;
1504 wxPropertyListFrame *propFrame = NULL;
1505 if (useDialog)
1506 {
1507 propDialog = new wxPropertyListDialog(view, NULL, "Property Sheet Test", TRUE, -1, -1, 400, 500);
1508 }
1509 else
1510 {
1511 propFrame = new wxPropertyListFrame(view, NULL, "Property Sheet Test", -1, -1, 400, 500);
1512 }
1513
1514 view->AddRegistry(&myListValidatorRegistry);
1515
1516 if (useDialog)
1517 {
1518 view->ShowView(sheet, propDialog);
1519 propDialog->Centre(wxBOTH);
1520 propDialog->Show(TRUE);
1521 }
1522 else
1523 {
1524 propFrame->Initialize();
1525 view->ShowView(sheet, propFrame->GetPropertyPanel());
1526 propFrame->Centre(wxBOTH);
1527 propFrame->Show(TRUE);
1528 }
1529 }
1530 \end{verbatim}
1531
1532 \subsection{Example 2: Property form view}
1533
1534 This example is similar to Example 1, but uses a property form view to
1535 edit a property sheet using a predefined dialog box.
1536
1537 \begin{verbatim}
1538 void RegisterValidators(void)
1539 {
1540 myFormValidatorRegistry.RegisterValidator((wxString)"real", new wxRealFormValidator);
1541 myFormValidatorRegistry.RegisterValidator((wxString)"string", new wxStringFormValidator);
1542 myFormValidatorRegistry.RegisterValidator((wxString)"integer", new wxIntegerFormValidator);
1543 myFormValidatorRegistry.RegisterValidator((wxString)"bool", new wxBoolFormValidator);
1544 }
1545
1546 void PropertyFormTest(Bool useDialog)
1547 {
1548 wxPropertySheet *sheet = new wxPropertySheet;
1549
1550 sheet->AddProperty(new wxProperty("fred", 25.0, "real", new wxRealFormValidator(0.0, 100.0)));
1551 sheet->AddProperty(new wxProperty("tough choice", (Bool)TRUE, "bool"));
1552 sheet->AddProperty(new wxProperty("ian", (long)45, "integer", new wxIntegerFormValidator(-50, 50)));
1553 sheet->AddProperty(new wxProperty("julian", "one", "string"));
1554 wxStringList *strings = new wxStringList("one", "two", "three", NULL);
1555 sheet->AddProperty(new wxProperty("constrained", "one", "string", new wxStringFormValidator(strings)));
1556
1557 wxPropertyFormView *view = new wxPropertyFormView(NULL);
1558
1559 wxDialogBox *propDialog = NULL;
1560 wxPropertyFormFrame *propFrame = NULL;
1561 if (useDialog)
1562 {
1563 propDialog = new wxPropertyFormDialog(view, NULL, "Property Form Test", TRUE, -1, -1, 400, 300);
1564 }
1565 else
1566 {
1567 propFrame = new wxPropertyFormFrame(view, NULL, "Property Form Test", -1, -1, 400, 300);
1568 propFrame->Initialize();
1569 }
1570
1571 wxPanel *panel = propDialog ? propDialog : propFrame->GetPropertyPanel();
1572 panel->SetLabelPosition(wxVERTICAL);
1573
1574 // Add items to the panel
1575
1576 (void) new wxButton(panel, (wxFunction)NULL, "OK", -1, -1, -1, -1, 0, "ok");
1577 (void) new wxButton(panel, (wxFunction)NULL, "Cancel", -1, -1, 80, -1, 0, "cancel");
1578 (void) new wxButton(panel, (wxFunction)NULL, "Update", -1, -1, 80, -1, 0, "update");
1579 (void) new wxButton(panel, (wxFunction)NULL, "Revert", -1, -1, -1, -1, 0, "revert");
1580 panel->NewLine();
1581
1582 // The name of this text item matches the "fred" property
1583 (void) new wxText(panel, (wxFunction)NULL, "Fred", "", -1, -1, 90, -1, 0, "fred");
1584 (void) new wxCheckBox(panel, (wxFunction)NULL, "Yes or no", -1, -1, -1, -1, 0, "tough choice");
1585 (void) new wxSlider(panel, (wxFunction)NULL, "Sliding scale", 0, -50, 50, 100, -1, -1, wxHORIZONTAL, "ian");
1586 panel->NewLine();
1587 (void) new wxListBox(panel, (wxFunction)NULL, "Constrained", wxSINGLE, -1, -1, 100, 90, 0, NULL, 0, "constrained");
1588
1589 view->AddRegistry(&myFormValidatorRegistry);
1590
1591 if (useDialog)
1592 {
1593 view->ShowView(sheet, propDialog);
1594 view->AssociateNames();
1595 view->TransferToDialog();
1596 propDialog->Centre(wxBOTH);
1597 propDialog->Show(TRUE);
1598 }
1599 else
1600 {
1601 view->ShowView(sheet, propFrame->GetPropertyPanel());
1602 view->AssociateNames();
1603 view->TransferToDialog();
1604 propFrame->Centre(wxBOTH);
1605 propFrame->Show(TRUE);
1606 }
1607 }
1608 \end{verbatim}
1609
1610 \section{Validator classes overview}\label{validatoroverview}
1611
1612 Classes: \helpref{Validator classes}{validatorclasses}
1613
1614 The validator classes provide functionality for mediating between a wxProperty and
1615 the actual display. There is a separate family of validator classes for each
1616 class of view, since the differences in user interface for these views implies
1617 that little common functionality can be shared amongst validators.
1618
1619 \subsection{wxPropertyValidator overview}\label{wxpropertyvalidatoroverview}
1620
1621 Class: \helpref{wxPropertyValidator}{wxpropertyvalidator}
1622
1623 This class is the root of all property validator classes. It contains a small
1624 amount of common functionality, including functions to convert between
1625 strings and C++ values.
1626
1627 A validator is notionally an object which sits between a property and its displayed
1628 value, and checks that the value the user enters is correct, giving an error message
1629 if the validation fails. In fact, the validator does more than that, and is akin to
1630 a view class but at a finer level of detail. It is also responsible for
1631 loading the dialog box control with the value from the property, putting it back
1632 into the property, preparing special controls for editing the value, and
1633 may even invoke special dialogs for editing the value in a convenient way.
1634
1635 In a property list dialog, there is quite a lot of scope for supplying custom dialogs,
1636 such as file or colour selectors. For a form dialog, there is less scope because
1637 there is no concept of `detailed editing' of a value: one control is associated with
1638 one property, and there is no provision for invoking further dialogs. The reader
1639 may like to work out how the form view could be extended to provide some of the
1640 functionality of the property list!
1641
1642 Validator objects may be associated explictly with a wxProperty, or they may be
1643 indirectly associated by virtue of a property `kind' that matches validators having
1644 that kind. In the latter case, such validators are stored in a validator registry
1645 which is passed to the view before the dialog is shown. If the validator takes
1646 arguments, such as minimum and maximum values in the case of a wxIntegerListValidator,
1647 then the validator must be associated explicitly with the property. The validator
1648 will be deleted when the property is deleted.
1649
1650 \subsection{wxPropertyListValidator overview}\label{wxpropertylistvalidatoroverview}
1651
1652 Class: \helpref{wxPropertyListValidator}{wxpropertylistvalidator}
1653
1654 This class is the abstract base class for property list view validators.
1655 The list view acts upon a user interface containing a list of properties,
1656 a text item for direct property value editing, confirm/cancel buttons for the value,
1657 a pulldown list for making a choice between values, and OK/Cancel/Help buttons
1658 for the dialog (see \helpref{property list appearance}{appearance}).
1659
1660 By overriding virtual functions, the programmer can create custom
1661 behaviour for different kinds of property. Custom behaviour can use just the
1662 available controls on the property list dialog, or the validator can
1663 invoke custom editors with quite different controls, which pop up in
1664 `detailed editing' mode.
1665
1666 See the detailed class documentation for the members you should override
1667 to give your validator appropriate behaviour.
1668
1669 \subsection{wxPropertyFormValidator overview}\label{wxpropertyformvalidatoroverview}
1670
1671 This class is the abstract base class for property form view validators.
1672 The form view acts upon an existing dialog box or panel, where either the
1673 panel item names correspond to property names, or the programmer has explicitly
1674 associated the panel item with the property.
1675
1676 By overriding virtual functions, the programmer determines how
1677 values are displayed or retrieved, and the checking that the validator does.
1678
1679 See the detailed class documentation for the members you should override
1680 to give your validator appropriate behaviour.
1681
1682 \section{View classes overview}\label{viewoverview}
1683
1684 Classes: \helpref{View classes}{viewclasses}
1685
1686 An instance of a view class relates a property sheet with an actual window.
1687 Currently, there are two classes of view: wxPropertyListView and wxPropertyFormView.
1688
1689 \subsection{wxPropertyView overview}\label{wxpropertyviewoverview}
1690
1691 Class: \helpref{wxPropertyView}{wxpropertyview}
1692
1693 This is the abstract base class for property views.
1694
1695 \subsection{wxPropertyListView overview}\label{wxpropertylistviewoverview}
1696
1697 Class: \helpref{wxPropertyListView}{wxpropertylistview}
1698
1699 The property list view defines the relationship between a property sheet and
1700 a property list dialog or panel. It manages user interface events such as
1701 clicking on a property, pressing return in the text edit field, and clicking
1702 on Confirm or Cancel. These events cause member functions of the
1703 class to be called, and these in turn may call member functions of
1704 the appropriate validator to be called, to prepare controls, check the property value,
1705 invoke detailed editing, etc.
1706
1707 \subsection{wxPropertyFormView overview}\label{wxpropertyformviewoverview}
1708
1709 Class: \helpref{wxPropertyFormView}{wxpropertyformview}
1710
1711 The property form view manages the relationship between a property sheet
1712 and an existing dialog or panel.
1713
1714 You must first create a panel or dialog box for the view to work on.
1715 The panel should contain panel items with names that correspond to
1716 properties in your property sheet; or you can explicitly set the
1717 panel item for each property.
1718
1719 Apart from any custom panel items that you wish to control independently
1720 of the property-editing items, wxPropertyFormView takes over the
1721 processing of item events. It can also control normal dialog behaviour such
1722 as OK, Cancel, so you should also create some standard buttons that the property view
1723 can recognise. Just create the buttons with standard names and the view
1724 will do the rest. The following button names are recognised:
1725
1726 \begin{itemize}\itemsep=0pt
1727 \item {\bf ok}: indicates the OK button. Calls wxPropertyFormView::OnOk. By default,
1728 checks and updates the form values, closes and deletes the frame or dialog, then deletes the view.
1729 \item {\bf cancel}: indicates the Cancel button. Calls wxPropertyFormView::OnCancel. By default,
1730 closes and deletes the frame or dialog, then deletes the view.
1731 \item {\bf help}: indicates the Help button. Calls wxPropertyFormView::OnHelp. This needs
1732 to be overridden by the application for anything interesting to happen.
1733 \item {\bf revert}: indicates the Revert button. Calls wxPropertyFormView::OnRevert,
1734 which by default transfers the wxProperty values to the panel items (in effect
1735 undoing any unsaved changes in the items).
1736 \item {\bf update}: indicates the Revert button. Calls wxPropertyFormView::OnUpdate, which
1737 by defaults transfers the displayed values to the wxProperty objects.
1738 \end{itemize}
1739
1740 \section{wxPropertySheet overview}\label{wxpropertysheetoverview}
1741
1742 Classes: \helpref{wxPropertySheet}{wxpropertysheet}, \helpref{wxProperty}{wxproperty}, \helpref{wxPropertyValue}{wxpropertyvalue}
1743
1744 A property sheet defines zero or more properties. This is a bit like an explicit representation of
1745 a C++ object. wxProperty objects can have values which are pointers to C++ values, or they
1746 can allocate their own storage for values.
1747
1748 Because the property sheet representation is explicit and can be manipulated by
1749 a program, it is a convenient form to be used for a variety of
1750 editing purposes. wxPropertyListView and wxPropertyFormView are two classes that
1751 specify the relationship between a property sheet and a user interface. You could imagine
1752 other uses for wxPropertySheet, for example to generate a form-like user interface without
1753 the need for GUI programming. Or for storing the names and values of command-line switches, with the
1754 option to subsequently edit these values using a wxPropertyListView.
1755
1756 A typical use for a property sheet is to represent values of an object
1757 which are only implicit in the current representation of it. For
1758 example, in Visual Basic and similar programming environments, you can
1759 `edit a button', or rather, edit the button's properties. One of the
1760 properties you can edit is {\it width} - but there is no explicit
1761 representation of width in a wxWindows button; instead, you call SetSize
1762 and GetSize members. To translate this into a consisent,
1763 property-oriented scheme, we could derive a new class
1764 wxButtonWithProperties, which has two new functions: SetProperty and
1765 GetProperty. SetProperty accepts a property name and a value, and calls
1766 an appropriate function for the property that is being passed.
1767 GetProperty accepts a property name, returning a property value. So
1768 instead of having to use the usual arbitrary set of C++ member functions
1769 to set or access attributes of a window, programmer deals merely with
1770 SetValue/GetValue, and property names and values.
1771 We now have a single point at which we can modify or query an object by specifying
1772 names and values at run-time. (The implementation of SetProperty and GetProperty
1773 is probably quite messy and involves a large if-then-else statement to
1774 test the property name and act accordingly.)
1775
1776 When the user invokes the property editor for a wxButtonWithProperties, the system
1777 creates a wxPropertySheet with `imaginary' properties such as width, height, font size
1778 and so on. For each property, wxButtonWithProperties::GetProperty is called, and the result is
1779 passed to the corresponding wxProperty. The wxPropertySheet is passed to a wxPropertyListView
1780 as described elsewhere, and the user edits away. When the user has finished editing, the system calls
1781 wxButtonWithProperties::SetProperty to transfer the wxProperty value back into the button
1782 by way of an appropriate call, wxWindow::SetSize in the case of width and height properties.
1783
1784
1785