X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f941a30bef665561d96d29c4cee07471dbbd497f..f239af65af594968e2fe6885e389a5bd28d73d9d:/include/wx/osx/combobox.h diff --git a/include/wx/osx/combobox.h b/include/wx/osx/combobox.h index 7eef53a199..05c14a96aa 100644 --- a/include/wx/osx/combobox.h +++ b/include/wx/osx/combobox.h @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: wx/mac/carbon/combobox.h +// Name: wx/osx/combobox.h // Purpose: wxComboBox class // Author: Stefan Csomor // Modified by: @@ -14,23 +14,32 @@ #include "wx/containr.h" #include "wx/choice.h" +#include "wx/textctrl.h" -WXDLLIMPEXP_DATA_CORE(extern const char) wxComboBoxNameStr[]; +WX_DEFINE_ARRAY( char * , wxComboBoxDataArray ) ; // forward declaration of private implementation classes class wxComboBoxText; class wxComboBoxChoice; +class wxComboWidgetImpl; // Combobox item -class WXDLLIMPEXP_CORE wxComboBox : public wxControl, public wxComboBoxBase +class WXDLLIMPEXP_CORE wxComboBox : + public wxWindowWithItems< +#if wxOSX_USE_CARBON + wxNavigationEnabled, +#else + wxControl, +#endif + wxComboBoxBase> { DECLARE_DYNAMIC_CLASS(wxComboBox) public: virtual ~wxComboBox(); -#ifndef wxOSX_USE_NATIVE_COMBOBOX +#if wxOSX_USE_CARBON // forward these functions to all subcontrols virtual bool Enable(bool enable = true); virtual bool Show(bool show = true); @@ -40,7 +49,7 @@ class WXDLLIMPEXP_CORE wxComboBox : public wxControl, public wxComboBoxBase virtual void DelegateTextChanged( const wxString& value ); virtual void DelegateChoice( const wxString& value ); - wxComboBox() { Init(); } + wxComboBox() { } wxComboBox(wxWindow *parent, wxWindowID id, const wxString& value = wxEmptyString, @@ -51,7 +60,6 @@ class WXDLLIMPEXP_CORE wxComboBox : public wxControl, public wxComboBoxBase const wxValidator& validator = wxDefaultValidator, const wxString& name = wxComboBoxNameStr) { - Init(); Create(parent, id, value, pos, size, n, choices, style, validator, name); } @@ -64,7 +72,6 @@ class WXDLLIMPEXP_CORE wxComboBox : public wxControl, public wxComboBoxBase const wxValidator& validator = wxDefaultValidator, const wxString& name = wxComboBoxNameStr) { - Init(); Create(parent, id, value, pos, size, choices, style, validator, name); } @@ -87,17 +94,22 @@ class WXDLLIMPEXP_CORE wxComboBox : public wxControl, public wxComboBoxBase const wxString& name = wxComboBoxNameStr); virtual int GetSelection() const; + virtual void GetSelection(long *from, long *to) const; virtual void SetSelection(int n); + virtual void SetSelection(long from, long to); virtual int FindString(const wxString& s, bool bCase = false) const; virtual wxString GetString(unsigned int n) const; virtual wxString GetStringSelection() const; virtual void SetString(unsigned int n, const wxString& s); + virtual unsigned int GetCount() const; + +// these methods are provided by wxTextEntry for the native impl. +#if wxOSX_USE_CARBON // Text field functions virtual void SetValue(const wxString& value); virtual wxString GetValue() const; virtual void WriteText(const wxString& text); - virtual void GetSelection(long *from, long *to) const; // Clipboard operations virtual void Copy(); @@ -109,12 +121,9 @@ class WXDLLIMPEXP_CORE wxComboBox : public wxControl, public wxComboBoxBase virtual wxTextPos GetLastPosition() const; virtual void Replace(long from, long to, const wxString& value); virtual void Remove(long from, long to); - virtual void SetSelection(long from, long to); virtual void SetEditable(bool editable); virtual bool IsEditable() const; - virtual unsigned int GetCount() const; - virtual void Undo(); virtual void Redo(); virtual void SelectAll(); @@ -127,31 +136,36 @@ class WXDLLIMPEXP_CORE wxComboBox : public wxControl, public wxComboBoxBase virtual wxClientDataType GetClientDataType() const; + virtual wxTextWidgetImpl* GetTextPeer() const; +#endif // wxOSX_USE_CARBON + +#if wxOSX_USE_COCOA + virtual void Popup(); + virtual void Dismiss(); +#endif // wxOSX_USE_COCOA + + // osx specific event handling common for all osx-ports virtual bool OSXHandleClicked( double timestampsec ); -#ifndef wxOSX_USE_NATIVE_COMBOBOX - wxCONTROL_ITEMCONTAINER_CLIENTDATAOBJECT_RECAST - - WX_DECLARE_CONTROL_CONTAINER(); +#if wxOSX_USE_COCOA + wxComboWidgetImpl* GetComboPeer() const; #endif - protected: - // common part of all ctors - void Init(); - // List functions virtual void DoDeleteOneItem(unsigned int n); virtual void DoClear(); // wxTextEntry functions +#if wxOSX_USE_CARBON virtual wxString DoGetValue() const; +#endif virtual wxWindow *GetEditableWindow() { return this; } -#ifndef wxOSX_USE_NATIVE_COMBOBOX // override the base class virtuals involved in geometry calculations virtual wxSize DoGetBestSize() const; +#if wxOSX_USE_CARBON virtual void DoMoveWindow(int x, int y, int width, int height); #endif @@ -162,7 +176,9 @@ protected: virtual void DoSetItemClientData(unsigned int n, void* clientData); virtual void * DoGetItemClientData(unsigned int n) const; +#if wxOSX_USE_CARBON virtual void SetClientDataType(wxClientDataType clientDataItemsType); +#endif virtual void EnableTextChangedEvents(bool enable); @@ -170,9 +186,7 @@ protected: wxComboBoxText* m_text; wxComboBoxChoice* m_choice; -#ifndef wxOSX_USE_NATIVE_COMBOBOX - DECLARE_EVENT_TABLE() -#endif + wxComboBoxDataArray m_datas; }; #endif // _WX_COMBOBOX_H_