CListCtrl控件使用指南(大全)

-------------------------------------------------------------------------------------------------------------------------------------------

本文主要介绍的是MFC中一个重要的控件CListCtrl,其使用范围广,很多软件中都能看到CListCtrl的身影。当然,一些基本的概念和操作MSDN有相关说明,这里汇总并整理了网上一些比较实用的实际操作,每一个都有对应简单案例。

CListCtrl有四种样式:Icon;Smal lcon;List;Report。前三种一般使用很少,最后一种Report是CListCtrl的重点,也是其精髓。

-------------------------------------------------------------------------------------------------------------------------------------------


一、CListCtrl外观风格

只能选下面四种的一种:

      LVS_ICON: 为每个item显示大图标;
      LVS_SMALLICON: 为每个item显示小图标;
      LVS_LIST: 显示一列带有小图标的item;
      LVS_REPORT: 显示item详细资料。
      直观的理解:windows资源管理器,【查看】标签下的“大图标,小图标,列表,详细信息”


先来说一下前三种使用方法:

前三种Icon,Small Icon,List都是通过图标的形式存在,那么他的重点也就是怎么加载图标。

首先需要创建CImageList对象,例如m_ImageList1

//创建大图标,Craete创建一个图标列表,当然大小可以随意设置,这里采用的是加载ICON
if ( m_ImageList1.GetSafeHandle() == NULL )
{
    m_ImageList1.Create(80,80,ILC_MASK|ILC_COLOR32, 0, 0);
    m_ImageList1.Add(AfxGetApp()->LoadIcon(IDR_MAINFRAME));
    m_ListCtrl1.SetImageList(&m_ImageList1, LVSIL_NORMAL);
}
//加载BMP图片
if (m_StatusImage.GetSafeHandle()==NULL)
{
     CBitmap Image;
     BITMAP ImageInfo;
     Image.LoadBitmap(IDB_SERVER_LIST_IMAGE);
     Image.GetBitmap(&ImageInfo);
     m_StatusImage.Create(18,ImageInfo.bmHeight,ILC_COLOR16|ILC_MASK,0,0);
     m_StatusImage.Add(&Image,RGB(255,0,255));
}
m_ListCtrl2.SetImageList(&m_StatusImage,LVSIL_SMALL);
m_ListCtrl3.SetImageList(&m_StatusImage,LVSIL_SMALL);
//插入节点
for (int i=0;i<40;i++)
{
    m_ListCtrl1.InsertItem(i, TEXT("Item"));
    m_ListCtrl2.InsertItem(i, TEXT("Item"));
    m_ListCtrl3.InsertItem(i, TEXT("Item"));
}



二、下面大篇幅主要介绍Report风格


1、创建列

也就是为标头控件添加节点,用InsertColumn()函数。

①参数1:新列的索引。 ②参数2:列标题的显示文本。③列的对齐方式;它的值可以是下面三个之一:LVCFMT_LEFT、 LVCFMT_RIGHT或 LVCFMT_CENTER。④参数4:列的宽度,以像素为单位。

//插入三个列
m_ListCtrl4.InsertColumn( 0, TEXT("姓名"), LVCFMT_LEFT, 70 );
m_ListCtrl4.InsertColumn( 1, TEXT("年龄"), LVCFMT_LEFT, 70 );
m_ListCtrl4.InsertColumn( 2, TEXT("学号"), LVCFMT_LEFT, 70 );




2、设置列表风格

          之前我们修改窗口属性的时候都是使用的SetWindowLong函数或者ModifyStyle,这次CListCtrl为我们提供一个新函数,SetExtendedStyle,当然通过它只能修改列表的扩展属性。
支持的扩展属性很多,但是常用的就几个而已,其他的可以参照msdn,这里讲解两个常用的样式
LVS_EX_CHECKBOXES:将CListCtrl添加复选框check控件

LVS_EX_FULLROWSELECT:未添加该样式,选择一个节点,默认只能选中节点的第一个元素,而这个属性则可以让选择节点的时候选中整行。
当然这些属性可以通过或运算而多个同时存在。

    LONG lStyle;
    lStyle = GetWindowLong(m_ListCtrl4.m_hWnd, GWL_STYLE);//获取当前窗口style
    lStyle &= ~LVS_TYPEMASK; //清除显示方式位
    lStyle |= LVS_REPORT; //设置style
    SetWindowLong(m_ListCtrl4.m_hWnd, GWL_STYLE, lStyle);//设置style
 
    DWORD dwStyle = m_ListCtrl4.GetExtendedStyle();
    dwStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl)
    dwStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl)
    dwStyle |= LVS_EX_CHECKBOXES;//item前生成checkbox控件
    m_ListCtrl4.SetExtendedStyle(dwStyle); //设置扩展风格

样式风格大全:

