设置LISTControl控件某一行的背景和文字颜色
定义宏
用listcontrol的SetItemData设置某一行的属性,通过自定义属性标识实现。
自定义某行内容颜色属性:
#define COLOR_DEFAULT 0 //默认颜色
#define COLOR_RED 1 //红色
#define COLOR_BLUE 2 //蓝色
定义消息
调用BOOL SetItemData(In int nItem, In DWORD_PTR dwData);
其中nItem为某行位置,下标以0开始,dwData可为自定义颜色属性。
然后在LISTControl控件中的NM_CUSTOMDRAW事件中处理。
void CListControlExampleDlg::OnNMCustomdrawList1(NMHDR *pNMHDR, LRESULT *pResult)
{
LPNMTVCUSTOMDRAW pNMCD = reinterpret_cast<LPNMTVCUSTOMDRAW>(pNMHDR);
// TODO: 在此添加控件通知处理程序代码
NMCUSTOMDRAW nmCustomDraw = pNMCD->nmcd;
switch(nmCustomDraw.dwDrawStage)
{
case CDDS_ITEMPREPAINT:
{
if (COLOR_BLUE == nmCustomDraw.lItemlParam)
{
pNMCD->clrTextBk = RGB(51, 153, 255);
pNMCD->clrText = RGB(255, 255, 255);
}
else if (COLOR_RED == nmCustomDraw.lItemlParam)
{
pNMCD->clrTextBk = RGB(255, 0, 0); //背景颜色
pNMCD->clrText = RGB(255, 255, 255); //文字颜色
}
else if (COLOR_DEFAULT == nmCustomDraw.lItemlParam)
{
pNMCD->clrTextBk = RGB(255, 255, 255);
pNMCD->clrText = RGB(0, 0, 0);
}
else
{
//
}
break;
}
default:
{
break;
}
}
*pResult = 0;
*pResult |= CDRF_NOTIFYPOSTPAINT; //必须有,不然就没有效果
*pResult |= CDRF_NOTIFYITEMDRAW; //必须有,不然就没有效果
return;
}
调用方法
void CListControlExampleDlg::OnBnClickedButton1()
{
// TODO: 在此添加控件通知处理程序代码
m_lstControl.SetItemData(0, COLOR_BLUE);
m_lstControl.SetItemData(1, COLOR_DEFAULT);
return;
}
void CListControlExampleDlg::OnBnClickedButton2()
{
// TODO: 在此添加控件通知处理程序代码
m_lstControl.SetItemData(0, COLOR_DEFAULT);
m_lstControl.SetItemData(1, COLOR_RED);
return;
}
参考
mfc中设置listcontrol某一行的背景和文字颜色