]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/pickerbase.h
handle error in GetDataSize()
[wxWidgets.git] / interface / wx / pickerbase.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: pickerbase.h
e54c96f1 3// Purpose: interface of wxPickerBase
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxPickerBase
7c913512 11
23324ae1 12 Base abstract class for all pickers which support an auxiliary text control.
74bf4e64 13
23324ae1 14 This class handles all positioning and sizing of the text control like a
74bf4e64
FM
15 an horizontal wxBoxSizer would do, with the text control on the left of the
16 picker button.
4d7b68d1 17
74bf4e64
FM
18 The proportion (see wxSizer documentation for more info about proportion values)
19 of the picker control defaults to 1 when there isn't a text control associated
20 (see @c wxPB_USE_TEXTCTRL style) and to 0 otherwise.
7c913512 21
23324ae1 22 @beginStyleTable
8c6791e4 23 @style{wxPB_USE_TEXTCTRL}
23324ae1
FM
24 Creates a text control to the left of the picker which is
25 completely managed by this wxPickerBase class.
26 @endStyleTable
7c913512 27
23324ae1 28 @library{wxcore}
74bf4e64 29 @category{pickers}
7c913512 30
e54c96f1 31 @see wxColourPickerCtrl
23324ae1
FM
32*/
33class wxPickerBase : public wxControl
34{
35public:
36 /**
37 Returns the margin (in pixel) between the picker and the text control.
74bf4e64 38
23324ae1
FM
39 This function can be used only when HasTextCtrl() returns @true.
40 */
328f5751 41 int GetInternalMargin() const;
23324ae1
FM
42
43 /**
44 Returns the proportion value of the picker.
45 */
328f5751 46 int GetPickerCtrlProportion() const;
23324ae1
FM
47
48 /**
49 Returns a pointer to the text control handled by this window or @NULL if the
74bf4e64
FM
50 @c wxPB_USE_TEXTCTRL style was not specified when this control was created.
51
52 @remarks
53 The contents of the text control could be containing an invalid
54 representation of the entity which can be chosen through the picker
55 (e.g. the user entered an invalid colour syntax because of a typo).
56 Thus you should never parse the content of the textctrl to get the
57 user's input; rather use the derived-class getter
58 (e.g. wxColourPickerCtrl::GetColour(), wxFilePickerCtrl::GetPath(), etc).
23324ae1 59 */
4cc4bfaf 60 wxTextCtrl* GetTextCtrl();
23324ae1
FM
61
62 /**
63 Returns the proportion value of the text control.
74bf4e64 64
23324ae1
FM
65 This function can be used only when HasTextCtrl() returns @true.
66 */
328f5751 67 int GetTextCtrlProportion() const;
23324ae1
FM
68
69 /**
74bf4e64
FM
70 Returns @true if this window has a valid text control (i.e. if the @c
71 wxPB_USE_TEXTCTRL style was given when creating this control).
23324ae1 72 */
328f5751 73 bool HasTextCtrl() const;
23324ae1
FM
74
75 /**
76 Returns @true if the picker control is growable.
77 */
328f5751 78 bool IsPickerCtrlGrowable() const;
23324ae1
FM
79
80 /**
81 Returns @true if the text control is growable.
74bf4e64 82
23324ae1
FM
83 This function can be used only when HasTextCtrl() returns @true.
84 */
328f5751 85 bool IsTextCtrlGrowable() const;
23324ae1
FM
86
87 /**
88 Sets the margin (in pixel) between the picker and the text control.
74bf4e64 89
23324ae1
FM
90 This function can be used only when HasTextCtrl() returns @true.
91 */
92 void SetInternalMargin(int margin);
93
94 /**
95 Sets the picker control as growable when @c grow is @true.
96 */
4cc4bfaf 97 void SetPickerCtrlGrowable(bool grow = true);
23324ae1
FM
98
99 /**
100 Sets the proportion value of the picker.
74bf4e64 101
4d7b68d1 102 Look at the detailed description of wxPickerBase for more info.
23324ae1
FM
103 */
104 void SetPickerCtrlProportion(int prop);
105
106 /**
107 Sets the text control as growable when @c grow is @true.
74bf4e64 108
23324ae1
FM
109 This function can be used only when HasTextCtrl() returns @true.
110 */
4cc4bfaf 111 void SetTextCtrlGrowable(bool grow = true);
23324ae1
FM
112
113 /**
114 Sets the proportion value of the text control.
74bf4e64 115
4d7b68d1
FM
116 Look at the detailed description of wxPickerBase for more info.
117
23324ae1
FM
118 This function can be used only when HasTextCtrl() returns @true.
119 */
120 void SetTextCtrlProportion(int prop);
121};
e54c96f1 122