X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/53010e52d3adc63d2771263e294714bf644fc979..32c1cda24418c225fa2cff4b1416f7a3d62c88b1:/include/wx/gtk/combobox.h diff --git a/include/wx/gtk/combobox.h b/include/wx/gtk/combobox.h index cd4d25d3a4..a9910b78a3 100644 --- a/include/wx/gtk/combobox.h +++ b/include/wx/gtk/combobox.h @@ -3,8 +3,8 @@ // Purpose: // Author: Robert Roebling // Created: 01/02/97 -// Id: -// Copyright: (c) 1998 Robert Roebling, Julian Smart and Markus Holzem +// Id: $Id$ +// Copyright: (c) 1998 Robert Roebling // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -13,10 +13,11 @@ #define __GTKCOMBOBOXH__ #ifdef __GNUG__ -#pragma interface +#pragma interface "combobox.h" #endif #include "wx/defs.h" + #include "wx/object.h" #include "wx/control.h" @@ -31,73 +32,97 @@ class wxComboBox; //----------------------------------------------------------------------------- extern const char* wxComboBoxNameStr; -extern const char* wxEmptyString; +extern const wxChar* wxEmptyString; //----------------------------------------------------------------------------- // wxComboBox //----------------------------------------------------------------------------- -class wxComboBox: public wxControl +class wxComboBox : public wxControl { DECLARE_DYNAMIC_CLASS(wxComboBox) - public: - inline wxComboBox(void) {} +public: - inline wxComboBox(wxWindow *parent, const wxWindowID id, + inline wxComboBox() {} + inline wxComboBox(wxWindow *parent, wxWindowID id, const wxString& value = wxEmptyString, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, - const int n = 0, const wxString choices[] = NULL, - const long style = 0, + int n = 0, const wxString choices[] = (const wxString *) NULL, + long style = 0, + const wxValidator& validator = wxDefaultValidator, const wxString& name = wxComboBoxNameStr) { - Create(parent, id, value, pos, size, n, choices, style, name); + Create(parent, id, value, pos, size, n, choices, style, validator, name); } - - bool Create(wxWindow *parent, const wxWindowID id, + ~wxComboBox(); + bool Create(wxWindow *parent, wxWindowID id, const wxString& value = wxEmptyString, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, - const int n = 0, const wxString choices[] = NULL, - const long style = 0, + int n = 0, const wxString choices[] = (const wxString *) NULL, + long style = 0, + const wxValidator& validator = wxDefaultValidator, const wxString& name = wxComboBoxNameStr); - // List functions - void Clear(void); void Append( const wxString &item ); - void Append( const wxString &item, char* clientData ); - void Delete( const int n ); - int FindString( const wxString &item ); - char* GetClientData( const int n ); - void SetClientData( const int n, char * clientData ); - int GetSelection(void) const; - wxString GetString( const int n ) const; - wxString GetStringSelection(void) const; - int Number(void) const; - void SetSelection( const int n ); + 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 ); - // Text field functions - wxString GetValue(void) const ; + int FindString( const wxString &item ); + int GetSelection() const; + wxString GetString( int n ) const; + wxString GetStringSelection() const; + int Number() const; + void SetSelection( int n ); + void SetStringSelection( const wxString &string ); + + wxString GetValue() const; void SetValue(const wxString& value); - // Clipboard operations - void Copy(void); - void Cut(void); - void Paste(void); - void SetInsertionPoint(const long pos); - void SetInsertionPointEnd(void); - long GetInsertionPoint(void) const ; - long GetLastPosition(void) const ; - void Replace(const long from, const long to, const wxString& value); - void Remove(const long from, const long to); - void SetSelection(const long from, const long to); - void SetEditable(const bool editable); - - private: + void Copy(); + void Cut(); + void Paste(); + void SetInsertionPoint( long pos ); + void SetInsertionPointEnd(); + long GetInsertionPoint() const; + long GetLastPosition() const; + void Replace( long from, long to, const wxString& value ); + void Remove( long from, long to ); + void SetSelection( long from, long to ); + void SetEditable( bool editable ); + + void OnSize( wxSizeEvent &event ); + void OnChar( wxKeyEvent &event ); + +// implementation + + bool m_alreadySent; + wxList m_clientDataList; + wxList m_clientObjectList; + + void AppendCommon( const wxString &item ); + GtkWidget* GetConnectWidget(); + bool IsOwnGtkWindow( GdkWindow *window ); + void ApplyWidgetStyle(); - wxList m_clientData; - + DECLARE_EVENT_TABLE() }; -#endif // __GTKCOMBOBOXH__ +#endif + + // __GTKCOMBOBOXH__