]> git.saurik.com Git - wxWidgets.git/blame - include/wx/listbox.h
added Unload(handle); updated the docs
[wxWidgets.git] / include / wx / listbox.h
CommitLineData
2ee3ee1b
VZ
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/listbox.h
3// Purpose: wxListBox class interface
4// Author: Vadim Zeitlin
5// Modified by:
6// Created: 22.10.99
7// RCS-ID: $Id$
8// Copyright: (c) wxWindows team
6c8a980f 9// Licence: wxWindows licence
2ee3ee1b
VZ
10///////////////////////////////////////////////////////////////////////////////
11
34138703
JS
12#ifndef _WX_LISTBOX_H_BASE_
13#define _WX_LISTBOX_H_BASE_
c801d85f 14
2ee3ee1b
VZ
15// ----------------------------------------------------------------------------
16// headers
17// ----------------------------------------------------------------------------
18
af49c4b8 19#if defined(__GNUG__) && !defined(__APPLE__)
2ee3ee1b
VZ
20 #pragma interface "listboxbase.h"
21#endif
22
23#include "wx/defs.h"
24
25#if wxUSE_LISTBOX
26
6c8a980f 27#include "wx/ctrlsub.h" // base class
2ee3ee1b
VZ
28
29// forward declarations are enough here
30class WXDLLEXPORT wxArrayInt;
31class WXDLLEXPORT wxArrayString;
32
33// ----------------------------------------------------------------------------
34// global data
35// ----------------------------------------------------------------------------
36
37WXDLLEXPORT_DATA(extern const wxChar*) wxListBoxNameStr;
38
39// ----------------------------------------------------------------------------
40// wxListBox interface is defined by the class wxListBoxBase
41// ----------------------------------------------------------------------------
42
6c8a980f 43class WXDLLEXPORT wxListBoxBase : public wxControlWithItems
2ee3ee1b
VZ
44{
45public:
fc7a2a60 46 wxListBoxBase() { }
799ea011 47 virtual ~wxListBoxBase();
2ee3ee1b 48
fc7a2a60
VZ
49 // all generic methods are in wxControlWithItems, except for the following
50 // ones which are not yet implemented by wxChoice/wxCombobox
2ee3ee1b
VZ
51 void Insert(const wxString& item, int pos)
52 { DoInsert(item, pos); }
53 void Insert(const wxString& item, int pos, void *clientData)
54 { DoInsert(item, pos); SetClientData(pos, clientData); }
55 void Insert(const wxString& item, int pos, wxClientData *clientData)
56 { DoInsert(item, pos); SetClientObject(pos, clientData); }
57
58 void InsertItems(int nItems, const wxString *items, int pos);
59 void InsertItems(const wxArrayString& items, int pos)
60 { DoInsertItems(items, pos); }
61
62 void Set(int n, const wxString* items, void **clientData = NULL);
63 void Set(const wxArrayString& items, void **clientData = NULL)
64 { DoSetItems(items, clientData); }
65
6c8a980f 66 // multiple selection logic
2ee3ee1b
VZ
67 virtual bool IsSelected(int n) const = 0;
68 virtual void SetSelection(int n, bool select = TRUE) = 0;
6c8a980f 69 virtual void Select(int n) { SetSelection(n, TRUE); }
2ee3ee1b 70 void Deselect(int n) { SetSelection(n, FALSE); }
1e6feb95 71 void DeselectAll(int itemToLeaveSelected = -1);
2ee3ee1b 72
6c8a980f 73 virtual bool SetStringSelection(const wxString& s, bool select = TRUE);
2ee3ee1b 74
6c8a980f
VZ
75 // works for single as well as multiple selection listboxes (unlike
76 // GetSelection which only works for listboxes with single selection)
77 virtual int GetSelections(wxArrayInt& aSelections) const = 0;
2ee3ee1b 78
1e6feb95 79 // set the specified item at the first visible item or scroll to max
2ee3ee1b
VZ
80 // range.
81 void SetFirstItem(int n) { DoSetFirstItem(n); }
82 void SetFirstItem(const wxString& s);
83
1e6feb95
VZ
84 // ensures that the given item is visible scrolling the listbox if
85 // necessary
86 virtual void EnsureVisible(int n);
87
88 // a combination of Append() and EnsureVisible(): appends the item to the
89 // listbox and ensures that it is visible i.e. not scrolled out of view
90 void AppendAndEnsureVisible(const wxString& s);
91
92 // return TRUE if the listbox allows multiple selection
93 bool HasMultipleSelection() const
94 {
95 return (m_windowStyle & wxLB_MULTIPLE) ||
96 (m_windowStyle & wxLB_EXTENDED);
97 }
98
99 // return TRUE if this listbox is sorted
100 bool IsSorted() const { return (m_windowStyle & wxLB_SORT) != 0; }
101
6c8a980f
VZ
102 // emulate selecting or deselecting the item event.GetInt() (depending on
103 // event.GetExtraLong())
104 void Command(wxCommandEvent& event);
2ee3ee1b
VZ
105
106 // compatibility - these functions are deprecated, use the new ones
107 // instead
108 bool Selected(int n) const { return IsSelected(n); }
2ee3ee1b
VZ
109
110protected:
111 // NB: due to wxGTK implementation details, DoInsert() is implemented
112 // using DoInsertItems() and not the other way round
243dbf1a
VZ
113 virtual int DoInsert(const wxString& item, int pos)
114 { InsertItems(1, &item, pos); return pos; }
2ee3ee1b
VZ
115
116 // to be implemented in derived classes
2ee3ee1b
VZ
117 virtual void DoInsertItems(const wxArrayString& items, int pos) = 0;
118 virtual void DoSetItems(const wxArrayString& items, void **clientData) = 0;
119
120 virtual void DoSetFirstItem(int n) = 0;
fc7a2a60
VZ
121
122 DECLARE_NO_COPY_CLASS(wxListBoxBase)
2ee3ee1b
VZ
123};
124
125// ----------------------------------------------------------------------------
126// include the platform-specific class declaration
127// ----------------------------------------------------------------------------
128
1e6feb95
VZ
129#if defined(__WXUNIVERSAL__)
130 #include "wx/univ/listbox.h"
131#elif defined(__WXMSW__)
2ee3ee1b 132 #include "wx/msw/listbox.h"
2049ba38 133#elif defined(__WXMOTIF__)
2ee3ee1b 134 #include "wx/motif/listbox.h"
2049ba38 135#elif defined(__WXGTK__)
2ee3ee1b 136 #include "wx/gtk/listbox.h"
34138703 137#elif defined(__WXMAC__)
2ee3ee1b 138 #include "wx/mac/listbox.h"
1777b9bb 139#elif defined(__WXPM__)
2ee3ee1b 140 #include "wx/os2/listbox.h"
e64df9bc
DE
141#elif defined(__WXCOCOA__)
142 #include "wx/cocoa/listbox.h"
c801d85f
KB
143#endif
144
2ee3ee1b
VZ
145#endif // wxUSE_LISTBOX
146
c801d85f 147#endif
34138703 148 // _WX_LISTBOX_H_BASE_