]> git.saurik.com Git - wxWidgets.git/blame - interface/filepicker.h
don't compile in wx hash code unless we really use it (#9532:12)
[wxWidgets.git] / interface / filepicker.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: filepicker.h
e54c96f1 3// Purpose: interface of wxFilePickerCtrl
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxFilePickerCtrl
11 @wxheader{filepicker.h}
7c913512 12
23324ae1
FM
13 This control allows the user to select a file. The generic implementation is
14 a button which brings up a wxFileDialog when clicked. Native implementation
15 may differ but this is usually a (small) widget which give access to the
16 file-chooser
17 dialog.
18 It is only available if @c wxUSE_FILEPICKERCTRL is set to 1 (the default).
7c913512 19
23324ae1 20 @beginStyleTable
8c6791e4 21 @style{wxFLP_DEFAULT_STYLE}
23324ae1
FM
22 The default style: includes wxFLP_OPEN | wxFLP_FILE_MUST_EXIST and,
23 under wxMSW only, wxFLP_USE_TEXTCTRL.
8c6791e4 24 @style{wxFLP_USE_TEXTCTRL}
23324ae1
FM
25 Creates a text control to the left of the picker button which is
26 completely managed by the wxFilePickerCtrl and which can be used by
27 the user to specify a path (see SetPath). The text control is
28 automatically synchronized with button's value. Use functions
29 defined in wxPickerBase to modify the text control.
8c6791e4 30 @style{wxFLP_OPEN}
23324ae1 31 Creates a picker which allows the user to select a file to open.
8c6791e4 32 @style{wxFLP_SAVE}
23324ae1 33 Creates a picker which allows the user to select a file to save.
8c6791e4 34 @style{wxFLP_OVERWRITE_PROMPT}
23324ae1
FM
35 Can be combined with wxFLP_SAVE only: ask confirmation to the user
36 before selecting a file.
8c6791e4 37 @style{wxFLP_FILE_MUST_EXIST}
23324ae1
FM
38 Can be combined with wxFLP_OPEN only: the selected file must be an
39 existing file.
8c6791e4 40 @style{wxFLP_CHANGE_DIR}
23324ae1
FM
41 Change current working directory on each user file selection change.
42 @endStyleTable
7c913512 43
23324ae1 44 @library{wxcore}
d18d9f60 45 @category{pickers}
0c7fe6f2 46 <!-- @appearance{filepickerctrl.png} -->
7c913512 47
e54c96f1 48 @see wxFileDialog, wxFileDirPickerEvent
23324ae1
FM
49*/
50class wxFilePickerCtrl : public wxPickerBase
51{
52public:
53 /**
54 Initializes the object and calls Create() with
55 all the parameters.
56 */
4cc4bfaf 57 wxFilePickerCtrl(wxWindow* parent, wxWindowID id,
23324ae1
FM
58 const wxString& path = wxEmptyString,
59 const wxString& message = "Select a file",
60 const wxString& wildcard = ".",
61 const wxPoint& pos = wxDefaultPosition,
62 const wxSize& size = wxDefaultSize,
63 long style = wxFLP_DEFAULT_STYLE,
64 const wxValidator& validator = wxDefaultValidator,
65 const wxString& name = "filepickerctrl");
66
67 /**
7c913512 68 @param parent
4cc4bfaf 69 Parent window, must not be non-@NULL.
7c913512 70 @param id
4cc4bfaf 71 The identifier for the control.
7c913512 72 @param path
4cc4bfaf
FM
73 The initial file shown in the control. Must be a valid path to a file or
74 the empty string.
7c913512 75 @param message
4cc4bfaf 76 The message shown to the user in the wxFileDialog shown by the control.
7c913512 77 @param wildcard
4cc4bfaf 78 A wildcard which defines user-selectable files (use the same syntax as for
23324ae1 79 wxFileDialog's wildcards).
7c913512 80 @param pos
4cc4bfaf 81 Initial position.
7c913512 82 @param size
4cc4bfaf 83 Initial size.
7c913512 84 @param style
4cc4bfaf 85 The window style, see wxFLP_* flags.
7c913512 86 @param validator
4cc4bfaf 87 Validator which can be used for additional date checks.
7c913512 88 @param name
4cc4bfaf 89 Control name.
3c4f71cc 90
d29a9a8a 91 @return @true if the control was successfully created or @false if
4cc4bfaf 92 creation failed.
23324ae1 93 */
4cc4bfaf 94 bool Create(wxWindow* parent, wxWindowID id,
23324ae1
FM
95 const wxString& path = wxEmptyString,
96 const wxString& message = "Select a file",
97 const wxString& wildcard = ".",
98 const wxPoint& pos = wxDefaultPosition,
99 const wxSize& size = wxDefaultSize,
100 long style = wxFLP_DEFAULT_STYLE,
101 const wxValidator& validator = wxDefaultValidator,
102 const wxString& name = "filepickerctrl");
103
104 /**
105 Similar to GetPath() but returns the path of
106 the currently selected file as a wxFileName object.
107 */
328f5751 108 wxFileName GetFileName() const;
23324ae1
FM
109
110 /**
111 Returns the absolute path of the currently selected file.
112 */
328f5751 113 wxString GetPath() const;
23324ae1
FM
114
115 /**
116 This method does the same thing as SetPath() but
117 takes a wxFileName object instead of a string.
118 */
4cc4bfaf 119 void SetFileName(const wxFileName& filename);
23324ae1
FM
120
121 /**
122 Sets the absolute path of the currently selected file. This must be a valid
123 file if
124 the @c wxFLP_FILE_MUST_EXIST style was given.
125 */
4cc4bfaf 126 void SetPath(const wxString& filename);
23324ae1
FM
127};
128
129
e54c96f1 130
23324ae1
FM
131/**
132 @class wxDirPickerCtrl
133 @wxheader{filepicker.h}
7c913512 134
23324ae1
FM
135 This control allows the user to select a directory. The generic implementation
136 is
137 a button which brings up a wxDirDialog when clicked. Native implementation
138 may differ but this is usually a (small) widget which give access to the
139 dir-chooser
140 dialog.
141 It is only available if @c wxUSE_DIRPICKERCTRL is set to 1 (the default).
7c913512 142
23324ae1 143 @beginStyleTable
8c6791e4 144 @style{wxDIRP_DEFAULT_STYLE}
23324ae1
FM
145 The default style: includes wxDIRP_DIR_MUST_EXIST and, under wxMSW
146 only, wxDIRP_USE_TEXTCTRL.
8c6791e4 147 @style{wxDIRP_USE_TEXTCTRL}
23324ae1
FM
148 Creates a text control to the left of the picker button which is
149 completely managed by the wxDirPickerCtrl and which can be used by
150 the user to specify a path (see SetPath). The text control is
151 automatically synchronized with button's value. Use functions
152 defined in wxPickerBase to modify the text control.
8c6791e4 153 @style{wxDIRP_DIR_MUST_EXIST}
23324ae1
FM
154 Creates a picker which allows to select only existing directories.
155 wxGTK control always adds this flag internally as it does not
156 support its absence.
8c6791e4 157 @style{wxDIRP_CHANGE_DIR}
23324ae1
FM
158 Change current working directory on each user directory selection
159 change.
160 @endStyleTable
7c913512 161
23324ae1 162 @library{wxcore}
d18d9f60 163 @category{pickers}
0c7fe6f2 164 <!-- @appearance{dirpickerctrl.png} -->
7c913512 165
e54c96f1 166 @see wxDirDialog, wxFileDirPickerEvent
23324ae1
FM
167*/
168class wxDirPickerCtrl : public wxPickerBase
169{
170public:
171 /**
172 Initializes the object and calls Create() with
173 all the parameters.
174 */
4cc4bfaf 175 wxDirPickerCtrl(wxWindow* parent, wxWindowID id,
23324ae1
FM
176 const wxString& path = wxEmptyString,
177 const wxString& message = "Select a folder",
178 const wxPoint& pos = wxDefaultPosition,
179 const wxSize& size = wxDefaultSize,
180 long style = wxDIRP_DEFAULT_STYLE,
181 const wxValidator& validator = wxDefaultValidator,
182 const wxString& name = "dirpickerctrl");
183
184 /**
7c913512 185 @param parent
4cc4bfaf 186 Parent window, must not be non-@NULL.
7c913512 187 @param id
4cc4bfaf 188 The identifier for the control.
7c913512 189 @param path
4cc4bfaf
FM
190 The initial directory shown in the control. Must be a valid path to a
191 directory or the empty string.
7c913512 192 @param message
4cc4bfaf 193 The message shown to the user in the wxDirDialog shown by the control.
7c913512 194 @param pos
4cc4bfaf 195 Initial position.
7c913512 196 @param size
4cc4bfaf 197 Initial size.
7c913512 198 @param style
4cc4bfaf 199 The window style, see wxDIRP_* flags.
7c913512 200 @param validator
4cc4bfaf 201 Validator which can be used for additional date checks.
7c913512 202 @param name
4cc4bfaf 203 Control name.
3c4f71cc 204
d29a9a8a 205 @return @true if the control was successfully created or @false if
4cc4bfaf 206 creation failed.
23324ae1 207 */
4cc4bfaf 208 bool Create(wxWindow* parent, wxWindowID id,
23324ae1
FM
209 const wxString& path = wxEmptyString,
210 const wxString& message = "Select a folder",
211 const wxPoint& pos = wxDefaultPosition,
212 const wxSize& size = wxDefaultSize,
213 long style = wxDIRP_DEFAULT_STYLE,
214 const wxValidator& validator = wxDefaultValidator,
215 const wxString& name = "dirpickerctrl");
216
217 /**
218 Returns the absolute path of the currently selected directory as a wxFileName
219 object.
220 This function is equivalent to GetPath()
221 */
328f5751 222 wxFileName GetDirName() const;
23324ae1
FM
223
224 /**
225 Returns the absolute path of the currently selected directory.
226 */
328f5751 227 wxString GetPath() const;
23324ae1
FM
228
229 /**
230 Just like SetPath() but this function takes a
231 wxFileName object.
232 */
4cc4bfaf 233 void SetDirName(const wxFileName& dirname);
23324ae1
FM
234
235 /**
236 Sets the absolute path of (the default converter uses current locale's
237 charset)the currently selected directory. This must be a valid directory if
238 @c wxDIRP_DIR_MUST_EXIST style was given.
239 */
4cc4bfaf 240 void SetPath(const wxString& dirname);
23324ae1
FM
241};
242
243
e54c96f1 244
23324ae1
FM
245/**
246 @class wxFileDirPickerEvent
247 @wxheader{filepicker.h}
7c913512 248
23324ae1
FM
249 This event class is used for the events generated by
250 wxFilePickerCtrl and by wxDirPickerCtrl.
7c913512 251
23324ae1
FM
252 @library{wxcore}
253 @category{FIXME}
7c913512 254
e54c96f1 255 @see wxfilepickerctrl()
23324ae1
FM
256*/
257class wxFileDirPickerEvent : public wxCommandEvent
258{
259public:
260 /**
261 The constructor is not normally used by the user code.
262 */
4cc4bfaf 263 wxFileDirPickerEvent(wxEventType type, wxObject* generator,
23324ae1
FM
264 int id,
265 const wxString path);
266
267 /**
268 Retrieve the absolute path of the file/directory the user has just selected.
269 */
328f5751 270 wxString GetPath() const;
23324ae1
FM
271
272 /**
273 Set the absolute path of the file/directory associated with the event.
274 */
4cc4bfaf 275 void SetPath(const wxString& path);
23324ae1 276};
e54c96f1 277