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