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:
@@ -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();
|
||||||
|
@@ -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);
|
||||||
|
|
||||||
|
@@ -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;
|
||||||
|
@@ -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()
|
||||||
};
|
};
|
||||||
|
@@ -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") );
|
||||||
|
@@ -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") );
|
||||||
|
Reference in New Issue
Block a user