VC改变CListCtrl 表格中文字颜色,和背景颜色。

(1)首先需要自定义一个类,派生自CListCtrl。如下图:

(2)然后在派生类的头文件中声明一个成员函数,如下图:

(3)在源文件中实现该成员方法,如图:

(4)在源文件中做消息映射,如图:

这时候,当CListCtrl控件在绘制的时候,就会有NM_CUSTOMDRAW消息被我们的函数截获。

我们就在实现函数中筛选出CListCtrl控件应该设置内容(文字颜色,文字背景颜色)的时机,对绘制的内容做相应的修改即可。

// ColorListCtrl.cpp : implementation file
//

#include "stdafx.h"
#include "test.h"
#include "ColorListCtrl.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CColorListCtrl

CColorListCtrl::CColorListCtrl()
{
    m_iRow = -1;  //这里我们定义了三个成员变量,分别用于表示单元格的“行号”,“列号”,“字体” 在构造函数中初始化他们。
    m_iCol = -1;
    m_Font = NULL;
}

CColorListCtrl::~CColorListCtrl()
{
    if ( m_Font )    delete m_Font;        //删除字体  析构函数中销毁字体所指对象。
}

BEGIN_MESSAGE_MAP(CColorListCtrl, CListCtrl)
    //{{AFX_MSG_MAP(CColorListCtrl)
        // NOTE - the ClassWizard will add and remove mapping macros here.
    ON_NOTIFY_REFLECT(NM_CUSTOMDRAW,OnNMCustomdraw)   //这里就是消息映射了。
    //}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CColorListCtrl message handlers

void CColorListCtrl::PreSubclassWindow()
{
    // TODO: Add your specialized code here and/or call the base class
    CListCtrl::PreSubclassWindow();
}

void   CColorListCtrl::OnNMCustomdraw(NMHDR   *pNMHDR,   LRESULT   *pResult)   //获取消息后的实现代码。
{
    NMLVCUSTOMDRAW* pLVCD = reinterpret_cast<NMLVCUSTOMDRAW*>( pNMHDR ); //首先声明一个NMLVCUSTOMDRAW结构体的指针pLVCD,关联pNMHDR,为了下面的操作。

    // Take the default processing unless we set this to something else below.
    *pResult = CDRF_DODEFAULT;

    // First thing - check the draw stage. If it‘s the control‘s prepaint
    // stage, then tell Windows we want messages for every item.

    if ( CDDS_PREPAINT == pLVCD->nmcd.dwDrawStage )
    {
        *pResult = CDRF_NOTIFYITEMDRAW;
    }
    else if ( CDDS_ITEMPREPAINT == pLVCD->nmcd.dwDrawStage )
    {
        // This is the notification message for an item. We‘ll request
        // notifications before each subitem‘s prepaint stage.
        *pResult = CDRF_NOTIFYSUBITEMDRAW;
    }
    else if ( (CDDS_ITEMPREPAINT | CDDS_SUBITEM) == pLVCD->nmcd.dwDrawStage ) //仅当pLVCD结构体中nmcd成员的dwDrawStage状态为CDDS_ITEMPREPAINT | CDDS_SUBITEM时
    {                                                                         //我们就可以判断“行”和“列”,从而来设置文字颜色和文字背景颜色了。
        // This is the prepaint stage for a subitem. Here‘s where we set the
        // item‘s text and background colors. Our return value will tell
        // Windows to draw the subitem itself, but it will use the new colors
        // we set here.
        if ( m_iCol == pLVCD->iSubItem && m_iRow == pLVCD->nmcd.dwItemSpec)
        {
            pLVCD->clrTextBk = m_Color;
            pLVCD->clrText = m_TextColor;

            //SetFont(m_Font, false);
        }
        else
        {
            pLVCD->clrTextBk = 16777215;//如果不是选择的“行”和“列”就设置成系统默认的那种颜色。
            pLVCD->clrText = 0;
        }
        //SetFont(m_Font, false);
        // Store the colors back in the NMLVCUSTOMDRAW struct.
        // Tell Windows to paint the control itself.
        *pResult = CDRF_DODEFAULT;
    }
}

