list列表可编辑状态

有时候list需要修改或选择属性,mfc自带的只能显示内容,基本上是不可以修改,为了实现这个功能需求,需要完成一下步骤转换.

第一步记录选择的单元格.
第二步创建一个编辑框CComboBox对象,
设置字体,窗口属性.
第三步获取选中单元格的位置信息.
第四步获取单元格内容信息.
第五步在编辑框上显示,把编辑框显示在单元格上,这样单元格就变成可编辑状态.

这样我们就完成了动态创建,编辑功能,还需要一个函数执行动态创建的销毁回收功能.

void createCobox(NM_LISTVIEW *pEditCtrl, CComboBox *createdit, int &Item, int &SubItem, bool &havecreat)//创建单元格编辑框函数

{
Item = pEditCtrl->iItem;//将点中的单元格的行赋值给“刚编辑过的行”以便后期处理
SubItem = pEditCtrl->iSubItem;//将点中的单元格的行赋值给“刚编辑过的行”以便后期处理
createdit->Create(WS_CHILD | WS_VISIBLE | CBS_DROPDOWN | CBS_OEMCONVERT,
CRect(0, 0, 0, 0), this, IDC_COMBO1);//创建编辑框对象,IDC_EDIT_CREATEID为控件ID号3000,在Resource.h中定义
havecreat = true;
createdit->SetFont(this->GetFont(), FALSE);//设置字体,不设置这里的话上面的字会很突兀的感觉
createdit->SetParent(&m_showMeasureResult);//将list control设置为父窗口,生成的Edit才能正确定位,这个也很重要
CRect EditRect;
m_showMeasureResult.GetSubItemRect(m_Row,m_Col, LVIR_LABEL, EditRect);//获取单元格的空间位置信息
EditRect.SetRect(EditRect.left+1, EditRect.top+1, EditRect.left + m_showMeasureResult.GetColumnWidth(m_Col)-1, EditRect.bottom-1);//+1和-1可以让编辑框不至于挡住列表框中的网格线
CString strItem = m_showMeasureResult.GetItemText(m_Row,m_Col);//获得相应单元格字符
createdit->SetWindowText(strItem);//将单元格字符显示在编辑框上
createdit->MoveWindow(&EditRect);//将编辑框位置放在相应单元格上
createdit->ShowWindow(SW_SHOW);//显示编辑框在单元格上面

void distroyCombox(CListCtrl list, CComboBox distroyedit, int &Item, int &SubItem)//销毁单元格编辑框对象
{
CString meditdata;
distroyedit->GetWindowText(meditdata);
list->SetItemText(Item, SubItem, meditdata);//获得相应单元格字符
distroyedit->DestroyWindow();//销毁对象,有创建就要有销毁,不然会报错

}

在list的单击函数中响应,我们的创建函数,就可以实现list可编辑,
在这里插入图片描述

void OnNMClickListshowMeasure(NMHDR *pNMHDR, LRESULT *pResult)
{
// TODO: Add your control notification handler code here

NM_LISTVIEW  * pEditCtrl = (NM_LISTVIEW *)pNMHDR;


printf("行:%d,列:%d\n",pEditCtrl->iItem,pEditCtrl->iSubItem);
	if((pEditCtrl->iItem >= 0&&pEditCtrl->iSubItem==0)||pEditCtrl->iItem == -1)//点击到非工作区
{
	if (m_haveeditcreate == true)//如果之前创建了编辑框就销毁掉
	{
		distroyCombox(&m_showMeasureResult,&m_combox,m_Row,m_Col);//销毁单元格编辑对象
		m_haveeditcreate = false;
	}
	return;
}
}

*pResult = 0;
}
最后焦点的处理设置,否则会异常
void OnKillfocusCcomboBox()
{

if (m_haveeditcreate == true )//如果之前创建了下拉列表框就销毁掉
{
	distroyCombox(&m_showMeasureResult, &m_combox, m_Row, m_Col);
	m_haveeditcreate = false ;
}

}

猜你喜欢

转载自blog.csdn.net/u011637657/article/details/135718125