]> git.saurik.com Git - wxWidgets.git/blob - include/wx/propgrid/advprops.h
Make it easier to define custom wxSizerXmlHandler subclasses.
[wxWidgets.git] / include / wx / propgrid / advprops.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/propgrid/advprops.h
3 // Purpose: wxPropertyGrid Advanced Properties (font, colour, etc.)
4 // Author: Jaakko Salli
5 // Modified by:
6 // Created: 2004-09-25
7 // RCS-ID: $Id$
8 // Copyright: (c) Jaakko Salli
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
11
12 #ifndef _WX_PROPGRID_ADVPROPS_H_
13 #define _WX_PROPGRID_ADVPROPS_H_
14
15 #include "wx/defs.h"
16
17 #if wxUSE_PROPGRID
18
19 #include "wx/propgrid/props.h"
20
21 // -----------------------------------------------------------------------
22
23 //
24 // Additional Value Type Handlers
25 //
26 bool WXDLLIMPEXP_PROPGRID
27 operator==(const wxArrayInt& array1, const wxArrayInt& array2);
28
29 //
30 // Additional Property Editors
31 //
32 #if wxUSE_SPINBTN
33 WX_PG_DECLARE_EDITOR_WITH_DECL(SpinCtrl,WXDLLIMPEXP_PROPGRID)
34 #endif
35
36 #if wxUSE_DATEPICKCTRL
37 WX_PG_DECLARE_EDITOR_WITH_DECL(DatePickerCtrl,WXDLLIMPEXP_PROPGRID)
38 #endif
39
40 // -----------------------------------------------------------------------
41
42
43 // Web colour is currently unsupported
44 #define wxPG_COLOUR_WEB_BASE 0x10000
45 //#define wxPG_TO_WEB_COLOUR(A) ((wxUint32)(A+wxPG_COLOUR_WEB_BASE))
46
47
48 #define wxPG_COLOUR_CUSTOM 0xFFFFFF
49 #define wxPG_COLOUR_UNSPECIFIED (wxPG_COLOUR_CUSTOM+1)
50
51 /** @class wxColourPropertyValue
52
53 Because text, background and other colours tend to differ between
54 platforms, wxSystemColourProperty must be able to select between system
55 colour and, when necessary, to pick a custom one. wxSystemColourProperty
56 value makes this possible.
57 */
58 class WXDLLIMPEXP_PROPGRID wxColourPropertyValue : public wxObject
59 {
60 public:
61 /** An integer value relating to the colour, and which exact
62 meaning depends on the property with which it is used.
63
64 For wxSystemColourProperty:
65
66 Any of wxSYS_COLOUR_XXX, or any web-colour ( use wxPG_TO_WEB_COLOUR
67 macro - (currently unsupported) ), or wxPG_COLOUR_CUSTOM.
68
69 For custom colour properties without values array specified:
70
71 index or wxPG_COLOUR_CUSTOM
72
73 For custom colour properties <b>with</b> values array specified:
74
75 m_arrValues[index] or wxPG_COLOUR_CUSTOM
76 */
77 wxUint32 m_type;
78
79 /** Resulting colour. Should be correct regardless of type. */
80 wxColour m_colour;
81
82 wxColourPropertyValue()
83 : wxObject()
84 {
85 m_type = 0;
86 }
87
88 virtual ~wxColourPropertyValue()
89 {
90 }
91
92 wxColourPropertyValue( const wxColourPropertyValue& v )
93 : wxObject()
94 {
95 m_type = v.m_type;
96 m_colour = v.m_colour;
97 }
98
99 void Init( wxUint32 type, const wxColour& colour )
100 {
101 m_type = type;
102 m_colour = colour;
103 }
104
105 wxColourPropertyValue( const wxColour& colour )
106 : wxObject()
107 {
108 m_type = wxPG_COLOUR_CUSTOM;
109 m_colour = colour;
110 }
111
112 wxColourPropertyValue( wxUint32 type )
113 : wxObject()
114 {
115 m_type = type;
116 }
117
118 wxColourPropertyValue( wxUint32 type, const wxColour& colour )
119 : wxObject()
120 {
121 Init( type, colour );
122 }
123
124 void operator=(const wxColourPropertyValue& cpv)
125 {
126 if (this != &cpv)
127 Init( cpv.m_type, cpv.m_colour );
128 }
129
130 private:
131 DECLARE_DYNAMIC_CLASS(wxColourPropertyValue)
132 };
133
134
135 bool WXDLLIMPEXP_PROPGRID
136 operator==(const wxColourPropertyValue&, const wxColourPropertyValue&);
137
138 DECLARE_VARIANT_OBJECT_EXPORTED(wxColourPropertyValue, WXDLLIMPEXP_PROPGRID)
139
140 // -----------------------------------------------------------------------
141 // Declare part of custom colour property macro pairs.
142
143 #if wxUSE_IMAGE
144 #include "wx/image.h"
145 #endif
146
147 // -----------------------------------------------------------------------
148
149 /** @class wxFontProperty
150 @ingroup classes
151 Property representing wxFont.
152 */
153 class WXDLLIMPEXP_PROPGRID wxFontProperty : public wxPGProperty
154 {
155 WX_PG_DECLARE_PROPERTY_CLASS(wxFontProperty)
156 public:
157
158 wxFontProperty(const wxString& label = wxPG_LABEL,
159 const wxString& name = wxPG_LABEL,
160 const wxFont& value = wxFont());
161 virtual ~wxFontProperty();
162 virtual void OnSetValue();
163 virtual wxString ValueToString( wxVariant& value, int argFlags = 0 ) const;
164 virtual bool OnEvent( wxPropertyGrid* propgrid,
165 wxWindow* primary, wxEvent& event );
166 virtual wxVariant ChildChanged( wxVariant& thisValue,
167 int childIndex,
168 wxVariant& childValue ) const;
169 virtual void RefreshChildren();
170
171 protected:
172 };
173
174 // -----------------------------------------------------------------------
175
176
177 /** If set, then match from list is searched for a custom colour. */
178 #define wxPG_PROP_TRANSLATE_CUSTOM wxPG_PROP_CLASS_SPECIFIC_1
179
180
181 /** @class wxSystemColourProperty
182 @ingroup classes
183 Has dropdown list of wxWidgets system colours. Value used is
184 of wxColourPropertyValue type.
185 */
186 class WXDLLIMPEXP_PROPGRID wxSystemColourProperty : public wxEnumProperty
187 {
188 WX_PG_DECLARE_PROPERTY_CLASS(wxSystemColourProperty)
189 public:
190
191 wxSystemColourProperty( const wxString& label = wxPG_LABEL,
192 const wxString& name = wxPG_LABEL,
193 const wxColourPropertyValue&
194 value = wxColourPropertyValue() );
195 virtual ~wxSystemColourProperty();
196
197 virtual void OnSetValue();
198 virtual bool IntToValue(wxVariant& variant,
199 int number,
200 int argFlags = 0) const;
201
202 /**
203 Override in derived class to customize how colours are printed as
204 strings.
205 */
206 virtual wxString ColourToString( const wxColour& col, int index ) const;
207
208 /** Returns index of entry that triggers colour picker dialog
209 (default is last).
210 */
211 virtual int GetCustomColourIndex() const;
212
213 virtual wxString ValueToString( wxVariant& value, int argFlags = 0 ) const;
214 virtual bool StringToValue( wxVariant& variant,
215 const wxString& text,
216 int argFlags = 0 ) const;
217 virtual bool OnEvent( wxPropertyGrid* propgrid,
218 wxWindow* primary, wxEvent& event );
219 virtual bool DoSetAttribute( const wxString& name, wxVariant& value );
220 virtual wxSize OnMeasureImage( int item ) const;
221 virtual void OnCustomPaint( wxDC& dc,
222 const wxRect& rect, wxPGPaintData& paintdata );
223
224 // Helper function to show the colour dialog
225 bool QueryColourFromUser( wxVariant& variant ) const;
226
227 /** Default is to use wxSystemSettings::GetColour(index). Override to use
228 custom colour tables etc.
229 */
230 virtual wxColour GetColour( int index ) const;
231
232 wxColourPropertyValue GetVal( const wxVariant* pVariant = NULL ) const;
233
234 protected:
235
236 // Special constructors to be used by derived classes.
237 wxSystemColourProperty( const wxString& label, const wxString& name,
238 const wxChar* const* labels, const long* values, wxPGChoices* choicesCache,
239 const wxColourPropertyValue& value );
240 wxSystemColourProperty( const wxString& label, const wxString& name,
241 const wxChar* const* labels, const long* values, wxPGChoices* choicesCache,
242 const wxColour& value );
243
244 void Init( int type, const wxColour& colour );
245
246 // Utility functions for internal use
247 virtual wxVariant DoTranslateVal( wxColourPropertyValue& v ) const;
248 wxVariant TranslateVal( wxColourPropertyValue& v ) const
249 {
250 return DoTranslateVal( v );
251 }
252 wxVariant TranslateVal( int type, const wxColour& colour ) const
253 {
254 wxColourPropertyValue v(type, colour);
255 return DoTranslateVal( v );
256 }
257
258 // Translates colour to a int value, return wxNOT_FOUND if no match.
259 int ColToInd( const wxColour& colour ) const;
260 };
261
262 // -----------------------------------------------------------------------
263
264 class WXDLLIMPEXP_PROPGRID wxColourProperty : public wxSystemColourProperty
265 {
266 WX_PG_DECLARE_PROPERTY_CLASS(wxColourProperty)
267 public:
268 wxColourProperty( const wxString& label = wxPG_LABEL,
269 const wxString& name = wxPG_LABEL,
270 const wxColour& value = *wxWHITE );
271 virtual ~wxColourProperty();
272
273 virtual wxString ValueToString( wxVariant& value, int argFlags = 0 ) const;
274 virtual wxColour GetColour( int index ) const;
275
276 protected:
277 virtual wxVariant DoTranslateVal( wxColourPropertyValue& v ) const;
278
279 private:
280 void Init( wxColour colour );
281 };
282
283 // -----------------------------------------------------------------------
284
285 /** @class wxCursorProperty
286 @ingroup classes
287 Property representing wxCursor.
288 */
289 class WXDLLIMPEXP_PROPGRID wxCursorProperty : public wxEnumProperty
290 {
291 DECLARE_DYNAMIC_CLASS(wxCursorProperty)
292
293 wxCursorProperty( const wxString& label= wxPG_LABEL,
294 const wxString& name= wxPG_LABEL,
295 int value = 0 );
296 virtual ~wxCursorProperty();
297
298 virtual wxSize OnMeasureImage( int item ) const;
299 virtual void OnCustomPaint( wxDC& dc,
300 const wxRect& rect, wxPGPaintData& paintdata );
301 };
302
303 // -----------------------------------------------------------------------
304
305 #if wxUSE_IMAGE
306
307 WXDLLIMPEXP_PROPGRID const wxString& wxPGGetDefaultImageWildcard();
308
309 /** @class wxImageFileProperty
310 @ingroup classes
311 Property representing image file(name).
312 */
313 class WXDLLIMPEXP_PROPGRID wxImageFileProperty : public wxFileProperty
314 {
315 DECLARE_DYNAMIC_CLASS(wxImageFileProperty)
316 public:
317
318 wxImageFileProperty( const wxString& label= wxPG_LABEL,
319 const wxString& name = wxPG_LABEL,
320 const wxString& value = wxEmptyString);
321 virtual ~wxImageFileProperty();
322
323 virtual void OnSetValue();
324
325 virtual wxSize OnMeasureImage( int item ) const;
326 virtual void OnCustomPaint( wxDC& dc,
327 const wxRect& rect, wxPGPaintData& paintdata );
328
329 protected:
330 wxBitmap* m_pBitmap; // final thumbnail area
331 wxImage* m_pImage; // intermediate thumbnail area
332 };
333
334 #endif
335
336 #if wxUSE_CHOICEDLG
337
338 /** @class wxMultiChoiceProperty
339 @ingroup classes
340 Property that manages a value resulting from wxMultiChoiceDialog. Value is
341 array of strings. You can get value as array of choice values/indices by
342 calling wxMultiChoiceProperty::GetValueAsArrayInt().
343
344 <b>Supported special attributes:</b>
345 - "UserStringMode": If > 0, allow user to manually enter strings that are
346 not in the list of choices. If this value is 1, user strings are
347 preferably placed in front of valid choices. If value is 2, then those
348 strings will placed behind valid choices.
349 */
350 class WXDLLIMPEXP_PROPGRID wxMultiChoiceProperty : public wxPGProperty
351 {
352 WX_PG_DECLARE_PROPERTY_CLASS(wxMultiChoiceProperty)
353 public:
354
355 wxMultiChoiceProperty( const wxString& label,
356 const wxString& name,
357 const wxArrayString& strings,
358 const wxArrayString& value );
359 wxMultiChoiceProperty( const wxString& label,
360 const wxString& name,
361 const wxPGChoices& choices,
362 const wxArrayString& value = wxArrayString() );
363
364 wxMultiChoiceProperty( const wxString& label = wxPG_LABEL,
365 const wxString& name = wxPG_LABEL,
366 const wxArrayString& value = wxArrayString() );
367
368 virtual ~wxMultiChoiceProperty();
369
370 virtual void OnSetValue();
371 virtual wxString ValueToString( wxVariant& value, int argFlags = 0 ) const;
372 virtual bool StringToValue(wxVariant& variant,
373 const wxString& text,
374 int argFlags = 0) const;
375 virtual bool OnEvent( wxPropertyGrid* propgrid,
376 wxWindow* primary, wxEvent& event );
377
378 wxArrayInt GetValueAsArrayInt() const
379 {
380 return m_choices.GetValuesForStrings(m_value.GetArrayString());
381 }
382
383 protected:
384
385 void GenerateValueAsString( wxVariant& value, wxString* target ) const;
386
387 // Returns translation of values into string indices.
388 wxArrayInt GetValueAsIndices() const;
389
390 wxArrayString m_valueAsStrings; // Value as array of strings
391
392 // Cache displayed text since generating it is relatively complicated.
393 wxString m_display;
394 };
395
396 #endif // wxUSE_CHOICEDLG
397
398 // -----------------------------------------------------------------------
399
400 #if wxUSE_DATETIME
401
402 /** @class wxDateProperty
403 @ingroup classes
404 Property representing wxDateTime.
405
406 <b>Supported special attributes:</b>
407 - "DateFormat": Determines displayed date format.
408 - "PickerStyle": Determines window style used with wxDatePickerCtrl.
409 Default is wxDP_DEFAULT | wxDP_SHOWCENTURY. Using wxDP_ALLOWNONE
410 enables additional support for unspecified property value.
411 */
412 class WXDLLIMPEXP_PROPGRID wxDateProperty : public wxPGProperty
413 {
414 WX_PG_DECLARE_PROPERTY_CLASS(wxDateProperty)
415 public:
416
417 wxDateProperty( const wxString& label = wxPG_LABEL,
418 const wxString& name = wxPG_LABEL,
419 const wxDateTime& value = wxDateTime() );
420 virtual ~wxDateProperty();
421
422 virtual void OnSetValue();
423 virtual wxString ValueToString( wxVariant& value, int argFlags = 0 ) const;
424 virtual bool StringToValue(wxVariant& variant,
425 const wxString& text,
426 int argFlags = 0) const;
427
428 virtual bool DoSetAttribute( const wxString& name, wxVariant& value );
429
430 void SetFormat( const wxString& format )
431 {
432 m_format = format;
433 }
434
435 const wxString& GetFormat() const
436 {
437 return m_format;
438 }
439
440 void SetDateValue( const wxDateTime& dt )
441 {
442 //m_valueDateTime = dt;
443 m_value = dt;
444 }
445
446 wxDateTime GetDateValue() const
447 {
448 //return m_valueDateTime;
449 return m_value;
450 }
451
452 long GetDatePickerStyle() const
453 {
454 return m_dpStyle;
455 }
456
457 protected:
458 wxString m_format;
459 long m_dpStyle; // DatePicker style
460
461 static wxString ms_defaultDateFormat;
462 static wxString DetermineDefaultDateFormat( bool showCentury );
463 };
464
465 #endif // wxUSE_DATETIME
466
467 // -----------------------------------------------------------------------
468
469 #if wxUSE_SPINBTN
470
471 //
472 // Implement an editor control that allows using wxSpinCtrl (actually, a
473 // combination of wxTextCtrl and wxSpinButton) to edit value of wxIntProperty
474 // and wxFloatProperty (and similar).
475 //
476 // Note that new editor classes needs to be registered before use. This can be
477 // accomplished using wxPGRegisterEditorClass macro, which is used for SpinCtrl
478 // in wxPropertyGridInterface::RegisterAdditionalEditors (see below).
479 // Registration can also be performed in a constructor of a property that is
480 // likely to require the editor in question.
481 //
482
483
484 #include "wx/spinbutt.h"
485 #include "wx/propgrid/editors.h"
486
487
488 // NOTE: Regardless that this class inherits from a working editor, it has
489 // all necessary methods to work independently. wxTextCtrl stuff is only
490 // used for event handling here.
491 class WXDLLIMPEXP_PROPGRID wxPGSpinCtrlEditor : public wxPGTextCtrlEditor
492 {
493 DECLARE_DYNAMIC_CLASS(wxPGSpinCtrlEditor)
494 public:
495 virtual ~wxPGSpinCtrlEditor();
496
497 wxString GetName() const;
498 virtual wxPGWindowList CreateControls(wxPropertyGrid* propgrid,
499 wxPGProperty* property,
500 const wxPoint& pos,
501 const wxSize& size) const;
502 virtual bool OnEvent( wxPropertyGrid* propgrid, wxPGProperty* property,
503 wxWindow* wnd, wxEvent& event ) const;
504
505 private:
506 mutable wxString m_tempString;
507 };
508
509 #endif // wxUSE_SPINBTN
510
511 // -----------------------------------------------------------------------
512
513 #endif // wxUSE_PROPGRID
514
515 #endif // _WX_PROPGRID_ADVPROPS_H_