void CColorListCtrl::SetColor(int iRow, int iCol, COLORREF color)
{
    m_iRow = iRow;
    m_iCol = iCol;
    m_Color = color;
    /*m_vctRow.push_back(iRow);
    m_vctCol.push_back(iCol);
    m_vctColorValue.push_back(color);*/
}

void CColorListCtrl::SetSubItemFont(LOGFONT font, COLORREF color, long lsize)
{
    if ( m_Font )    delete m_Font;    //删除旧字体
    m_Font = new CFont;
    m_Font->CreateFontIndirect(&font);

    m_TextColor = color;
    m_TextSize = lsize;
}

 最后,要使用的时候(及要改变列表框中文字颜色或文字背景颜色的时候),我们只需要调用这个派生类的对象的这两个Public方法,把颜色传入。如下:

void CTestDlg::OnApply()
{
    // TODO: Add your control notification handler code here
    CString strRow;
    CString strCol;
    GetDlgItem(IDC_EDIT1)->GetWindowText(strRow);
    GetDlgItem(IDC_EDIT2)->GetWindowText(strCol);
    int iRow = atoi(strRow);
    int iCol = atoi(strCol);
//    m_List.SetColor(iRow, iCol, m_color);
    //m_List.SetItemColor(iRow, iCol, m_color);
    m_List.SetColor(iRow, iCol, m_color);
    m_List.SetSubItemFont(m_Font, m_TextColor, m_TextSize);
    Invalidate(TRUE);
}

为了让我们的修改生效,必须调用Invalidate(TRUE);

////////////////////////////////////////////////////////////////////////////////////////////////////////

 

 

/////////////////////////////////////////////////////////////////////////////////////////////////////////

下面代码实现列表框的选择项的颜色修改。。。。。。另一个消息相应函数。

void CXListCtrl::OnNMCustomdraw(NMHDR *pNMHDR, LRESULT *pResult)
{
     /*修改内容:
       改用switch case语句
       case语句中增加了CDDS_ITEMPREPAINT和CDDS_ITEMPOSTPAINT两个状态判断
       同时在改变颜色时增加了一个函数SetItemState
       */
     static BOOL s_bThisItemSelect = FALSE;
     NMLVCUSTOMDRAW* pLVCD = reinterpret_cast<LPNMLVCUSTOMDRAW>(pNMHDR);
     int nItemIndex=pLVCD->nmcd.dwItemSpec; 

     *pResult = CDRF_DODEFAULT;
     switch (pLVCD->nmcd.dwDrawStage)
     {
         case CDDS_PREPAINT:
             *pResult = CDRF_NOTIFYITEMDRAW;
             break;
         case CDDS_ITEMPREPAINT:
             {
                 UINT ordin = pLVCD->nmcd.lItemlParam;
                 s_bThisItemSelect = FALSE;
                 //选中行颜色改变
                 if (GetItemState(nItemIndex,LVIS_SELECTED) == LVIS_SELECTED/*pLVCD->nmcd.uItemState & CDIS_SELECTED*/)
                 {
                     s_bThisItemSelect = TRUE;
                     //增加了下面这个SetItemState函数
                     SetItemState(pLVCD->nmcd.dwItemSpec, 0, LVIS_SELECTED);
                     pLVCD->clrText = RGB(255,255,255)/*m_SelectItemTextColor*/;
                     pLVCD->clrTextBk =RGB(255,128,0)/*m_SelectItemBkColor*/;
                 }            

             *pResult = CDRF_NOTIFYPOSTPAINT;
             }
             break;
             //加了一个状体判断
         case CDDS_ITEMPOSTPAINT:
             if (s_bThisItemSelect)
             SetItemState(pLVCD->nmcd.dwItemSpec, 0xFF, LVIS_SELECTED);
             break;
     }   

}
时间: 2024-07-31 06:29:36

VC改变CListCtrl 表格中文字颜色,和背景颜色。的相关文章

css selection改变文字反选的背景颜色

