]>
Commit | Line | Data |
---|---|---|
ad486020 | 1 | ///////////////////////////////////////////////////////////////////////////// |
80fdcdb9 | 2 | // Name: wx/generic/listctrl.h |
ad486020 FM |
3 | // Purpose: private definitions of wxListCtrl helpers |
4 | // Author: Robert Roebling | |
5 | // Vadim Zeitlin (virtual list control support) | |
6 | // Id: $Id$ | |
7 | // Copyright: (c) 1998 Robert Roebling | |
8 | // Licence: wxWindows licence | |
9 | ///////////////////////////////////////////////////////////////////////////// | |
10 | ||
11 | #ifndef _WX_GENERIC_LISTCTRL_PRIVATE_H_ | |
12 | #define _WX_GENERIC_LISTCTRL_PRIVATE_H_ | |
13 | ||
14 | #include "wx/defs.h" | |
15 | ||
16 | #if wxUSE_LISTCTRL | |
17 | ||
18 | #include "wx/listctrl.h" | |
19 | #include "wx/selstore.h" | |
4d833b7b VZ |
20 | #include "wx/timer.h" |
21 | #include "wx/settings.h" | |
ad486020 FM |
22 | |
23 | // ============================================================================ | |
24 | // private classes | |
25 | // ============================================================================ | |
26 | ||
27 | //----------------------------------------------------------------------------- | |
28 | // wxColWidthInfo (internal) | |
29 | //----------------------------------------------------------------------------- | |
30 | ||
31 | struct wxColWidthInfo | |
32 | { | |
33 | int nMaxWidth; | |
34 | bool bNeedsUpdate; // only set to true when an item whose | |
35 | // width == nMaxWidth is removed | |
36 | ||
37 | wxColWidthInfo(int w = 0, bool needsUpdate = false) | |
38 | { | |
39 | nMaxWidth = w; | |
40 | bNeedsUpdate = needsUpdate; | |
41 | } | |
42 | }; | |
43 | ||
44 | WX_DEFINE_ARRAY_PTR(wxColWidthInfo *, ColWidthArray); | |
45 | ||
46 | //----------------------------------------------------------------------------- | |
47 | // wxListItemData (internal) | |
48 | //----------------------------------------------------------------------------- | |
49 | ||
50 | class wxListItemData | |
51 | { | |
52 | public: | |
53 | wxListItemData(wxListMainWindow *owner); | |
54 | ~wxListItemData(); | |
55 | ||
56 | void SetItem( const wxListItem &info ); | |
57 | void SetImage( int image ) { m_image = image; } | |
58 | void SetData( wxUIntPtr data ) { m_data = data; } | |
59 | void SetPosition( int x, int y ); | |
60 | void SetSize( int width, int height ); | |
61 | ||
62 | bool HasText() const { return !m_text.empty(); } | |
63 | const wxString& GetText() const { return m_text; } | |
64 | void SetText(const wxString& text) { m_text = text; } | |
65 | ||
66 | // we can't use empty string for measuring the string width/height, so | |
67 | // always return something | |
68 | wxString GetTextForMeasuring() const | |
69 | { | |
70 | wxString s = GetText(); | |
71 | if ( s.empty() ) | |
9a83f860 | 72 | s = wxT('H'); |
ad486020 FM |
73 | |
74 | return s; | |
75 | } | |
76 | ||
77 | bool IsHit( int x, int y ) const; | |
78 | ||
79 | int GetX() const; | |
80 | int GetY() const; | |
81 | int GetWidth() const; | |
82 | int GetHeight() const; | |
83 | ||
84 | int GetImage() const { return m_image; } | |
85 | bool HasImage() const { return GetImage() != -1; } | |
86 | ||
87 | void GetItem( wxListItem &info ) const; | |
88 | ||
89 | void SetAttr(wxListItemAttr *attr) { m_attr = attr; } | |
90 | wxListItemAttr *GetAttr() const { return m_attr; } | |
91 | ||
92 | public: | |
93 | // the item image or -1 | |
94 | int m_image; | |
95 | ||
96 | // user data associated with the item | |
97 | wxUIntPtr m_data; | |
98 | ||
99 | // the item coordinates are not used in report mode; instead this pointer is | |
100 | // NULL and the owner window is used to retrieve the item position and size | |
101 | wxRect *m_rect; | |
102 | ||
103 | // the list ctrl we are in | |
104 | wxListMainWindow *m_owner; | |
105 | ||
106 | // custom attributes or NULL | |
107 | wxListItemAttr *m_attr; | |
108 | ||
109 | protected: | |
110 | // common part of all ctors | |
111 | void Init(); | |
112 | ||
113 | wxString m_text; | |
114 | }; | |
115 | ||
116 | //----------------------------------------------------------------------------- | |
117 | // wxListHeaderData (internal) | |
118 | //----------------------------------------------------------------------------- | |
119 | ||
120 | class wxListHeaderData : public wxObject | |
121 | { | |
122 | public: | |
123 | wxListHeaderData(); | |
124 | wxListHeaderData( const wxListItem &info ); | |
125 | void SetItem( const wxListItem &item ); | |
126 | void SetPosition( int x, int y ); | |
127 | void SetWidth( int w ); | |
128 | void SetState( int state ); | |
129 | void SetFormat( int format ); | |
130 | void SetHeight( int h ); | |
131 | bool HasImage() const; | |
132 | ||
133 | bool HasText() const { return !m_text.empty(); } | |
134 | const wxString& GetText() const { return m_text; } | |
135 | void SetText(const wxString& text) { m_text = text; } | |
136 | ||
137 | void GetItem( wxListItem &item ); | |
138 | ||
139 | bool IsHit( int x, int y ) const; | |
140 | int GetImage() const; | |
141 | int GetWidth() const; | |
142 | int GetFormat() const; | |
143 | int GetState() const; | |
144 | ||
145 | protected: | |
146 | long m_mask; | |
147 | int m_image; | |
148 | wxString m_text; | |
149 | int m_format; | |
150 | int m_width; | |
151 | int m_xpos, | |
152 | m_ypos; | |
153 | int m_height; | |
154 | int m_state; | |
155 | ||
156 | private: | |
157 | void Init(); | |
158 | }; | |
159 | ||
160 | //----------------------------------------------------------------------------- | |
161 | // wxListLineData (internal) | |
162 | //----------------------------------------------------------------------------- | |
163 | ||
164 | WX_DECLARE_LIST(wxListItemData, wxListItemDataList); | |
165 | ||
166 | class wxListLineData | |
167 | { | |
168 | public: | |
169 | // the list of subitems: only may have more than one item in report mode | |
170 | wxListItemDataList m_items; | |
171 | ||
172 | // this is not used in report view | |
173 | struct GeometryInfo | |
174 | { | |
175 | // total item rect | |
176 | wxRect m_rectAll; | |
177 | ||
178 | // label only | |
179 | wxRect m_rectLabel; | |
180 | ||
181 | // icon only | |
182 | wxRect m_rectIcon; | |
183 | ||
184 | // the part to be highlighted | |
185 | wxRect m_rectHighlight; | |
186 | ||
187 | // extend all our rects to be centered inside the one of given width | |
188 | void ExtendWidth(wxCoord w) | |
189 | { | |
190 | wxASSERT_MSG( m_rectAll.width <= w, | |
9a83f860 | 191 | wxT("width can only be increased") ); |
ad486020 FM |
192 | |
193 | m_rectAll.width = w; | |
194 | m_rectLabel.x = m_rectAll.x + (w - m_rectLabel.width) / 2; | |
195 | m_rectIcon.x = m_rectAll.x + (w - m_rectIcon.width) / 2; | |
196 | m_rectHighlight.x = m_rectAll.x + (w - m_rectHighlight.width) / 2; | |
197 | } | |
198 | } | |
199 | *m_gi; | |
200 | ||
201 | // is this item selected? [NB: not used in virtual mode] | |
202 | bool m_highlighted; | |
203 | ||
204 | // back pointer to the list ctrl | |
205 | wxListMainWindow *m_owner; | |
206 | ||
207 | public: | |
208 | wxListLineData(wxListMainWindow *owner); | |
209 | ||
210 | ~wxListLineData() | |
211 | { | |
212 | WX_CLEAR_LIST(wxListItemDataList, m_items); | |
213 | delete m_gi; | |
214 | } | |
215 | ||
476de5ea VZ |
216 | // called by the owner when it toggles report view |
217 | void SetReportView(bool inReportView) | |
218 | { | |
219 | // we only need m_gi when we're not in report view so update as needed | |
220 | if ( inReportView ) | |
221 | { | |
222 | delete m_gi; | |
223 | m_gi = NULL; | |
224 | } | |
225 | else | |
226 | { | |
227 | m_gi = new GeometryInfo; | |
228 | } | |
229 | } | |
230 | ||
ad486020 FM |
231 | // are we in report mode? |
232 | inline bool InReportView() const; | |
233 | ||
234 | // are we in virtual report mode? | |
235 | inline bool IsVirtual() const; | |
236 | ||
237 | // these 2 methods shouldn't be called for report view controls, in that | |
238 | // case we determine our position/size ourselves | |
239 | ||
240 | // calculate the size of the line | |
241 | void CalculateSize( wxDC *dc, int spacing ); | |
242 | ||
243 | // remember the position this line appears at | |
244 | void SetPosition( int x, int y, int spacing ); | |
245 | ||
246 | // wxListCtrl API | |
247 | ||
248 | void SetImage( int image ) { SetImage(0, image); } | |
249 | int GetImage() const { return GetImage(0); } | |
250 | void SetImage( int index, int image ); | |
251 | int GetImage( int index ) const; | |
252 | ||
253 | bool HasImage() const { return GetImage() != -1; } | |
254 | bool HasText() const { return !GetText(0).empty(); } | |
255 | ||
256 | void SetItem( int index, const wxListItem &info ); | |
257 | void GetItem( int index, wxListItem &info ); | |
258 | ||
259 | wxString GetText(int index) const; | |
260 | void SetText( int index, const wxString& s ); | |
261 | ||
262 | wxListItemAttr *GetAttr() const; | |
263 | void SetAttr(wxListItemAttr *attr); | |
264 | ||
265 | // return true if the highlighting really changed | |
266 | bool Highlight( bool on ); | |
267 | ||
268 | void ReverseHighlight(); | |
269 | ||
270 | bool IsHighlighted() const | |
271 | { | |
9a83f860 | 272 | wxASSERT_MSG( !IsVirtual(), wxT("unexpected call to IsHighlighted") ); |
ad486020 FM |
273 | |
274 | return m_highlighted; | |
275 | } | |
276 | ||
277 | // draw the line on the given DC in icon/list mode | |
ed84dc74 | 278 | void Draw( wxDC *dc, bool current ); |
ad486020 | 279 | |
ed84dc74 VZ |
280 | // the same in report mode: it needs more parameters as we don't store |
281 | // everything in the item in report mode | |
ad486020 FM |
282 | void DrawInReportMode( wxDC *dc, |
283 | const wxRect& rect, | |
284 | const wxRect& rectHL, | |
285 | bool highlighted, | |
286 | bool current ); | |
287 | ||
288 | private: | |
289 | // set the line to contain num items (only can be > 1 in report mode) | |
290 | void InitItems( int num ); | |
291 | ||
292 | // get the mode (i.e. style) of the list control | |
293 | inline int GetMode() const; | |
294 | ||
ed84dc74 VZ |
295 | // Apply this item attributes to the given DC: set the text font and colour |
296 | // and also erase the background appropriately. | |
297 | void ApplyAttributes(wxDC *dc, | |
298 | const wxRect& rectHL, | |
299 | bool highlighted, | |
300 | bool current); | |
ad486020 FM |
301 | |
302 | // draw the text on the DC with the correct justification; also add an | |
303 | // ellipsis if the text is too large to fit in the current width | |
304 | void DrawTextFormatted(wxDC *dc, | |
305 | const wxString &text, | |
306 | int col, | |
307 | int x, | |
308 | int yMid, // this is middle, not top, of the text | |
309 | int width); | |
310 | }; | |
311 | ||
312 | WX_DECLARE_OBJARRAY(wxListLineData, wxListLineDataArray); | |
313 | ||
314 | //----------------------------------------------------------------------------- | |
315 | // wxListHeaderWindow (internal) | |
316 | //----------------------------------------------------------------------------- | |
317 | ||
318 | class wxListHeaderWindow : public wxWindow | |
319 | { | |
320 | protected: | |
321 | wxListMainWindow *m_owner; | |
322 | const wxCursor *m_currentCursor; | |
323 | wxCursor *m_resizeCursor; | |
324 | bool m_isDragging; | |
325 | ||
326 | // column being resized or -1 | |
327 | int m_column; | |
328 | ||
329 | // divider line position in logical (unscrolled) coords | |
330 | int m_currentX; | |
331 | ||
332 | // minimal position beyond which the divider line | |
333 | // can't be dragged in logical coords | |
334 | int m_minX; | |
335 | ||
336 | public: | |
337 | wxListHeaderWindow(); | |
338 | ||
339 | wxListHeaderWindow( wxWindow *win, | |
340 | wxWindowID id, | |
341 | wxListMainWindow *owner, | |
342 | const wxPoint &pos = wxDefaultPosition, | |
343 | const wxSize &size = wxDefaultSize, | |
344 | long style = 0, | |
345 | const wxString &name = wxT("wxlistctrlcolumntitles") ); | |
346 | ||
347 | virtual ~wxListHeaderWindow(); | |
348 | ||
349 | void DrawCurrent(); | |
350 | void AdjustDC( wxDC& dc ); | |
351 | ||
352 | void OnPaint( wxPaintEvent &event ); | |
353 | void OnMouse( wxMouseEvent &event ); | |
354 | void OnSetFocus( wxFocusEvent &event ); | |
355 | ||
356 | // needs refresh | |
357 | bool m_dirty; | |
358 | ||
359 | // Update main window's column later | |
360 | bool m_sendSetColumnWidth; | |
361 | int m_colToSend; | |
362 | int m_widthToSend; | |
363 | ||
364 | virtual void OnInternalIdle(); | |
365 | ||
366 | private: | |
367 | // common part of all ctors | |
368 | void Init(); | |
369 | ||
370 | // generate and process the list event of the given type, return true if | |
371 | // it wasn't vetoed, i.e. if we should proceed | |
372 | bool SendListEvent(wxEventType type, const wxPoint& pos); | |
373 | ||
374 | DECLARE_EVENT_TABLE() | |
375 | }; | |
376 | ||
377 | //----------------------------------------------------------------------------- | |
378 | // wxListRenameTimer (internal) | |
379 | //----------------------------------------------------------------------------- | |
380 | ||
381 | class wxListRenameTimer: public wxTimer | |
382 | { | |
383 | private: | |
384 | wxListMainWindow *m_owner; | |
385 | ||
386 | public: | |
387 | wxListRenameTimer( wxListMainWindow *owner ); | |
388 | void Notify(); | |
389 | }; | |
390 | ||
391 | //----------------------------------------------------------------------------- | |
392 | // wxListTextCtrlWrapper: wraps a wxTextCtrl to make it work for inline editing | |
393 | //----------------------------------------------------------------------------- | |
394 | ||
395 | class wxListTextCtrlWrapper : public wxEvtHandler | |
396 | { | |
397 | public: | |
398 | // NB: text must be a valid object but not Create()d yet | |
399 | wxListTextCtrlWrapper(wxListMainWindow *owner, | |
400 | wxTextCtrl *text, | |
401 | size_t itemEdit); | |
402 | ||
403 | wxTextCtrl *GetText() const { return m_text; } | |
404 | ||
64ac3db8 VZ |
405 | // Check if the given key event should stop editing and return true if it |
406 | // does or false otherwise. | |
407 | bool CheckForEndEditKey(const wxKeyEvent& event); | |
408 | ||
93f6e00d VZ |
409 | // Different reasons for calling EndEdit(): |
410 | // | |
411 | // It was called because: | |
412 | enum EndReason | |
413 | { | |
414 | End_Accept, // user has accepted the changes. | |
415 | End_Discard, // user has cancelled editing. | |
416 | End_Destroy // the entire control is being destroyed. | |
417 | }; | |
418 | ||
419 | void EndEdit(EndReason reason); | |
ad486020 FM |
420 | |
421 | protected: | |
422 | void OnChar( wxKeyEvent &event ); | |
423 | void OnKeyUp( wxKeyEvent &event ); | |
424 | void OnKillFocus( wxFocusEvent &event ); | |
425 | ||
426 | bool AcceptChanges(); | |
427 | void Finish( bool setfocus ); | |
428 | ||
429 | private: | |
430 | wxListMainWindow *m_owner; | |
431 | wxTextCtrl *m_text; | |
432 | wxString m_startValue; | |
433 | size_t m_itemEdited; | |
434 | bool m_aboutToFinish; | |
435 | ||
436 | DECLARE_EVENT_TABLE() | |
437 | }; | |
438 | ||
439 | //----------------------------------------------------------------------------- | |
440 | // wxListMainWindow (internal) | |
441 | //----------------------------------------------------------------------------- | |
442 | ||
443 | WX_DECLARE_LIST(wxListHeaderData, wxListHeaderDataList); | |
444 | ||
445 | class wxListMainWindow : public wxWindow | |
446 | { | |
447 | public: | |
448 | wxListMainWindow(); | |
449 | wxListMainWindow( wxWindow *parent, | |
450 | wxWindowID id, | |
451 | const wxPoint& pos = wxDefaultPosition, | |
452 | const wxSize& size = wxDefaultSize, | |
453 | long style = 0, | |
9a83f860 | 454 | const wxString &name = wxT("listctrlmainwindow") ); |
ad486020 FM |
455 | |
456 | virtual ~wxListMainWindow(); | |
457 | ||
476de5ea VZ |
458 | // called by the main control when its mode changes |
459 | void SetReportView(bool inReportView); | |
460 | ||
461 | // helper to simplify testing for wxLC_XXX flags | |
ad486020 FM |
462 | bool HasFlag(int flag) const { return m_parent->HasFlag(flag); } |
463 | ||
464 | // return true if this is a virtual list control | |
465 | bool IsVirtual() const { return HasFlag(wxLC_VIRTUAL); } | |
466 | ||
467 | // return true if the control is in report mode | |
468 | bool InReportView() const { return HasFlag(wxLC_REPORT); } | |
469 | ||
470 | // return true if we are in single selection mode, false if multi sel | |
471 | bool IsSingleSel() const { return HasFlag(wxLC_SINGLE_SEL); } | |
472 | ||
473 | // do we have a header window? | |
474 | bool HasHeader() const | |
475 | { return InReportView() && !HasFlag(wxLC_NO_HEADER); } | |
476 | ||
477 | void HighlightAll( bool on ); | |
478 | ||
479 | // all these functions only do something if the line is currently visible | |
480 | ||
481 | // change the line "selected" state, return true if it really changed | |
482 | bool HighlightLine( size_t line, bool highlight = true); | |
483 | ||
484 | // as HighlightLine() but do it for the range of lines: this is incredibly | |
485 | // more efficient for virtual list controls! | |
486 | // | |
487 | // NB: unlike HighlightLine() this one does refresh the lines on screen | |
488 | void HighlightLines( size_t lineFrom, size_t lineTo, bool on = true ); | |
489 | ||
490 | // toggle the line state and refresh it | |
491 | void ReverseHighlight( size_t line ) | |
492 | { HighlightLine(line, !IsHighlighted(line)); RefreshLine(line); } | |
493 | ||
494 | // return true if the line is highlighted | |
495 | bool IsHighlighted(size_t line) const; | |
496 | ||
497 | // refresh one or several lines at once | |
498 | void RefreshLine( size_t line ); | |
499 | void RefreshLines( size_t lineFrom, size_t lineTo ); | |
500 | ||
501 | // refresh all selected items | |
502 | void RefreshSelected(); | |
503 | ||
504 | // refresh all lines below the given one: the difference with | |
505 | // RefreshLines() is that the index here might not be a valid one (happens | |
506 | // when the last line is deleted) | |
507 | void RefreshAfter( size_t lineFrom ); | |
508 | ||
509 | // the methods which are forwarded to wxListLineData itself in list/icon | |
510 | // modes but are here because the lines don't store their positions in the | |
511 | // report mode | |
512 | ||
513 | // get the bound rect for the entire line | |
514 | wxRect GetLineRect(size_t line) const; | |
515 | ||
516 | // get the bound rect of the label | |
517 | wxRect GetLineLabelRect(size_t line) const; | |
518 | ||
519 | // get the bound rect of the items icon (only may be called if we do have | |
520 | // an icon!) | |
521 | wxRect GetLineIconRect(size_t line) const; | |
522 | ||
523 | // get the rect to be highlighted when the item has focus | |
524 | wxRect GetLineHighlightRect(size_t line) const; | |
525 | ||
526 | // get the size of the total line rect | |
527 | wxSize GetLineSize(size_t line) const | |
528 | { return GetLineRect(line).GetSize(); } | |
529 | ||
530 | // return the hit code for the corresponding position (in this line) | |
531 | long HitTestLine(size_t line, int x, int y) const; | |
532 | ||
533 | // bring the selected item into view, scrolling to it if necessary | |
534 | void MoveToItem(size_t item); | |
535 | ||
536 | bool ScrollList( int WXUNUSED(dx), int dy ); | |
537 | ||
538 | // bring the current item into view | |
539 | void MoveToFocus() { MoveToItem(m_current); } | |
540 | ||
541 | // start editing the label of the given item | |
542 | wxTextCtrl *EditLabel(long item, | |
b19b28c8 | 543 | wxClassInfo* textControlClass = wxCLASSINFO(wxTextCtrl)); |
ad486020 FM |
544 | wxTextCtrl *GetEditControl() const |
545 | { | |
546 | return m_textctrlWrapper ? m_textctrlWrapper->GetText() : NULL; | |
547 | } | |
548 | ||
549 | void ResetTextControl(wxTextCtrl *text) | |
550 | { | |
551 | delete text; | |
552 | m_textctrlWrapper = NULL; | |
553 | } | |
554 | ||
555 | void OnRenameTimer(); | |
556 | bool OnRenameAccept(size_t itemEdit, const wxString& value); | |
557 | void OnRenameCancelled(size_t itemEdit); | |
558 | ||
559 | void OnMouse( wxMouseEvent &event ); | |
560 | ||
561 | // called to switch the selection from the current item to newCurrent, | |
562 | void OnArrowChar( size_t newCurrent, const wxKeyEvent& event ); | |
563 | ||
64ac3db8 | 564 | void OnCharHook( wxKeyEvent &event ); |
ad486020 FM |
565 | void OnChar( wxKeyEvent &event ); |
566 | void OnKeyDown( wxKeyEvent &event ); | |
567 | void OnKeyUp( wxKeyEvent &event ); | |
568 | void OnSetFocus( wxFocusEvent &event ); | |
569 | void OnKillFocus( wxFocusEvent &event ); | |
570 | void OnScroll( wxScrollWinEvent& event ); | |
571 | ||
572 | void OnPaint( wxPaintEvent &event ); | |
573 | ||
574 | void OnChildFocus(wxChildFocusEvent& event); | |
575 | ||
576 | void DrawImage( int index, wxDC *dc, int x, int y ); | |
577 | void GetImageSize( int index, int &width, int &height ) const; | |
ad486020 FM |
578 | |
579 | void SetImageList( wxImageList *imageList, int which ); | |
580 | void SetItemSpacing( int spacing, bool isSmall = false ); | |
581 | int GetItemSpacing( bool isSmall = false ); | |
582 | ||
94248d2e | 583 | void SetColumn( int col, const wxListItem &item ); |
ad486020 FM |
584 | void SetColumnWidth( int col, int width ); |
585 | void GetColumn( int col, wxListItem &item ) const; | |
586 | int GetColumnWidth( int col ) const; | |
587 | int GetColumnCount() const { return m_columns.GetCount(); } | |
588 | ||
589 | // returns the sum of the heights of all columns | |
590 | int GetHeaderWidth() const; | |
591 | ||
592 | int GetCountPerPage() const; | |
593 | ||
594 | void SetItem( wxListItem &item ); | |
595 | void GetItem( wxListItem &item ) const; | |
596 | void SetItemState( long item, long state, long stateMask ); | |
597 | void SetItemStateAll( long state, long stateMask ); | |
598 | int GetItemState( long item, long stateMask ) const; | |
599 | bool GetItemRect( long item, wxRect &rect ) const | |
600 | { | |
601 | return GetSubItemRect(item, wxLIST_GETSUBITEMRECT_WHOLEITEM, rect); | |
602 | } | |
603 | bool GetSubItemRect( long item, long subItem, wxRect& rect ) const; | |
604 | wxRect GetViewRect() const; | |
605 | bool GetItemPosition( long item, wxPoint& pos ) const; | |
606 | int GetSelectedItemCount() const; | |
607 | ||
0fe26008 | 608 | wxString GetItemText(long item, int col = 0) const |
ad486020 FM |
609 | { |
610 | wxListItem info; | |
611 | info.m_mask = wxLIST_MASK_TEXT; | |
612 | info.m_itemId = item; | |
0fe26008 | 613 | info.m_col = col; |
ad486020 FM |
614 | GetItem( info ); |
615 | return info.m_text; | |
616 | } | |
617 | ||
618 | void SetItemText(long item, const wxString& value) | |
619 | { | |
620 | wxListItem info; | |
621 | info.m_mask = wxLIST_MASK_TEXT; | |
622 | info.m_itemId = item; | |
623 | info.m_text = value; | |
624 | SetItem( info ); | |
625 | } | |
626 | ||
627 | wxImageList* GetSmallImageList() const | |
628 | { return m_small_image_list; } | |
629 | ||
630 | // set the scrollbars and update the positions of the items | |
631 | void RecalculatePositions(bool noRefresh = false); | |
632 | ||
633 | // refresh the window and the header | |
634 | void RefreshAll(); | |
635 | ||
636 | long GetNextItem( long item, int geometry, int state ) const; | |
637 | void DeleteItem( long index ); | |
638 | void DeleteAllItems(); | |
639 | void DeleteColumn( int col ); | |
640 | void DeleteEverything(); | |
641 | void EnsureVisible( long index ); | |
642 | long FindItem( long start, const wxString& str, bool partial = false ); | |
643 | long FindItem( long start, wxUIntPtr data); | |
644 | long FindItem( const wxPoint& pt ); | |
645 | long HitTest( int x, int y, int &flags ) const; | |
646 | void InsertItem( wxListItem &item ); | |
94248d2e | 647 | void InsertColumn( long col, const wxListItem &item ); |
ad486020 | 648 | int GetItemWidthWithImage(wxListItem * item); |
b18e2046 | 649 | void SortItems( wxListCtrlCompare fn, wxIntPtr data ); |
ad486020 FM |
650 | |
651 | size_t GetItemCount() const; | |
652 | bool IsEmpty() const { return GetItemCount() == 0; } | |
653 | void SetItemCount(long count); | |
654 | ||
655 | // change the current (== focused) item, send a notification event | |
656 | void ChangeCurrent(size_t current); | |
657 | void ResetCurrent() { ChangeCurrent((size_t)-1); } | |
658 | bool HasCurrent() const { return m_current != (size_t)-1; } | |
659 | ||
660 | // send out a wxListEvent | |
661 | void SendNotify( size_t line, | |
662 | wxEventType command, | |
663 | const wxPoint& point = wxDefaultPosition ); | |
664 | ||
665 | // override base class virtual to reset m_lineHeight when the font changes | |
666 | virtual bool SetFont(const wxFont& font) | |
667 | { | |
668 | if ( !wxWindow::SetFont(font) ) | |
669 | return false; | |
670 | ||
671 | m_lineHeight = 0; | |
672 | ||
673 | return true; | |
674 | } | |
675 | ||
676 | // these are for wxListLineData usage only | |
677 | ||
678 | // get the backpointer to the list ctrl | |
679 | wxGenericListCtrl *GetListCtrl() const | |
680 | { | |
681 | return wxStaticCast(GetParent(), wxGenericListCtrl); | |
682 | } | |
683 | ||
684 | // get the height of all lines (assuming they all do have the same height) | |
685 | wxCoord GetLineHeight() const; | |
686 | ||
687 | // get the y position of the given line (only for report view) | |
688 | wxCoord GetLineY(size_t line) const; | |
689 | ||
690 | // get the brush to use for the item highlighting | |
691 | wxBrush *GetHighlightBrush() const | |
692 | { | |
693 | return m_hasFocus ? m_highlightBrush : m_highlightUnfocusedBrush; | |
694 | } | |
695 | ||
696 | bool HasFocus() const | |
697 | { | |
698 | return m_hasFocus; | |
699 | } | |
700 | ||
701 | protected: | |
702 | // the array of all line objects for a non virtual list control (for the | |
703 | // virtual list control we only ever use m_lines[0]) | |
704 | wxListLineDataArray m_lines; | |
705 | ||
706 | // the list of column objects | |
707 | wxListHeaderDataList m_columns; | |
708 | ||
709 | // currently focused item or -1 | |
710 | size_t m_current; | |
711 | ||
712 | // the number of lines per page | |
713 | int m_linesPerPage; | |
714 | ||
715 | // this flag is set when something which should result in the window | |
716 | // redrawing happens (i.e. an item was added or deleted, or its appearance | |
717 | // changed) and OnPaint() doesn't redraw the window while it is set which | |
718 | // allows to minimize the number of repaintings when a lot of items are | |
719 | // being added. The real repainting occurs only after the next OnIdle() | |
720 | // call | |
721 | bool m_dirty; | |
722 | ||
723 | wxColour *m_highlightColour; | |
724 | wxImageList *m_small_image_list; | |
725 | wxImageList *m_normal_image_list; | |
726 | int m_small_spacing; | |
727 | int m_normal_spacing; | |
728 | bool m_hasFocus; | |
729 | ||
730 | bool m_lastOnSame; | |
731 | wxTimer *m_renameTimer; | |
732 | bool m_isCreated; | |
733 | int m_dragCount; | |
734 | wxPoint m_dragStart; | |
735 | ColWidthArray m_aColWidths; | |
736 | ||
737 | // for double click logic | |
738 | size_t m_lineLastClicked, | |
739 | m_lineBeforeLastClicked, | |
740 | m_lineSelectSingleOnUp; | |
741 | ||
742 | protected: | |
743 | wxWindow *GetMainWindowOfCompositeControl() { return GetParent(); } | |
744 | ||
745 | // the total count of items in a virtual list control | |
746 | size_t m_countVirt; | |
747 | ||
748 | // the object maintaining the items selection state, only used in virtual | |
749 | // controls | |
750 | wxSelectionStore m_selStore; | |
751 | ||
752 | // common part of all ctors | |
753 | void Init(); | |
754 | ||
755 | // get the line data for the given index | |
756 | wxListLineData *GetLine(size_t n) const | |
757 | { | |
9a83f860 | 758 | wxASSERT_MSG( n != (size_t)-1, wxT("invalid line index") ); |
ad486020 FM |
759 | |
760 | if ( IsVirtual() ) | |
761 | { | |
762 | wxConstCast(this, wxListMainWindow)->CacheLineData(n); | |
763 | n = 0; | |
764 | } | |
765 | ||
766 | return &m_lines[n]; | |
767 | } | |
768 | ||
769 | // get a dummy line which can be used for geometry calculations and such: | |
770 | // you must use GetLine() if you want to really draw the line | |
771 | wxListLineData *GetDummyLine() const; | |
772 | ||
773 | // cache the line data of the n-th line in m_lines[0] | |
774 | void CacheLineData(size_t line); | |
775 | ||
776 | // get the range of visible lines | |
777 | void GetVisibleLinesRange(size_t *from, size_t *to); | |
778 | ||
779 | // force us to recalculate the range of visible lines | |
780 | void ResetVisibleLinesRange() { m_lineFrom = (size_t)-1; } | |
781 | ||
782 | // get the colour to be used for drawing the rules | |
783 | wxColour GetRuleColour() const | |
784 | { | |
785 | return wxSystemSettings::GetColour(wxSYS_COLOUR_3DLIGHT); | |
786 | } | |
787 | ||
788 | private: | |
789 | // initialize the current item if needed | |
790 | void UpdateCurrent(); | |
791 | ||
792 | // delete all items but don't refresh: called from dtor | |
793 | void DoDeleteAllItems(); | |
794 | ||
3d167c00 VZ |
795 | // Compute the minimal width needed to fully display the column header. |
796 | int ComputeMinHeaderWidth(const wxListHeaderData* header) const; | |
797 | ||
798 | ||
ad486020 FM |
799 | // the height of one line using the current font |
800 | wxCoord m_lineHeight; | |
801 | ||
802 | // the total header width or 0 if not calculated yet | |
803 | wxCoord m_headerWidth; | |
804 | ||
805 | // the first and last lines being shown on screen right now (inclusive), | |
806 | // both may be -1 if they must be calculated so never access them directly: | |
807 | // use GetVisibleLinesRange() above instead | |
808 | size_t m_lineFrom, | |
809 | m_lineTo; | |
810 | ||
811 | // the brushes to use for item highlighting when we do/don't have focus | |
812 | wxBrush *m_highlightBrush, | |
813 | *m_highlightUnfocusedBrush; | |
814 | ||
815 | // wrapper around the text control currently used for in place editing or | |
816 | // NULL if no item is being edited | |
817 | wxListTextCtrlWrapper *m_textctrlWrapper; | |
818 | ||
819 | ||
820 | DECLARE_EVENT_TABLE() | |
821 | ||
822 | friend class wxGenericListCtrl; | |
823 | }; | |
824 | ||
825 | #endif // wxUSE_LISTCTRL | |
826 | #endif // _WX_GENERIC_LISTCTRL_PRIVATE_H_ |