LVS_ALIGNLEFT : 用来确定表项的大小图标以左对齐方式显示; 
LVS_ALIGNTOP : 用来确定表项的大小图标以顶对齐方式显示; 
LVS_AUTOARRANGE : 用来确定表项的大小图标以自动排列方式显示; 
LVS_EDITLABELS : 设置表项文本可以编辑,父窗口必须设有LVN_ENDLABELEDIT风格; 
LVS_ICON : 用来确定大图标的显示方式; 
LVS_LIST : 用来确定列表方式显示; 
LVS_NOCOLUMNHEADER : 用来确定在详细资料方式时不显示列表头; 
LVS_NOLABELWRAP : 用来确定以单行方式显示图标的文本项; 
LVS_NOSCROLL : 用来屏蔽滚动条; 
LVS_NOSORTHEADER : 用来确定列表头不能用作按钮功能; 
LVS_OWNERDRAWFIXED : 在详细列表方式时允许自绘窗口; 
LVS_REPORT : 用来确定以详细资料即报告方式显示; 
LVS_SHAREIMAGELISTS : 用来确定共享图像列表方式; 
LVS_SHOWSELALWAYS : 用来确定一直显示被选中表项方式; 
LVS_SINGLESEL : 用来确定在某一时刻只能有一项被选中&

  • 7
    点赞
  • 78
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
CListCtrl 控件的表头默认只能显示一行,如果需要实现多行显示,可以通过继承 CHeaderCtrl 类并重写其 OnPaint 函数来实现。 具体实现步骤如下: 1. 定义一个新的类,继承自 CHeaderCtrl 类。 2. 在该类的头文件中添加一个变量,用于保存每个表头项的高度。 3. 在该类的构造函数中,设置表头的高度并获取每个表头项的高度。 4. 重写 OnPaint 函数,绘制多行表头。 下面是一个示例代码: ```cpp class CMultiLineHeaderCtrl : public CHeaderCtrl { public: CMultiLineHeaderCtrl(); virtual ~CMultiLineHeaderCtrl(); protected: int m_nHeaderHeight; // 表头高度 CArray<int, int> m_arrHeaderItemHeight; // 表头项高度 afx_msg void OnPaint(); DECLARE_MESSAGE_MAP() }; CMultiLineHeaderCtrl::CMultiLineHeaderCtrl() { m_nHeaderHeight = 50; // 设置表头高度 for (int i = 0; i < GetItemCount(); i++) { HDITEM hdi; hdi.mask = HDI_HEIGHT; GetItem(i, &hdi); m_arrHeaderItemHeight.Add(hdi.cy); // 获取每个表头项的高度 } } CMultiLineHeaderCtrl::~CMultiLineHeaderCtrl() { } BEGIN_MESSAGE_MAP(CMultiLineHeaderCtrl, CHeaderCtrl) ON_WM_PAINT() END_MESSAGE_MAP() void CMultiLineHeaderCtrl::OnPaint() { CPaintDC dc(this); CRect rc; GetClientRect(&rc); // 绘制表头背景 CBrush brush(GetSysColor(COLOR_3DFACE)); dc.FillRect(rc, &brush); // 绘制表头项 int nOffset = 0; for (int i = 0; i < GetItemCount(); i++) { HDITEM hdi; TCHAR szText[255]; hdi.mask = HDI_TEXT | HDI_FORMAT; hdi.pszText = szText; hdi.cchTextMax = sizeof(szText) / sizeof(TCHAR); GetItem(i, &hdi); // 计算表头项的矩形区域 CRect rcItem(nOffset, 0, nOffset + GetColumnWidth(i), m_arrHeaderItemHeight[i]); // 绘制表头项的背景 CBrush brushItem(GetSysColor(COLOR_BTNFACE)); dc.FillRect(rcItem, &brushItem); // 绘制表头项的文本 dc.SetBkMode(TRANSPARENT); dc.DrawText(szText, -1, rcItem, DT_CENTER | DT_SINGLELINE | DT_VCENTER); // 更新表头项的位置偏移量 nOffset += GetColumnWidth(i); } // 绘制表头分隔线 nOffset = 0; for (int i = 0; i < GetItemCount() - 1; i++) { CRect rcDivider(nOffset + GetColumnWidth(i) - 1, 0, nOffset + GetColumnWidth(i), m_nHeaderHeight); dc.FillRect(rcDivider, &brush); nOffset += GetColumnWidth(i); } } ``` 在使用该类的时候,只需要将 CListCtrl 控件的表头替换为 CMultiLineHeaderCtrl 控件即可实现多行表头的显示: ```cpp CMultiLineHeaderCtrl* pHeaderCtrl = new CMultiLineHeaderCtrl(); pHeaderCtrl->SubclassDlgItem(IDC_LIST_HEADER, this); ``` 其中,IDC_LIST_HEADER 是 CListCtrl 控件的表头控件的 ID。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值