// Author: Robert Roebling
// Created: 01/02/97
// Id: $Id$
-// Copyright: (c) 1998 Robert Roebling, Julian Smart and Markus Holzem
+// Copyright: (c) 1998 Robert Roebling
// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef __GTKCOMBOBOXH__
#define __GTKCOMBOBOXH__
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(__APPLE__)
#pragma interface "combobox.h"
#endif
#include "wx/defs.h"
+
+#if wxUSE_COMBOBOX
+
#include "wx/object.h"
#include "wx/control.h"
// global data
//-----------------------------------------------------------------------------
-extern const char* wxComboBoxNameStr;
-extern const char* wxEmptyString;
+extern const wxChar* wxComboBoxNameStr;
+extern const wxChar* wxEmptyString;
//-----------------------------------------------------------------------------
// wxComboBox
//-----------------------------------------------------------------------------
-class wxComboBox: public wxControl
+class wxComboBox : public wxControl
{
- DECLARE_DYNAMIC_CLASS(wxComboBox)
-
- public:
- inline wxComboBox(void) {}
-
- inline wxComboBox(wxWindow *parent, wxWindowID id,
+public:
+ inline wxComboBox() {}
+ inline wxComboBox(wxWindow *parent, wxWindowID id,
const wxString& value = wxEmptyString,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
long style = 0,
const wxValidator& validator = wxDefaultValidator,
const wxString& name = wxComboBoxNameStr)
- {
- Create(parent, id, value, pos, size, n, choices, style, validator, name);
- }
- bool Create(wxWindow *parent, wxWindowID id,
+ {
+ Create(parent, id, value, pos, size, n, choices, style, validator, name);
+ }
+ ~wxComboBox();
+ bool Create(wxWindow *parent, wxWindowID id,
const wxString& value = wxEmptyString,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,
const wxValidator& validator = wxDefaultValidator,
const wxString& name = wxComboBoxNameStr);
- void Clear(void);
- void Append( const wxString &item );
- void Append( const wxString &item, char* clientData );
- void Delete( int n );
- int FindString( const wxString &item );
- char* GetClientData( int n );
- void SetClientData( int n, char * clientData );
- int GetSelection(void) const;
- wxString GetString( int n ) const;
- wxString GetStringSelection(void) const;
- int Number(void) const;
- void SetSelection( int n );
- void SetStringSelection( const wxString &string );
-
- wxString GetValue(void) const ;
- void SetValue(const wxString& value);
-
- void Copy(void);
- void Cut(void);
- void Paste(void);
- void SetInsertionPoint(long pos);
- void SetInsertionPointEnd(void);
- long GetInsertionPoint(void) const ;
- long GetLastPosition(void) 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 SetFont( const wxFont &font );
- void OnSize( wxSizeEvent &event );
-
- // implementation
+ void Append( const wxString &item );
+ void Append( const wxString &item, void* clientData );
+ void Append( const wxString &item, wxClientData* clientData );
+
+ void Insert( const wxString &item, int pos );
+ void Insert( const wxString &item, int pos, void* clientData );
+ void Insert( const wxString &item, int pos, wxClientData* clientData );
+
+ void SetClientData( int n, void* clientData );
+ void* GetClientData( int n ) const;
+ void SetClientObject( int n, wxClientData* clientData );
+ wxClientData* GetClientObject( int n ) const;
+
+ 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 &item );
+ int GetSelection() const;
+ wxString GetString( int n ) const;
+ wxString GetStringSelection() const;
+ int GetCount() const { return Number(); }
+ int Number() const;
+ void SetSelection( int n );
+ void SetStringSelection( const wxString &string );
+ void SetString(int n, const wxString &text);
+
+ wxString GetValue() const;
+ void SetValue(const wxString& value);
+
+ 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 );
+
+ // implementation
+
+ virtual void SetFocus();
+
+ void OnSize( wxSizeEvent &event );
+ void OnChar( wxKeyEvent &event );
bool m_alreadySent;
-
- private:
-
- wxList m_clientData;
-
- GtkWidget* GetConnectWidget(void);
- bool IsOwnGtkWindow( GdkWindow *window );
-
- DECLARE_EVENT_TABLE()
+ wxList m_clientDataList;
+ wxList m_clientObjectList;
+ int m_prevSelection;
+
+ void DisableEvents();
+ void EnableEvents();
+ void AppendCommon( const wxString &item );
+ void InsertCommon( const wxString &item, int pos );
+ GtkWidget* GetConnectWidget();
+ bool IsOwnGtkWindow( GdkWindow *window );
+ void ApplyWidgetStyle();
+
+protected:
+ virtual wxSize DoGetBestSize() const;
+
+private:
+ DECLARE_DYNAMIC_CLASS(wxComboBox)
+ DECLARE_EVENT_TABLE()
};
-#endif // __GTKCOMBOBOXH__
+#endif
+
+#endif
+
+ // __GTKCOMBOBOXH__