X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/58614078c466cffaf0e5d0369741706f130fb793..d9ea011f4d7f66c9728593c5ee10ce2c34964545:/include/wx/gtk/listbox.h diff --git a/include/wx/gtk/listbox.h b/include/wx/gtk/listbox.h index ea621e0697..9b9e436289 100644 --- a/include/wx/gtk/listbox.h +++ b/include/wx/gtk/listbox.h @@ -1,10 +1,10 @@ ///////////////////////////////////////////////////////////////////////////// // Name: listbox.h -// Purpose: +// Purpose: wxListBox class declaration // Author: Robert Roebling // Id: $Id$ // Copyright: (c) 1998 Robert Roebling -// Licence: wxWindows licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -16,6 +16,9 @@ #endif #include "wx/defs.h" + +#if wxUSE_LISTBOX + #include "wx/object.h" #include "wx/list.h" #include "wx/control.h" @@ -37,63 +40,96 @@ extern const char *wxListBoxNameStr; // wxListBox //----------------------------------------------------------------------------- -class wxListBox: public wxControl +class wxListBox : public wxControl { - DECLARE_DYNAMIC_CLASS(wxListBox) - - public: - - wxListBox(void); - inline wxListBox( wxWindow *parent, wxWindowID id, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - int n = 0, const wxString choices[] = (const wxString *) NULL, - long style = 0, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = wxListBoxNameStr ) +DECLARE_DYNAMIC_CLASS(wxListBox) + +public: + wxListBox(); + wxListBox( wxWindow *parent, wxWindowID id, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + int n = 0, const wxString choices[] = (const wxString *) NULL, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxListBoxNameStr ) { - Create(parent, id, pos, size, n, choices, style, validator, name); +#if wxUSE_CHECKLISTBOX + m_hasCheckBoxes = FALSE; +#endif // wxUSE_CHECKLISTBOX + Create(parent, id, pos, size, n, choices, style, validator, name); } - bool Create( wxWindow *parent, wxWindowID id, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - int n = 0, const wxString choices[] = (const wxString *) NULL, - long style = 0, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = wxListBoxNameStr ); + virtual ~wxListBox(); + + bool Create(wxWindow *parent, wxWindowID id, + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + int n = 0, const wxString choices[] = (const wxString *) NULL, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxListBoxNameStr); + void Append( const wxString &item ); - void Append( const wxString &item, char *clientData ); - void Clear(void); + void Append( const wxString &item, void* clientData ); + void Append( const wxString &item, wxClientData* clientData ); + + void InsertItems(int nItems, const wxString items[], int pos); + + void SetClientData( int n, void* clientData ); + void* GetClientData( int n ); + void SetClientObject( int n, wxClientData* clientData ); + wxClientData* GetClientObject( int n ); + + void SetClientObject( wxClientData *data ) { wxControl::SetClientObject( data ); } + wxClientData *GetClientObject() const { return wxControl::GetClientObject(); } + void SetClientData( void *data ) { wxControl::SetClientData( data ); } + void *GetClientData() const { return wxControl::GetClientData(); } + + void Clear(); void Delete( int n ); + void Deselect( int n ); int FindString( const wxString &item ) const; - char *GetClientData( int n ) const; int GetSelection(void) const; int GetSelections( class wxArrayInt &) const; wxString GetString( int n ) const; wxString GetStringSelection(void) const; - int Number(void); + int Number(); bool Selected( int n ); void Set( int n, const wxString *choices ); - void SetClientData( int n, char *clientData ); void SetFirstItem( int n ); void SetFirstItem( const wxString &item ); void SetSelection( int n, bool select = TRUE ); void SetString( int n, const wxString &string ); void SetStringSelection( const wxString &string, bool select = TRUE ); - + +#if wxUSE_DRAG_AND_DROP void SetDropTarget( wxDropTarget *dropTarget ); +#endif - // implementation - + // implementation + + void DisableEvents(); + void EnableEvents(); + void AppendCommon( const wxString &item ); int GetIndex( GtkWidget *item ) const; - GtkWidget *GetConnectWidget(void); + GtkWidget *GetConnectWidget(); bool IsOwnGtkWindow( GdkWindow *window ); void ApplyWidgetStyle(); - + +#if wxUSE_TOOLTIPS + void ApplyToolTip( GtkTooltips *tips, const wxChar *tip ); +#endif // wxUSE_TOOLTIPS + GtkList *m_list; - wxList m_clientData; - + wxList m_clientDataList; + wxList m_clientObjectList; + +#if wxUSE_CHECKLISTBOX + bool m_hasCheckBoxes; +#endif // wxUSE_CHECKLISTBOX }; +#endif + #endif // __GTKLISTBOXH__