В моем приложении MFC я добавляю CListCtrl в свой класс View с помощью функции OnCreate(). В этой таблице 10 столбцов и 8 строк. Я хочу поставить флажок во втором столбце.
Мой код
int CTrendView::OnCreate(LPCREATESTRUCT l)
{
m_ctLstCtrl.Create(WS_CHILD | WS_VISIBLE | LVS_REPORT ,listRect, this, IDC_TRENDLISTCTRL);
m_ctLstCtrl.SetExtendedStyle(m_ctLstCtrl.GetExtendedStyle() | LVS_EX_GRIDLINES| LVS_EX_FULLROWSELECT| LVS_EX_ONECLICKACTIVATE );
m_ctLstCtrl.SetBkColor(RGB(255,255,255));
m_ctLstCtrl.SetTextColor(RGB(0,0,0));
m_ctLstCtrl.SetTextBkColor(RGB(255,255,255));
m_ctLstCtrl.InsertColumn(0,_T(""),LVCFMT_LEFT,10);
m_ctLstCtrl.InsertColumn(1,_T("Visible"),LVCFMT_LEFT,50);
m_ctLstCtrl.InsertColumn(2,_T("Status"),LVCFMT_LEFT,50);
m_ctLstCtrl.InsertColumn(3,_T("Color"),LVCFMT_LEFT,50);
m_ctLstCtrl.InsertColumn(4,_T("Object1"),LVCFMT_RIGHT,100);
m_ctLstCtrl.InsertColumn(5,_T("Object2"),LVCFMT_RIGHT,100);
m_ctLstCtrl.InsertColumn(6,_T("Desc"),LVCFMT_RIGHT,100);
m_ctLstCtrl.InsertColumn(7,_T("Value"),LVCFMT_LEFT,100);
m_ctLstCtrl.InsertColumn(8,_T("Low"),LVCFMT_LEFT,100);
m_ctLstCtrl.InsertColumn(9,_T("High"),LVCFMT_LEFT,100);
}
Я использую функцию ниже, чтобы добавить зеленый цвет в третий столбец и четвертый столбец.
void CTrendView::OnCustomdrawMyList ( NMHDR* pNMHDR, LRESULT* pResult )
{
NMLVCUSTOMDRAW* pLVCD = reinterpret_cast<NMLVCUSTOMDRAW*>( pNMHDR );
*pResult = CDRF_DODEFAULT;
switch(pLVCD->nmcd.dwDrawStage)
{
case CDDS_PREPAINT:
*pResult = CDRF_NOTIFYITEMDRAW;
break;
case CDDS_ITEMPREPAINT:
*pResult = CDRF_NOTIFYSUBITEMDRAW;
break;
case (CDDS_ITEMPREPAINT | CDDS_SUBITEM):
{
if (pLVCD->iSubItem == 2 )
pLVCD->clrTextBk = RGB(0, 255, 0);
else
pLVCD->clrTextBk = RGB(255, 255, 255);
}
for(int i=0;i<8;i++)
{
if (pLVCD->nmcd.dwItemSpec == i && pLVCD->iSubItem == 3)
pLVCD->clrTextBk = PenSelect[i];
}
break;
}
}
Для добавления динамических значений для других столбцов я использую одну функцию, вызываемую из OnDraw().
void DrawData(CDC *pDC,int iTagPos,CListCtrl &TagListctrl,CRect rect,int pType,float pScaleLow,float pScaleHigh, int TimeCursorPos,int pFlag,CString stime)
{
int index;
CString sPV, sType;
sType = ".SV";
if (TrendTempSV[TimeCursorPos] != -999999)
{
sPV.Format ("%3.2f",TrendTempSV[TimeCursorPos]);
}
else
sPV.Format ("%s","**.** ");
CString sScaleLow,sScaleHigh,indexno;
sScaleLow.Format ("%4.1f",pScaleLow);
sScaleHigh.Format ("%4.1f", pScaleHigh);
indexno.Format("%d",iTagPos+1);
TagListctrl.SetRedraw( FALSE );
TagListctrl.DeleteItem(iTagPos);
index = TagListctrl.InsertItem(iTagPos,indexno);
TagListctrl.SetItemText(iTagPos,4,"Object");
TagListctrl.SetItemText(iTagPos,5,sName);
TagListctrl.SetItemText(iTagPos,6,sDesc);
TagListctrl.SetItemText(iTagPos,7,sPV);
TagListctrl.SetItemText(iTagPos,8,sScaleLow);
TagListctrl.SetItemText(iTagPos,9,sScaleHigh);
TagListctrl.SetRedraw( TRUE );
}
Я хочу установить флажок в столбце "Видимый". Для этого я включаю | LVS_EX_CHECKBOXES в SetExtendedStyle.
m_ctLstCtrl.SetExtendedStyle(m_ctLstCtrl.GetExtendedStyle() | LVS_EX_CHECKBOXES | LVS_EX_GRIDLINES|
LVS_EX_FULLROWSELECT| LVS_EX_ONECLICKACTIVATE );
Я столкнулся с проблемой ниже, сделав это. Флажок появится в первом столбце с порядковым номером. ListCtrl начинает мерцать, заголовки не видны, только когда я нажимаю где-то в listctrl, каждый заголовок столбца et появляется один за другим, а шестерка listctrl также не такая, как предыдущая. Как мне этого избежать?
Да ... на самом деле я хочу отображать текущее значение в этом элементе управления. Уже в этом коде они использовали CDC для рисования таблицы и разместили эти значения. Вместо этого я хочу иметь элемент управления List вместо рисования таблицы, подобной структуре. А также значения меняются каждые несколько микросекунд. В CView я добавляю CLIstCtrl, поэтому у меня постоянно обновляются значения ... либо мне нужно использовать OnTImer (), либо это. ??





Кроме того, вы можете использовать CListCtrlExt (или CListViewExt), которые не являются настраиваемым отрисовкой !! это означает, что вы можете сохранить стиль ОС без изменений, и вы можете использовать каждый столбец, любой элемент управления, включая кнопку флажка ...