]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/vlbox.h
1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: interface of wxVListBox
4 // Author: wxWidgets team
6 // Licence: wxWindows license
7 /////////////////////////////////////////////////////////////////////////////
12 wxVListBox is a wxListBox-like control with the following two main
13 differences from a regular wxListBox: it can have an arbitrarily huge
14 number of items because it doesn't store them itself but uses the
15 OnDrawItem() callback to draw them (so it is a virtual listbox) and its
16 items can have variable height as determined by OnMeasureItem() (so it is
17 also a listbox with the lines of variable height).
19 Also, as a consequence of its virtual nature, it doesn't have any methods
20 to append or insert items in it as it isn't necessary to do it: you just
21 have to call SetItemCount() to tell the control how many items it should
22 display. Of course, this also means that you will never use this class
23 directly because it has pure virtual functions, but will need to derive
24 your own class from it (for example, wxHtmlListBox).
26 However it emits the same events as wxListBox and the same event macros may
27 be used with it. Since wxVListBox does not store its items itself, the
28 events will only contain the index, not any contents such as the string of
33 @appearance{vlistbox.png}
35 @see wxSimpleHtmlListBox, wxHtmlListBox
37 class wxVListBox
: public wxVScrolledWindow
41 Default constructor, you must call Create() later.
45 Normal constructor which calls Create() internally.
47 wxVListBox(wxWindow
* parent
, wxWindowID id
= wxID_ANY
,
48 const wxPoint
& pos
= wxDefaultPosition
,
49 const wxSize
& size
= wxDefaultSize
,
50 long style
= 0, const wxString
& name
= wxVListBoxNameStr
);
55 virtual ~wxVListBox();
58 Deletes all items from the control.
63 Creates the control. To finish creating it you also should call
64 SetItemCount() to let it know about the number of items it contains.
66 The only special style which may be used with wxVListBox is
67 @c wxLB_MULTIPLE which indicates that the listbox should support
70 @return @true on success or @false if the control couldn't be created.
72 bool Create(wxWindow
* parent
, wxWindowID id
= wxID_ANY
,
73 const wxPoint
& pos
= wxDefaultPosition
,
74 const wxSize
& size
= wxDefaultSize
, long style
= 0,
75 const wxString
& name
= wxVListBoxNameStr
);
78 Deselects all the items in the listbox. This method is only valid for
79 multi selection listboxes.
81 @return @true if any items were changed, i.e. if there had been any
82 selected items before, or @false if all the items were already
85 @see SelectAll(), Select()
90 Returns the index of the first selected item in the listbox or
91 @c wxNOT_FOUND if no items are currently selected.
93 @a cookie is an opaque parameter which should be passed to the
94 subsequent calls to GetNextSelected(). It is needed in order to allow
95 parallel iterations over the selected items.
97 Here is a typical example of using these functions:
100 unsigned long cookie;
101 int item = hlbox->GetFirstSelected(cookie);
102 while ( item != wxNOT_FOUND )
104 // ... process item ...
105 item = hlbox->GetNextSelected(cookie);
109 This method is only valid for multi selection listboxes.
111 int GetFirstSelected(unsigned long& cookie
) const;
114 Get the number of items in the control.
118 size_t GetItemCount() const;
121 Returns the margins used by the control. The @c x field of the returned
122 point is the horizontal margin and the @c y field is the vertical one.
126 wxPoint
GetMargins() const;
129 Returns the rectangle occupied by this item in physical coordinates.
131 If the item is not currently visible, returns an empty rectangle.
135 wxRect
GetItemRect(size_t item
) const;
138 Returns the index of the next selected item or @c wxNOT_FOUND if there
141 This method is only valid for multi selection listboxes.
143 @see GetFirstSelected()
145 int GetNextSelected(unsigned long& cookie
) const;
148 Returns the number of the items currently selected.
150 It is valid for both single and multi selection controls. In the former
151 case it may only return 0 or 1 however.
153 @see IsSelected(), GetFirstSelected(), GetNextSelected()
155 size_t GetSelectedCount() const;
158 Get the currently selected item or @c wxNOT_FOUND if there is no
161 int GetSelection() const;
164 Returns the background colour used for the selected cells. By default
165 the standard system colour is used.
167 @see wxSystemSettings::GetColour(), SetSelectionBackground()
169 const wxColour
& GetSelectionBackground() const;
172 Returns @true if the listbox was created with @c wxLB_MULTIPLE style
173 and so supports multiple selection or @false if it is a single
176 bool HasMultipleSelection() const;
179 Returns @true if this item is the current one, @false otherwise.
181 The current item is always the same as selected one for the single
182 selection listbox and in this case this method is equivalent to
183 IsSelected() but they are different for multi selection listboxes where
184 many items may be selected but only one (at most) is current.
186 bool IsCurrent(size_t item
) const;
189 Returns @true if this item is selected, @false otherwise.
191 bool IsSelected(size_t item
) const;
194 This method is used to draw the items background and, maybe, a border
197 The base class version implements a reasonable default behaviour which
198 consists in drawing the selected item with the standard background
199 colour and drawing a border around the item if it is either selected or
202 @todo Change this function signature to non-const.
204 virtual void OnDrawBackground(wxDC
& dc
, const wxRect
& rect
, size_t n
) const;
207 This method may be used to draw separators between the lines. The
208 rectangle passed to it may be modified, typically to deflate it a bit
209 before passing to OnDrawItem().
211 The base class version of this method doesn't do anything.
214 The device context to use for drawing.
216 The bounding rectangle for the item.
218 The index of the item.
220 @todo Change this function signature to non-const.
222 virtual void OnDrawSeparator(wxDC
& dc
, wxRect
& rect
, size_t n
) const;
225 Selects or deselects the specified item which must be valid (i.e. not
226 equal to @c wxNOT_FOUND).
228 @return @true if the items selection status has changed or @false
231 This function is only valid for the multiple selection listboxes, use
232 SetSelection() for the single selection ones.
234 bool Select(size_t item
, bool select
= true);
237 Selects all the items in the listbox.
239 @return @true if any items were changed, i.e. if there had been any
240 unselected items before, or @false if all the items were
243 This method is only valid for multi selection listboxes.
245 @see DeselectAll(), Select()
250 Selects all items in the specified range which may be given in any
253 @return @true if the items selection status has changed or @false
256 This method is only valid for multi selection listboxes.
258 @see SelectAll(), Select()
260 bool SelectRange(size_t from
, size_t to
);
263 Set the number of items to be shown in the control.
265 This is just a synonym for wxVScrolledWindow::SetRowCount().
267 virtual void SetItemCount(size_t count
);
271 Set the margins: horizontal margin is the distance between the window
272 border and the item contents while vertical margin is half of the
273 distance between items.
275 By default both margins are 0.
277 void SetMargins(const wxPoint
& pt
);
278 void SetMargins(wxCoord x
, wxCoord y
);
282 Set the selection to the specified item, if it is -1 the selection is
283 unset. The selected item will be automatically scrolled into view if it
284 isn't currently visible.
286 This method may be used both with single and multiple selection
289 void SetSelection(int selection
);
292 Sets the colour to be used for the selected cells background. The
293 background of the standard cells may be changed by simply calling
294 wxWindow::SetBackgroundColour().
296 @note Using a non-default background colour may result in control
297 having an appearance different from the similar native controls
298 and should be avoided in general.
300 @see GetSelectionBackground()
302 void SetSelectionBackground(const wxColour
& col
);
305 Toggles the state of the specified @a item, i.e. selects it if it was
306 unselected and deselects it if it was selected.
308 This method is only valid for multi selection listboxes.
312 void Toggle(size_t item
);
317 The derived class must implement this function to actually draw the
318 item with the given index on the provided DC.
321 The device context to use for drawing.
323 The bounding rectangle for the item being drawn (DC clipping
324 region is set to this rectangle before calling this function).
326 The index of the item to be drawn.
328 @todo Change this function signature to non-const.
330 virtual void OnDrawItem(wxDC
& dc
, const wxRect
& rect
, size_t n
) const = 0;
333 The derived class must implement this method to return the height of
334 the specified item (in pixels).
336 virtual wxCoord
OnMeasureItem(size_t n
) const = 0;