<style type="text/css"><!--.ai::-moz-selection { background:#cc0000; color:#fff; }.ai::selection { background:#cc0000; color:#fff; }.av::-moz-selection { background:#FFCC00; color:#CC33FF; }.av::selection { background:#FFCC00; color:#CC

[]如何在Windows 10中更改文件夹背景颜色

ini文件.我们甚至可以使用相同的技术将图片设置为文件夹背景. 已有工具可以更改Windows 7中Windows资源管理器背景的颜色,并将图像设置为Windows 7中的文件夹背景,但这些工具与Windows 8引入的新文件管理器不兼容. 由于某些原因,这些文件夹背景更改工具在Windows 10和Windows 8/8中不起作用.1.自从Windows 10发布以来,用户一直在要求我们提出一种将图片设置为文件夹背景或至少更改文件夹背景颜色的方法,我们决定提出本指南. 如果您在Windows

[转]如何在Windows 10中更改文件夹背景颜色

ini文件.我们甚至可以使用相同的技术将图片设置为文件夹背景. 已有工具可以更改Windows 7中Windows资源管理器背景的颜色,并将图像设置为Windows 7中的文件夹背景,但这些工具与Windows 8引入的新文件管理器不兼容. 由于某些原因,这些文件夹背景更改工具在Windows 10和Windows 8/8中不起作用.1.自从Windows 10发布以来,用户一直在要求我们提出一种将图片设置为文件夹背景或至少更改文件夹背景颜色的方法,我们决定提出本指南. 如果您在Windows

iOS中通过设置CSS改变WebView字体大小,颜色,背景颜色

因为WebView自带的属性是不可以改变字体大小颜色这些需求的,只能通过改变css样式,内置来解决.在百度上搜了半天很多不靠谱,现在给出几种解决方案如下: 1.第一种方式:在WebView的代理方法webViewDidFinishLoad中: 字体大小: [webView stringByEvaluatingJavaScriptFromString:@"document.getElementsByTagName('body')[0].style.webkitTextSizeAdjust= '12

xml中设置button的背景颜色

在画几个设置界面,用到了button控件,对于button空间的背景色在不同状态下的颜色改变方法,做了一下尝试,发现了两种背景颜色改变的方法,就总结了下. 方法一尝试了好多遍才好,要点在于,在selector中android:drawable="@drawable/button_focus"引号中为xml文件,此xml文件为color类型,且在此color xml文件中 <color xmlns:android="http://schemas.android.com/a

Android RadioGroup的RadioButton 选择改变字体颜色和背景颜色

RadioGroup <RadioGroup android:id="@+id/client_charge_radiogroup" android:layout_width="200dp" android:layout_height="40dp" android:layout_marginLeft="5dp" android:layout_alignParentRight="true" android

RadioGroup 的 RadioButton 选择改变字体颜色和背景颜色

RadioGroup [html] view plaincopy <RadioGroup android:id="@+id/client_charge_radiogroup" android:layout_width="200dp" android:layout_height="40dp" android:layout_marginLeft="5dp" android:layout_alignParentRight=&q

QStandardItemModel中设置项目的背景颜色

如何根据内容显示不同的背景颜色? 参照ECMWF的Metview源码实现. Qt的Model中不同类型的数据用role区分,Qt的宏ItemDataRole提供了一些角色: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 enum ItemDataRole { DisplayRole = 0, DecorationRole = 1, EditRole = 2, ToolT

Delphi FMX 如何改变TButton, TSpeedButton中自带图标的颜色

在FMX框架中, TButton 和 TSpeedButton区别非常小,甚至通过设置StyleLookup为相同的外观样式后,几乎是一模一样的. 在移动开发中,如果需要实现一个返回功能的按钮,我们可以添加一个TButton,设置StyleLookup为backtoolbutton(这里的名称是RAD Studio 10.1 berlin版本的,其他版本可能稍微不同),这时候按钮的外观已经变成一个返回箭头,FMX内置了各种各样的StyleLookup,可以满足日常开发的基本需要. 添加完按钮并改