added support for item attributes in virtual list control

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@10972 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2001-07-11 16:22:12 +00:00
parent a5f1fd3e33
commit 6c02c32922
6 changed files with 95 additions and 18 deletions

View File

@@ -185,14 +185,16 @@ protected:
// return the icon for the given item // return the icon for the given item
virtual int OnGetItemImage(long item) const; virtual int OnGetItemImage(long item) const;
// return the attribute for the item (may return NULL if none)
virtual wxListItemAttr *OnGetItemAttr(long item) const;
// it calls our OnGetXXX() functions // it calls our OnGetXXX() functions
friend class WXDLLEXPORT wxListMainWindow; friend class WXDLLEXPORT wxListMainWindow;
private: private:
// Virtual function hiding supression // Virtual function hiding supression
void Update(void) virtual void Update() { wxWindowBase::Update(); }
{ wxWindowBase::Update(); }
// create the header window // create the header window
void CreateHeaderWindow(); void CreateHeaderWindow();

View File

@@ -373,6 +373,9 @@ protected:
// return the icon for the given item // return the icon for the given item
virtual int OnGetItemImage(long item) const; virtual int OnGetItemImage(long item) const;
// return the attribute for the item (may return NULL if none)
virtual wxListItemAttr *OnGetItemAttr(long item) const;
private: private:
bool DoCreateControl(int x, int y, int w, int h); bool DoCreateControl(int x, int y, int w, int h);

View File

