fixing 'id' objc.h collisions, listbox rewrite
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@38830 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -21,8 +21,30 @@
|
|||||||
// forward decl for GetSelections()
|
// forward decl for GetSelections()
|
||||||
class wxArrayInt;
|
class wxArrayInt;
|
||||||
|
|
||||||
// forward decl for GetPeer()
|
// exposed for subclasses like wxCheckListBox
|
||||||
class wxMacListControl;
|
|
||||||
|
class wxMacListControl
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual void MacDelete( unsigned int n ) = 0;
|
||||||
|
virtual void MacInsert( unsigned int n, const wxString& item ) = 0;
|
||||||
|
virtual void MacInsert( unsigned int n, const wxArrayString& items ) = 0;
|
||||||
|
// returns index of newly created line
|
||||||
|
virtual int MacAppend( const wxString& item ) = 0;
|
||||||
|
virtual void MacSetString( unsigned int n, const wxString& item ) = 0;
|
||||||
|
virtual void MacClear() = 0;
|
||||||
|
virtual void MacDeselectAll() = 0;
|
||||||
|
virtual void MacSetSelection( unsigned int n, bool select ) = 0;
|
||||||
|
virtual int MacGetSelection() const = 0;
|
||||||
|
virtual int MacGetSelections( wxArrayInt& aSelections ) const = 0;
|
||||||
|
virtual bool MacIsSelected( unsigned int n ) const = 0;
|
||||||
|
virtual void MacScrollTo( unsigned int n ) = 0;
|
||||||
|
virtual wxString MacGetString( unsigned int n) const = 0;
|
||||||
|
virtual unsigned int MacGetCount() const = 0;
|
||||||
|
|
||||||
|
virtual void MacSetClientData( unsigned int n, void * data) = 0;
|
||||||
|
virtual void * MacGetClientData( unsigned int) const = 0;
|
||||||
|
};
|
||||||
|
|
||||||
// List box item
|
// List box item
|
||||||
|
|
||||||
@@ -40,7 +62,7 @@ public:
|
|||||||
|
|
||||||
wxListBox(
|
wxListBox(
|
||||||
wxWindow *parent,
|
wxWindow *parent,
|
||||||
wxWindowID id,
|
wxWindowID winid,
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
const wxPoint& pos = wxDefaultPosition,
|
||||||
const wxSize& size = wxDefaultSize,
|
const wxSize& size = wxDefaultSize,
|
||||||
int n = 0, const wxString choices[] = NULL,
|
int n = 0, const wxString choices[] = NULL,
|
||||||
@@ -48,12 +70,12 @@ public:
|
|||||||
const wxValidator& validator = wxDefaultValidator,
|
const wxValidator& validator = wxDefaultValidator,
|
||||||
const wxString& name = wxListBoxNameStr)
|
const wxString& name = wxListBoxNameStr)
|
||||||
{
|
{
|
||||||
Create(parent, id, pos, size, n, choices, style, validator, name);
|
Create(parent, winid, pos, size, n, choices, style, validator, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
wxListBox(
|
wxListBox(
|
||||||
wxWindow *parent,
|
wxWindow *parent,
|
||||||
wxWindowID id,
|
wxWindowID winid,
|
||||||
const wxPoint& pos,
|
const wxPoint& pos,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
const wxArrayString& choices,
|
const wxArrayString& choices,
|
||||||
@@ -61,12 +83,12 @@ public:
|
|||||||
const wxValidator& validator = wxDefaultValidator,
|
const wxValidator& validator = wxDefaultValidator,
|
||||||
const wxString& name = wxListBoxNameStr)
|
const wxString& name = wxListBoxNameStr)
|
||||||
{
|
{
|
||||||
Create(parent, id, pos, size, choices, style, validator, name);
|
Create(parent, winid, pos, size, choices, style, validator, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Create(
|
bool Create(
|
||||||
wxWindow *parent,
|
wxWindow *parent,
|
||||||
wxWindowID id,
|
wxWindowID winid,
|
||||||
const wxPoint& pos = wxDefaultPosition,
|
const wxPoint& pos = wxDefaultPosition,
|
||||||
const wxSize& size = wxDefaultSize,
|
const wxSize& size = wxDefaultSize,
|
||||||
int n = 0,
|
int n = 0,
|
||||||
@@ -77,7 +99,7 @@ public:
|
|||||||
|
|
||||||
bool Create(
|
bool Create(
|
||||||
wxWindow *parent,
|
wxWindow *parent,
|
||||||
wxWindowID id,
|
wxWindowID winid,
|
||||||
const wxPoint& pos,
|
const wxPoint& pos,
|
||||||
const wxSize& size,
|
const wxSize& size,
|
||||||
const wxArrayString& choices,
|
const wxArrayString& choices,
|
||||||
@@ -101,40 +123,34 @@ public:
|
|||||||
virtual int GetSelection() const;
|
virtual int GetSelection() const;
|
||||||
virtual int GetSelections(wxArrayInt& aSelections) const;
|
virtual int GetSelections(wxArrayInt& aSelections) const;
|
||||||
|
|
||||||
|
virtual void EnsureVisible(int n);
|
||||||
|
|
||||||
// wxCheckListBox support
|
// wxCheckListBox support
|
||||||
static wxVisualAttributes
|
static wxVisualAttributes
|
||||||
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
|
||||||
|
|
||||||
wxMacListControl * GetPeer() const { return (wxMacListControl*)m_peer; }
|
|
||||||
|
|
||||||
wxArrayString m_stringArray;
|
|
||||||
wxListDataArray m_dataArray;
|
|
||||||
|
|
||||||
|
wxMacListControl* GetPeer() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// common creation for all databrowser list implementations
|
// from wxItemContainer
|
||||||
wxMacListControl* CreateMacListControl(const wxPoint& pos, const wxSize& size, long style);
|
|
||||||
|
|
||||||
// internal storage for line n has changed, issue a redraw
|
|
||||||
void MacUpdateLine(int n);
|
|
||||||
|
|
||||||
virtual void DoSetSelection(int n, bool select);
|
|
||||||
virtual int DoAppend(const wxString& item);
|
virtual int DoAppend(const wxString& item);
|
||||||
virtual void DoInsertItems(const wxArrayString& items, unsigned int pos);
|
|
||||||
virtual void DoSetItems(const wxArrayString& items, void **clientData);
|
|
||||||
virtual void DoSetFirstItem(int n);
|
|
||||||
virtual void DoSetItemClientData(unsigned int n, void* clientData);
|
virtual void DoSetItemClientData(unsigned int n, void* clientData);
|
||||||
virtual void* DoGetItemClientData(unsigned int n) const;
|
virtual void* DoGetItemClientData(unsigned int n) const;
|
||||||
virtual void DoSetItemClientObject(unsigned int n, wxClientData* clientData);
|
virtual void DoSetItemClientObject(unsigned int n, wxClientData* clientData);
|
||||||
virtual wxClientData* DoGetItemClientObject(unsigned int n) const;
|
virtual wxClientData* DoGetItemClientObject(unsigned int n) const;
|
||||||
virtual void DoSetSize(int x, int y, int width, int height, int sizeFlags = wxSIZE_AUTO);
|
|
||||||
|
// from wxListBoxBase
|
||||||
|
virtual void DoSetSelection(int n, bool select);
|
||||||
|
virtual void DoInsertItems(const wxArrayString& items, unsigned int pos);
|
||||||
|
virtual void DoSetItems(const wxArrayString& items, void **clientData);
|
||||||
|
virtual void DoSetFirstItem(int n);
|
||||||
virtual int DoListHitTest(const wxPoint& point) const;
|
virtual int DoListHitTest(const wxPoint& point) const;
|
||||||
virtual wxSize DoGetBestSize() const;
|
|
||||||
|
|
||||||
// free memory (common part of Clear() and dtor)
|
// free memory (common part of Clear() and dtor)
|
||||||
// prevent collision with some BSD definitions of macro Free()
|
// prevent collision with some BSD definitions of macro Free()
|
||||||
void FreeData();
|
void FreeData();
|
||||||
|
|
||||||
unsigned int m_noItems;
|
virtual wxSize DoGetBestSize() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DECLARE_DYNAMIC_CLASS(wxListBox)
|
DECLARE_DYNAMIC_CLASS(wxListBox)
|
||||||
|
Reference in New Issue
Block a user