X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b4071e913e85e35024ee5883a0a046f0fd6332bf..559fe022dbd5d4d961402b5c973e5225fa91f17f:/include/wx/gtk1/choice.h diff --git a/include/wx/gtk1/choice.h b/include/wx/gtk1/choice.h index 9929a37fef..7b95f490da 100644 --- a/include/wx/gtk1/choice.h +++ b/include/wx/gtk1/choice.h @@ -2,13 +2,11 @@ // Name: choice.h // Purpose: // Author: Robert Roebling -// Created: 01/02/97 -// Id: -// Copyright: (c) 1998 Robert Roebling, Julian Smart and Markus Holzem -// Licence: wxWindows licence +// Id: $Id$ +// Copyright: (c) 1998 Robert Roebling +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// - #ifndef __GTKCHOICEH__ #define __GTKCHOICEH__ @@ -17,6 +15,7 @@ #endif #include "wx/defs.h" + #include "wx/object.h" #include "wx/list.h" #include "wx/control.h" @@ -31,50 +30,75 @@ class wxChoice; // global data //----------------------------------------------------------------------------- -extern const char *wxChoiceNameStr; +extern const wxChar *wxChoiceNameStr; //----------------------------------------------------------------------------- // wxChoice //----------------------------------------------------------------------------- -class wxChoice: public wxControl +class wxChoice : public wxControl { - DECLARE_DYNAMIC_CLASS(wxChoice) - - public: - - wxChoice(void); - inline wxChoice( 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 = wxChoiceNameStr ) +public: + wxChoice(); + wxChoice( 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 = wxChoiceNameStr ) { - Create(parent, id, pos, size, n, choices, style, validator, name); + Create(parent, id, pos, size, n, choices, style, validator, name); } + ~wxChoice(); bool Create( wxWindow *parent, wxWindowID id, - const wxPoint& pos = wxDefaultPosition, - const wxSize& size = wxDefaultSize, - int n = 0, const wxString choices[] = (wxString *) NULL, - long style = 0, - const wxValidator& validator = wxDefaultValidator, - const wxString& name = wxChoiceNameStr ); + const wxPoint& pos = wxDefaultPosition, + const wxSize& size = wxDefaultSize, + int n = 0, const wxString choices[] = (wxString *) NULL, + long style = 0, + const wxValidator& validator = wxDefaultValidator, + const wxString& name = wxChoiceNameStr ); + void Append( const wxString &item ); - void Clear(void); + void Append( const wxString &item, void* clientData ); + void Append( const wxString &item, wxClientData* clientData ); + + 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); + int FindString( const wxString &string ) const; - int GetColumns(void) const; - int GetSelection(void); + int GetColumns() const; + int GetSelection(); wxString GetString( int n ) const; - wxString GetStringSelection(void) const; - int Number(void) const; + wxString GetStringSelection() const; + int Number() const; void SetColumns( int n = 1 ); void SetSelection( int n ); void SetStringSelection( const wxString &string ); + + // implementation + + wxList m_clientDataList; + wxList m_clientObjectList; + + void DisableEvents(); + void EnableEvents(); + void AppendCommon( const wxString &item ); + void ApplyWidgetStyle(); - void SetFont( const wxFont &font ); +private: + DECLARE_DYNAMIC_CLASS(wxChoice) }; + #endif // __GTKCHOICEH__