@@ -657,6 +657,22 @@ void MyListCtrl::OnListKeyDown(wxListEvent& event)
{ {
switch ( event.GetCode() ) switch ( event.GetCode() )
{ {
case 'c':
{
wxListItem info;
info.m_itemId = event.GetIndex();
GetItem(info);
wxListItemAttr *attr = info.GetAttributes();
if ( !attr || !attr->HasTextColour() )
{
info.SetTextColour(*wxCYAN);
SetItem(info);
}
}
break;
case WXK_DELETE: case WXK_DELETE:
DeleteItem(event.GetIndex()); DeleteItem(event.GetIndex());
@@ -708,6 +724,11 @@ int MyListCtrl::OnGetItemImage(long item) const
return 0; return 0;
} }
wxListItemAttr *MyListCtrl::OnGetItemAttr(long item) const
{
return item % 2 ? NULL : (wxListItemAttr *)&m_attr;
}
void MyListCtrl::InsertItemInReportView(int i) void MyListCtrl::InsertItemInReportView(int i)
{ {
wxString buf; wxString buf;

View File

@@ -19,9 +19,13 @@ public:
class MyListCtrl: public wxListCtrl class MyListCtrl: public wxListCtrl
{ {
public: public:
MyListCtrl(wxWindow *parent, const wxWindowID id, const wxPoint& pos, MyListCtrl(wxWindow *parent,
const wxSize& size, long style): const wxWindowID id,
wxListCtrl(parent, id, pos, size, style) const wxPoint& pos,
const wxSize& size,
long style)
: wxListCtrl(parent, id, pos, size, style),
m_attr(*wxCYAN, *wxLIGHT_GREY, wxNullFont)
{ {
} }
@@ -49,6 +53,9 @@ private:
virtual wxString OnGetItemText(long item, long column) const; virtual wxString OnGetItemText(long item, long column) const;
virtual int OnGetItemImage(long item) const; virtual int OnGetItemImage(long item) const;
virtual wxListItemAttr *OnGetItemAttr(long item) const;
wxListItemAttr m_attr;
DECLARE_EVENT_TABLE() DECLARE_EVENT_TABLE()
}; };

View File

@@ -247,7 +247,8 @@ public:
void GetItem( wxListItem &info ) const; void GetItem( wxListItem &info ) const;
wxListItemAttr *GetAttributes() const { return m_attr; } void SetAttr(wxListItemAttr *attr) { m_attr = attr; }
wxListItemAttr *GetAttr() const { return m_attr; }
public: public:
// the item image or -1 // the item image or -1
@@ -384,6 +385,9 @@ public:
wxString GetText(int index) const; wxString GetText(int index) const;
void SetText( int index, const wxString s ); void SetText( int index, const wxString s );
wxListItemAttr *GetAttr() const;
void SetAttr(wxListItemAttr *attr);
// return true if the highlighting really changed // return true if the highlighting really changed
bool Highlight( bool on ); bool Highlight( bool on );
@@ -1475,6 +1479,24 @@ int wxListLineData::GetImage( int index ) const
return item->GetImage(); return item->GetImage();
} }
wxListItemAttr *wxListLineData::GetAttr() const
{
wxListItemDataList::Node *node = m_items.GetFirst();
wxCHECK_MSG( node, NULL, _T("invalid column index in GetAttr()") );
wxListItemData *item = node->GetData();
return item->GetAttr();
}
void wxListLineData::SetAttr(wxListItemAttr *attr)
{
wxListItemDataList::Node *node = m_items.GetFirst();
wxCHECK_RET( node, _T("invalid column index in SetAttr()") );
wxListItemData *item = node->GetData();
item->SetAttr(attr);
}
void wxListLineData::SetAttributes(wxDC *dc, void wxListLineData::SetAttributes(wxDC *dc,
const wxListItemAttr *attr, const wxListItemAttr *attr,
const wxColour& colText, const wxColour& colText,
@@ -1547,11 +1569,10 @@ void wxListLineData::DrawInReportMode( wxDC *dc,
// default font // default font
wxFont font = listctrl->GetFont(); wxFont font = listctrl->GetFont();
// VZ: currently we set the colours/fonts only once, but like this (i.e. // TODO: later we should support setting different attributes for
// using SetAttributes() inside the loop), it will be trivial to // different columns - to do it, just add "col" argument to
// customize the subitems (in report mode) too. // GetAttr() and move this code into the loop below
wxListItemData *item = m_items.GetFirst()->GetData(); wxListItemAttr *attr = GetAttr();
wxListItemAttr *attr = item->GetAttributes();
SetAttributes(dc, attr, colText, font, highlighted); SetAttributes(dc, attr, colText, font, highlighted);
bool hasBgCol = attr && attr->HasBackgroundColour(); bool hasBgCol = attr && attr->HasBackgroundColour();
@@ -2145,6 +2166,7 @@ void wxListMainWindow::CacheLineData(size_t line)
} }
ld->SetImage(listctrl->OnGetItemImage(line)); ld->SetImage(listctrl->OnGetItemImage(line));
ld->SetAttr(listctrl->OnGetItemAttr(line));
} }
wxListLineData *wxListMainWindow::GetDummyLine() const wxListLineData *wxListMainWindow::GetDummyLine() const
@@ -2458,6 +2480,8 @@ void wxListMainWindow::OnPaint( wxPaintEvent &WXUNUSED(event) )
continue; continue;
} }
printf("Redrawing line %u\n", line);
GetLine(line)->DrawInReportMode( &dc, GetLine(line)->DrawInReportMode( &dc,
rectLine, rectLine,
GetLineHighlightRect(line), GetLineHighlightRect(line),
@@ -3365,19 +3389,21 @@ void wxListMainWindow::SetItem( wxListItem &item )
wxCHECK_RET( id >= 0 && (size_t)id < GetItemCount(), wxCHECK_RET( id >= 0 && (size_t)id < GetItemCount(),
_T("invalid item index in SetItem") ); _T("invalid item index in SetItem") );
if ( IsVirtual() ) if ( !IsVirtual() )
{
wxListLineData *line = GetLine((size_t)id);
line->SetItem( item.m_col, item );
}
if ( InReportView() )
{ {
// just refresh the line to show the new value of the text/image // just refresh the line to show the new value of the text/image
RefreshLine((size_t)id); RefreshLine((size_t)id);
} }
else // !virtual else // !report
{ {
// refresh everything (resulting in horrible flicker - FIXME!)
m_dirty = TRUE; m_dirty = TRUE;
wxListLineData *line = GetLine((size_t)id);
if ( HasFlag(wxLC_REPORT) )
item.m_width = GetColumnWidth( item.m_col );
line->SetItem( item.m_col, item );
} }
} }
@@ -4880,6 +4906,15 @@ int wxListCtrl::OnGetItemImage(long item) const
return -1; return -1;
} }
wxListItemAttr *wxListCtrl::OnGetItemAttr(long item) const
{
wxASSERT_MSG( item >= 0 && item < GetItemCount(),
_T("invalid item index in OnGetItemAttr()") );
// no attributes by default
return NULL;
}
void wxListCtrl::SetItemCount(long count) void wxListCtrl::SetItemCount(long count)
{ {
wxASSERT_MSG( IsVirtual(), _T("this is for virtual controls only") ); wxASSERT_MSG( IsVirtual(), _T("this is for virtual controls only") );

View File

@@ -1825,6 +1825,15 @@ int wxListCtrl::OnGetItemImage(long item) const
return -1; return -1;
} }
wxListItemAttr *wxListCtrl::OnGetItemAttr(long item) const
{
wxASSERT_MSG( item >= 0 && (size_t)item < GetItemCount(),
_T("invalid item index in OnGetItemAttr()") );
// no attributes by default
return NULL;
}
void wxListCtrl::SetItemCount(long count) void wxListCtrl::SetItemCount(long count)
{ {
wxASSERT_MSG( IsVirtual(), _T("this is for virtual controls only") ); wxASSERT_MSG( IsVirtual(), _T("this is for virtual controls only") );