MFC ListCtrl的用法
来源:互联网 发布:在万网买完域名之后 编辑:程序博客网 时间:2024/04/27 16:53
文章转载别人的,写的很全,格式也很好。谢谢。
1. CListCtrl 风格
LVS_ICON: 为每个item显示大图标
LVS_SMALLICON: 为每个item显示小图标
LVS_LIST: 显示一列带有小图标的item
LVS_REPORT: 显示item详细资料
直观的理解:windows资源管理器,“查看”标签下的“大图标,小图标,列表,详细资料”
2. 设置listctrl 风格及扩展风格
LONG lStyle;
lStyle = GetWindowLong(m_list.m_hWnd, GWL_STYLE);//获取当前窗口style
lStyle &= ~LVS_TYPEMASK; //清除显示方式位
lStyle |= LVS_REPORT; //设置style
SetWindowLong(m_list.m_hWnd, GWL_STYLE, lStyle);//设置style
DWORD dwStyle = m_list.GetExtendedStyle();
dwStyle |= LVS_EX_FULLROWSELECT;//选中某行使整行高亮(只适用与report风格的listctrl)
dwStyle |= LVS_EX_GRIDLINES;//网格线(只适用与report风格的listctrl)
dwStyle |= LVS_EX_CHECKBOXES;//item前生成checkbox控件
m_list.SetExtendedStyle(dwStyle); //设置扩展风格
3. 插入数据
m_list.InsertColumn( 0, "ID", LVCFMT_LEFT, 40 );//插入列
m_list.InsertColumn( 1, "NAME", LVCFMT_LEFT, 50 );
int nRow = m_list.InsertItem(0, “11”);//插入行
m_list.SetItemText(nRow, 1, “jacky”);//设置数据
4. 一直选中item
选中style中的Show selection always,或者在上面第2点中设置LVS_SHOWSELALWAYS5. 选中和取消选中一行
int nIndex = 0;
//选中
m_list.SetItemState(nIndex, LVIS_SELECTED|LVIS_FOCUSED, LVIS_SELECTED|LVIS_FOCUSED);
//取消选中
m_list.SetItemState(nIndex, 0, LVIS_SELECTED|LVIS_FOCUSED);
6. 得到listctrl中所有行的checkbox的状态
m_list.SetExtendedStyle(LVS_EX_CHECKBOXES);
CString str;
for(int i=0; i<m_list.GetItemCount(); i++)
{
if( m_list.GetItemState(i, LVIS_SELECTED) == LVIS_SELECTED || m_list.GetCheck(i))
{
str.Format(_T("第%d行的checkbox为选中状态"), i);
AfxMessageBox(str);
}
}
7. 得到listctrl中所有选中行的序号
方法一:
CString str;
for(int i=0; i<m_list.GetItemCount(); i++)
{
if( m_list.GetItemState(i, LVIS_SELECTED) == LVIS_SELECTED )
{
str.Format(_T("选中了第%d行"), i);
AfxMessageBox(str);
}
}
方法二:
POSITION pos = m_list.GetFirstSelectedItemPosition();
if (pos == NULL)
TRACE0("No items were selected!\n");
else
{
while (pos)
{
int nItem = m_list.GetNextSelectedItem(pos);
TRACE1("Item %d was selected!\n", nItem);
// you could do your own processing on nItem here
}
}
8. 得到item的信息
TCHAR szBuf[1024];
LVITEM lvi;
lvi.iItem = nItemIndex;
lvi.iSubItem = 0;
lvi.mask = LVIF_TEXT;
lvi.pszText = szBuf;
lvi.cchTextMax = 1024;
m_list.GetItem(&lvi);
9. 得到listctrl的所有列的header字符串内容
LVCOLUMN lvcol;
char str[256];
int nColNum;
CString strColumnName[4];//假如有4列
nColNum = 0;
lvcol.mask = LVCF_TEXT;
lvcol.pszText = str;
lvcol.cchTextMax = 256;
while(m_list.GetColumn(nColNum, &lvcol))
{
strColumnName[nColNum] = lvcol.pszText;
nColNum++;
}
10. 使listctrl中一项可见,即滚动滚动条
m_list.EnsureVisible(i, FALSE);11. 得到listctrl列数
int nHeadNum = m_list.GetHeaderCtrl()->GetItemCount();12. 删除所有列
方法一:
while ( m_list.DeleteColumn (0))
因为你删除了第一列后,后面的列会依次向上移动。
方法二:
int nColumns = 4;
for (int i=nColumns-1; i>=0; i--)
m_list.DeleteColumn (i);
13. 得到单击的listctrl的行列号
添加listctrl控件的NM_CLICK消息相应函数
void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)
{
// 方法一:
/*
DWORD dwPos = GetMessagePos();
CPoint point( LOWORD(dwPos), HIWORD(dwPos) );
m_list.ScreenToClient(&point);
LVHITTESTINFO lvinfo;
lvinfo.pt = point;
lvinfo.flags = LVHT_ABOVE;
int nItem = m_list.SubItemHitTest(&lvinfo);
if(nItem != -1)
{
CString strtemp;
strtemp.Format("单击的是第%d行第%d列", lvinfo.iItem, lvinfo.iSubItem);
AfxMessageBox(strtemp);
}
*/
// 方法二:
/*
NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;
if(pNMListView->iItem != -1)
{
CString strtemp;
strtemp.Format("单击的是第%d行第%d列",
pNMListView->iItem, pNMListView->iSubItem);
AfxMessageBox(strtemp);
}
*/
*pResult = 0;
}
14. 判断是否点击在listctrl的checkbox上
添加listctrl控件的NM_CLICK消息相应函数
void CTest6Dlg::OnClickList1(NMHDR* pNMHDR, LRESULT* pResult)
{
DWORD dwPos = GetMessagePos();
CPoint point( LOWORD(dwPos), HIWORD(dwPos) );
m_list.ScreenToClient(&point);
LVHITTESTINFO lvinfo;
lvinfo.pt = point;
lvinfo.flags = LVHT_ABOVE;
UINT nFlag;
int nItem = m_list.HitTest(point, &nFlag);
//判断是否点在checkbox上
if(nFlag == LVHT_ONITEMSTATEICON)
{
AfxMessageBox("点在listctrl的checkbox上");
}
*pResult = 0;
}
15. 右键点击listctrl的item弹出菜单
添加listctrl控件的NM_RCLICK消息相应函数
void CTest6Dlg::OnRclickList1(NMHDR* pNMHDR, LRESULT* pResult)
{
NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;
if(pNMListView->iItem != -1)
{
DWORD dwPos = GetMessagePos();
CPoint point( LOWORD(dwPos), HIWORD(dwPos) );
CMenu menu;
VERIFY( menu.LoadMenu( IDR_MENU1 ) );
CMenu* popup = menu.GetSubMenu(0);
ASSERT( popup != NULL );
popup->TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON, point.x, point.y, this );
}
*pResult = 0;
}
16. item切换焦点时(包括用键盘和鼠标切换item时),状态的一些变化顺序
添加listctrl控件的LVN_ITEMCHANGED消息相应函数
void CTest6Dlg::OnItemchangedList1(NMHDR* pNMHDR, LRESULT* pResult)
{
NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;
// TODO: Add your control notification handler code here
CString sTemp;
if((pNMListView->uOldState & LVIS_FOCUSED) == LVIS_FOCUSED &&
(pNMListView->uNewState & LVIS_FOCUSED) == 0)
{
sTemp.Format("%d losted focus",pNMListView->iItem);
}
else if((pNMListView->uOldState & LVIS_FOCUSED) == 0 &&
(pNMListView->uNewState & LVIS_FOCUSED) == LVIS_FOCUSED)
{
sTemp.Format("%d got focus",pNMListView->iItem);
}
if((pNMListView->uOldState & LVIS_SELECTED) == LVIS_SELECTED &&
(pNMListView->uNewState & LVIS_SELECTED) == 0)
{
sTemp.Format("%d losted selected",pNMListView->iItem);
}
else if((pNMListView->uOldState & LVIS_SELECTED) == 0 &&
(pNMListView->uNewState & LVIS_SELECTED) == LVIS_SELECTED)
{
sTemp.Format("%d got selected",pNMListView->iItem);
}
*pResult = 0;
}
17. 改变选中行的颜色
首先是添加以下消息
ON_NOTIFY( NM_CUSTOMDRAW, IDC_LIST1, OnDrawColorForMyList ) //为改变颜色添加的消息
再添加类成员函数,就OK了:
//改变 m_List 控件单行的颜色
void CSSDTDlg::OnDrawColorForMyList( NMHDR *pNmHdr, LRESULT *pResult )
{
NMLVCUSTOMDRAW* pLVCD = reinterpret_cast<NMLVCUSTOMDRAW*>( pNmHdr );
*pResult = CDRF_DODEFAULT;
if ( CDDS_PREPAINT == pLVCD->nmcd.dwDrawStage )
{
*pResult = CDRF_NOTIFYITEMDRAW;
}
else if ( CDDS_ITEMPREPAINT == pLVCD->nmcd.dwDrawStage )
{
*pResult = CDRF_NOTIFYSUBITEMDRAW;
}
else if ( (CDDS_ITEMPREPAINT | CDDS_SUBITEM) == pLVCD->nmcd.dwDrawStage )
{
COLORREF clrNewTextColor, clrNewBkColor;
int nItem = static_cast<int>( pLVCD->nmcd.dwItemSpec );
//选中行显示字体为红色,否则为黑色
if(m_item == nItem) //设置为红色
{
clrNewTextColor = RGB( 255, 0, 0 );
}
else //设置为黑色
{
clrNewTextColor = RGB( 0, 0, 0 );
}
//设置背景色
if( nItem%2 ==0 )
{
clrNewBkColor = RGB( 240, 240, 240 ); //偶数行背景色为灰色
}
else
{
clrNewBkColor = RGB( 255, 255, 255 ); //奇数行背景色为白色
}
pLVCD->clrText = clrNewTextColor;
pLVCD->clrTextBk = clrNewBkColor;
*pResult = CDRF_DODEFAULT;
}
}
// ListCtrlEdit
class ListCtrlEdit : public CEdit
{
DECLARE_DYNAMIC(ListCtrlEdit)
public:
ListCtrlEdit();
virtual ~ListCtrlEdit();
protected:
DECLARE_MESSAGE_MAP()
public:
afx_msg void OnKillFocus(CWnd* pNewWnd);
};
#include "stdafx.h"
#include "MotusConfiguration.h"
#include "ListCtrlEdit.h"
// ListCtrlEdit
IMPLEMENT_DYNAMIC(ListCtrlEdit, CEdit)
ListCtrlEdit::ListCtrlEdit()
{
}
ListCtrlEdit::~ListCtrlEdit()
{
}
BEGIN_MESSAGE_MAP(ListCtrlEdit, CEdit)
ON_WM_KILLFOCUS()
END_MESSAGE_MAP()
// ListCtrlEdit 消息处理程序
void ListCtrlEdit::OnKillFocus(CWnd* pNewWnd)
{
CEdit::OnKillFocus(pNewWnd);
CWnd *pParent = this->GetParent();
::PostMessage(pParent->GetSafeHwnd(), WM_USER_EDIT_END, 0, 0);
}
#include "ListCtrlEdit.h"
// EditAbleListCtrl
class EditAbleListCtrl : public CListCtrl
{
DECLARE_DYNAMIC(EditAbleListCtrl)
public:
EditAbleListCtrl();
virtual ~EditAbleListCtrl();
private:
ListCtrlEdit m_edit;
int nItem; // 当前点击项
int nSubItem; // 当前点击子项
bool m_bEditVisible; // Edit是否可见
void ShowEdit(bool bShow, int nItem, int nSubItem, CRect rcCtrl);
LRESULT OnEditEnd(WPARAM wParam, LPARAM lParam);
protected:
DECLARE_MESSAGE_MAP()
public:
afx_msg void OnCustomDraw(NMHDR *pNMHDR, LRESULT *pResult);
afx_msg void OnHdnBegintrack(NMHDR *pNMHDR, LRESULT *pResult);
afx_msg void OnVScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar);
afx_msg void OnLButtonDblClk(UINT nFlags, CPoint point);
afx_msg void OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar);
virtual BOOL PreTranslateMessage(MSG* pMsg);
};
#include "stdafx.h"
#include "MotusConfiguration.h"
#include "EditAbleListCtrl.h"
// EditAbleListCtrl
IMPLEMENT_DYNAMIC(EditAbleListCtrl, CListCtrl)
//构造函数
EditAbleListCtrl::EditAbleListCtrl() : m_bEditVisible(false), nItem(-1), nSubItem(-1)
{
}
//析构函数
EditAbleListCtrl::~EditAbleListCtrl()
{
}
BEGIN_MESSAGE_MAP(EditAbleListCtrl, CListCtrl)
ON_NOTIFY(HDN_BEGINTRACKA, 0, &EditAbleListCtrl::OnHdnBegintrack)
ON_NOTIFY(HDN_BEGINTRACKW, 0, &EditAbleListCtrl::OnHdnBegintrack)
ON_NOTIFY_REFLECT(NM_CUSTOMDRAW, OnCustomDraw)
ON_WM_VSCROLL()
ON_WM_LBUTTONDBLCLK()
ON_MESSAGE(WM_USER_EDIT_END, OnEditEnd)
ON_WM_HSCROLL()
END_MESSAGE_MAP()
//显示编译对话框
void EditAbleListCtrl::ShowEdit(bool bShow, int nItem, int nSubItem, CRect rcCtrl)
{
m_bEditVisible = bShow;
if (m_edit.m_hWnd == NULL)
{
m_edit.Create(ES_AUTOHSCROLL | WS_CHILD | ES_LEFT | ES_WANTRETURN | WS_BORDER,
CRect(0, 0, 0, 0), this, 1001);
m_edit.ShowWindow(SW_HIDE);
CFont tpFont;
tpFont.CreateStockObject(DEFAULT_GUI_FONT);
m_edit.SetFont(&tpFont);
tpFont.DeleteObject();
}
if (bShow == TRUE)
{
CString cstrItem = GetItemText(nItem, nSubItem);
m_edit.MoveWindow(&rcCtrl);
m_edit.ShowWindow(SW_SHOW);
m_edit.SetWindowText(cstrItem);
m_edit.SetFocus();
m_edit.SetSel(-1);
}
else
m_edit.ShowWindow(SW_HIDE);
}
//垂直滑动水平条
void EditAbleListCtrl::OnVScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
if (m_edit.m_hWnd != NULL && m_bEditVisible)
OnEditEnd(0, 0);
CListCtrl::OnVScroll(nSBCode, nPos, pScrollBar);
}
//结束编译
LRESULT EditAbleListCtrl::OnEditEnd(WPARAM wParam, LPARAM lParam)
{
CString strText;
m_edit.GetWindowText(strText);
SetItemText(nItem, nSubItem, strText);
ShowEdit(false, -1, -1, CRect());
return 0;
}
//双击消息响应函数
void EditAbleListCtrl::OnLButtonDblClk(UINT nFlags, CPoint point)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
CRect rcCtrl;
LVHITTESTINFO lvhti;
lvhti.pt = point;
nItem = SubItemHitTest(&lvhti);
if (nItem == -1)
return;
nSubItem = lvhti.iSubItem;
GetSubItemRect(nItem, nSubItem, LVIR_LABEL, rcCtrl);
if (lvhti.iSubItem == 1)
ShowEdit(TRUE, nItem, nSubItem, rcCtrl);
CListCtrl::OnLButtonDblClk(nFlags, point);
}
//水平滑动响应函数
void EditAbleListCtrl::OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar)
{
// TODO: 在此添加消息处理程序代码和/或调用默认值
if (m_edit.m_hWnd != NULL && m_bEditVisible)
OnEditEnd(0, 0);
CListCtrl::OnHScroll(nSBCode, nPos, pScrollBar);
}
//改变头大小函数
void EditAbleListCtrl::OnHdnBegintrack(NMHDR *pNMHDR, LRESULT *pResult)
{
LPNMHEADER phdr = reinterpret_cast<LPNMHEADER>(pNMHDR);
// TODO: Add your control notification handler code here
if (m_edit.m_hWnd != NULL && m_bEditVisible)
OnEditEnd(0, 0);
*pResult = TRUE;
}
//响应enter按键消息
BOOL EditAbleListCtrl::PreTranslateMessage(MSG* pMsg)
{
// TODO: 在此添加专用代码和/或调用基类
if (pMsg->message == WM_KEYDOWN && pMsg->wParam == VK_RETURN)
{
if (m_edit.m_hWnd != NULL && m_bEditVisible)
OnEditEnd(0, 0);
return TRUE;
}
return CListCtrl::PreTranslateMessage(pMsg);
}
//设置背景色
void EditAbleListCtrl::OnCustomDraw(NMHDR *pNMHDR, LRESULT *pResult)
{
//类型安全转换
NMLVCUSTOMDRAW* pLVCD = reinterpret_cast<NMLVCUSTOMDRAW*>(pNMHDR);
*pResult = 0;
//指定列表项绘制前后发送消息
if (CDDS_PREPAINT == pLVCD->nmcd.dwDrawStage)
{
*pResult = CDRF_NOTIFYITEMDRAW;
}
else if (CDDS_ITEMPREPAINT == pLVCD->nmcd.dwDrawStage)
{
//奇数行
if (pLVCD->nmcd.dwItemSpec % 2)
pLVCD->clrTextBk = RGB(255, 255, 128);
//偶数行
else
pLVCD->clrTextBk = RGB(128, 255, 255);
//继续
*pResult = CDRF_DODEFAULT;
}
}
- MFC ListCtrl的用法
- [MFC]ListCtrl的扩展用法
- VC ++ MFC编程--ListCtrl控件的用法
- VC ++ MFC编程--ListCtrl控件的用法
- VC ++ MFC编程--ListCtrl控件的用法
- MFC学习之 ListCtrl 控件的用法
- VC ++ MFC编程--ListCtrl控件的用法
- MFC-listctrl用法
- mfc listCtrl用法
- MFC-ListCtrl基本用法
- MFC ListCtrl 用法详细举例
- 关于listctrl的用法
- 学习ListCtrl 的用法
- ListCtrl的基本用法
- win32 listctrl 的用法
- MFC中listctrl的使用
- MFC ListCtrl控件的使用
- MFC ListCtrl控件的使用
- LACP学习笔记
- HUST 1588 辗转数对 []【数学】
- 官方侧滑菜单DrawerLayout的简单实现
- PAT A1095. Cars on Campus (30)
- 弄懂SPI接口
- MFC ListCtrl的用法
- 计算组合数
- iOS 10 跳转系统设置
- 信号量(java并发编程实战5.5.4)
- 关于STL模板的使用效率与控制输出时最后不加空格问题
- 设置radio选中
- Android--实现点击一次返回键返回桌面而不是退出应用
- 图解Nosql(hbase)与传统数据库的区别
- python 部分文件、目录操作