2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: dirdlg.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxDirDialog
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
2010-07-13 13:29:13 +00:00
|
|
|
// Licence: wxWindows licence
|
2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2011-12-30 06:14:17 +00:00
|
|
|
#define wxDD_DEFAULT_STYLE (wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER)
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxDirDialog
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class represents the directory chooser dialog.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@beginStyleTable
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxDD_DEFAULT_STYLE}
|
2008-03-08 13:52:38 +00:00
|
|
|
Equivalent to a combination of wxDEFAULT_DIALOG_STYLE and
|
|
|
|
wxRESIZE_BORDER (the last one is not used under wxWinCE).
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxDD_DIR_MUST_EXIST}
|
2008-03-08 13:52:38 +00:00
|
|
|
The dialog will allow the user to choose only an existing folder.
|
|
|
|
When this style is not given, a "Create new directory" button is
|
|
|
|
added to the dialog (on Windows) or some other way is provided to
|
|
|
|
the user to type the name of a new folder.
|
2008-04-06 14:43:04 +00:00
|
|
|
@style{wxDD_CHANGE_DIR}
|
2008-03-08 13:52:38 +00:00
|
|
|
Change the current working directory to the directory chosen by the
|
|
|
|
user.
|
|
|
|
@endStyleTable
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-11-05 15:27:34 +00:00
|
|
|
Notice that @c wxRESIZE_BORDER has special side effect under recent (i.e.
|
|
|
|
later than Win9x) Windows where two different directory selection dialogs
|
|
|
|
are available and this style also implicitly selects the new version as the
|
|
|
|
old one always has fixed size. As the new version is almost always
|
|
|
|
preferable, it is recommended that @c wxRESIZE_BORDER style be always used.
|
|
|
|
This is the case if the dialog is created with the default style value but
|
|
|
|
if you need to use any additional styles you should still specify @c
|
|
|
|
wxDD_DEFAULT_STYLE unless you explicitly need to use the old dialog version
|
|
|
|
under Windows. E.g. do
|
|
|
|
@code
|
|
|
|
wxDirDialog dlg(NULL, "Choose input directory", "",
|
|
|
|
wxDD_DEFAULT_STYLE | wxDD_DIR_MUST_EXIST);
|
|
|
|
@endcode
|
|
|
|
instead of just using @c wxDD_DIR_MUST_EXIST style alone.
|
2008-04-21 01:40:12 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
|
|
|
@category{cmndlg}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-21 01:40:12 +00:00
|
|
|
@see @ref overview_cmndlg_dir, wxFileDialog
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxDirDialog : public wxDialog
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-04-21 01:40:12 +00:00
|
|
|
Constructor. Use ShowModal() to show the dialog.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
@param parent
|
2008-03-09 12:33:59 +00:00
|
|
|
Parent window.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param message
|
2008-03-09 12:33:59 +00:00
|
|
|
Message to show on the dialog.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param defaultPath
|
2008-03-09 12:33:59 +00:00
|
|
|
The default path, or the empty string.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param style
|
2008-03-09 12:33:59 +00:00
|
|
|
The dialog style. See wxDirDialog
|
2008-03-08 14:43:31 +00:00
|
|
|
@param pos
|
2008-03-09 12:33:59 +00:00
|
|
|
Dialog position. Ignored under Windows.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param size
|
2008-03-09 12:33:59 +00:00
|
|
|
Dialog size. Ignored under Windows.
|
2008-03-08 14:43:31 +00:00
|
|
|
@param name
|
2008-03-09 12:33:59 +00:00
|
|
|
The dialog name, not used.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxDirDialog(wxWindow* parent,
|
2008-11-08 15:17:16 +00:00
|
|
|
const wxString& message = wxDirSelectorPromptStr,
|
|
|
|
const wxString& defaultPath = wxEmptyString,
|
2008-03-08 13:52:38 +00:00
|
|
|
long style = wxDD_DEFAULT_STYLE,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
|
|
|
const wxSize& size = wxDefaultSize,
|
2008-11-08 15:17:16 +00:00
|
|
|
const wxString& name = wxDirDialogNameStr);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual ~wxDirDialog();
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the message that will be displayed on the dialog.
|
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual wxString GetMessage() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the default or user-selected path.
|
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual wxString GetPath() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the message that will be displayed on the dialog.
|
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual void SetMessage(const wxString& message);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Sets the default path.
|
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual void SetPath(const wxString& path);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-21 01:40:12 +00:00
|
|
|
Shows the dialog, returning wxID_OK if the user pressed OK, and
|
|
|
|
wxID_CANCEL otherwise.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
int ShowModal();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
// ============================================================================
|
|
|
|
// Global functions/macros
|
|
|
|
// ============================================================================
|
|
|
|
|
2009-01-05 20:48:06 +00:00
|
|
|
/** @addtogroup group_funcmacro_dialog */
|
2008-03-18 19:30:01 +00:00
|
|
|
//@{
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
2008-03-18 19:30:01 +00:00
|
|
|
Pops up a directory selector dialog. The arguments have the same meaning
|
|
|
|
as those of wxDirDialog::wxDirDialog(). The message is displayed at the
|
|
|
|
top, and the default_path, if specified, is set as the initial selection.
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
The application must check for an empty return value (if the user pressed
|
|
|
|
Cancel). For example:
|
2008-03-09 12:33:59 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@code
|
|
|
|
const wxString& dir = wxDirSelector("Choose a folder");
|
|
|
|
if ( !dir.empty() )
|
|
|
|
{
|
2008-03-18 19:30:01 +00:00
|
|
|
...
|
2008-03-08 13:52:38 +00:00
|
|
|
}
|
|
|
|
@endcode
|
2008-03-18 19:30:01 +00:00
|
|
|
|
|
|
|
@header{wx/dirdlg.h}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
wxString wxDirSelector(const wxString& message = wxDirSelectorPromptStr,
|
2009-01-10 18:31:45 +00:00
|
|
|
const wxString& default_path = wxEmptyString,
|
2008-03-08 13:52:38 +00:00
|
|
|
long style = 0,
|
|
|
|
const wxPoint& pos = wxDefaultPosition,
|
2008-03-09 12:33:59 +00:00
|
|
|
wxWindow* parent = NULL);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
2008-03-18 19:30:01 +00:00
|
|
|
//@}
|
|
|
|
|