X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ae7e6cc946f85a9f12ab97f5860bf8d6235ec12a..92c0fc34c104c8d7c12d6a3b78ea232690fc23f4:/interface/wx/rearrangectrl.h diff --git a/interface/wx/rearrangectrl.h b/interface/wx/rearrangectrl.h index 9160b3efa7..fede1749eb 100644 --- a/interface/wx/rearrangectrl.h +++ b/interface/wx/rearrangectrl.h @@ -3,9 +3,8 @@ // Purpose: interface of wxRearrangeList // Author: Vadim Zeitlin // Created: 2008-12-15 -// RCS-ID: $Id$ // Copyright: (c) 2008 Vadim Zeitlin -// Licence: wxWindows license +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// /** @@ -42,6 +41,8 @@ is to use wxRearrangeCtrl which combines it with two standard buttons to move the current item up or down. + @since 2.9.0 + @library{wxcore} @category{ctrl} */ @@ -173,10 +174,12 @@ public: the "Up" and "Down" buttons to move the currently selected item up or down. It is used as the main part of a wxRearrangeDialog. + @since 2.9.0 + @library{wxcore} @category{ctrl} */ -class wxRearrangeCtrl +class wxRearrangeCtrl : public wxPanel { public: /** @@ -260,10 +263,12 @@ public: } @endcode + @since 2.9.0 + @library{wxcore} @category{cmndlg} */ -class wxRearrangeDialog +class wxRearrangeDialog : public wxDialog { public: /** @@ -317,6 +322,52 @@ public: const wxPoint& pos = wxDefaultPosition, const wxString& name = wxRearrangeDialogNameStr); + /** + Customize the dialog by adding extra controls to it. + + This function adds the given @a win to the dialog, putting it just + below the part occupied by wxRearrangeCtrl. It must be called after + creating the dialog and you will typically need to process the events + generated by the extra controls for them to do something useful. + + For example: + @code + class MyRearrangeDialog : public wxRearrangeDialog + { + public: + MyRearrangeDialog(wxWindow *parent, ...) + : wxRearrangeDialog(parent, ...) + { + wxPanel *panel = new wxPanel(this); + wxSizer *sizer = new wxBoxSizer(wxHORIZONTAL); + sizer->Add(new wxStaticText(panel, wxID_ANY, + "Column width in pixels:")); + sizer->Add(new wxTextCtrl(panel, wxID_ANY, "")); + panel->SetSizer(sizer); + AddExtraControls(panel); + } + + ... code to update the text control with the currently selected + item width and to react to its changes omitted ... + }; + @endcode + + See also the complete example of a custom rearrange dialog in the + dialogs sample. + + @param win + The window containing the extra controls. It must have this dialog + as its parent. + */ + void AddExtraControls(wxWindow *win); + + /** + Return the list control used by the dialog. + + @see wxRearrangeCtrl::GetList() + */ + wxRearrangeList *GetList() const; + /** Return the array describing the order of items after it was modified by the user.