CListCtrl大数据显示

 CListCtrl是个很方便的东西,但是当数据大到一个程度(比如说10万条数据),显示速度就会非常的慢。解决办法就是用虚拟列表。

 

  CListCtrl显示数据的原理是将需显示的所有数据拷贝在它内部的一块空间里,然后显示出来。一但数据量过大,拷贝的时间就会延长,显示速度当然也就非常慢了。而虚拟列表则不需要将显示数据拷贝到内部空间,它的做法是当需要显示某个数据时,才将数据拷入内部空间。看上去好像和普通CListCtrl的做法相同,实则大不一样。因为列表一屏的数据,最多也就几百行。也就是说虚拟列表每次最多也就只需要拷贝几百行的数据,对现在计算机的速度而言,速度的延迟是完全可以忽略的。

 

  好了,原理说到这里。接下来该说做怎么做了。

class CVirtaulListCtrl : public CListCtrl { DECLARE_DYNAMIC(CVirtaulListCtrl) public: CVirtaulListCtrl(); virtual ~CVirtaulListCtrl(); public: //导入数据 void ImportData(CStringArray *pDataArray) { m_pDataArray = pDataArray; SetItemCount(m_pDataArray->GetSize()); } protected: CStringArray *m_pDataArray; protected: DECLARE_MESSAGE_MAP() public: afx_msg void OnLvnGetdispinfo(NMHDR *pNMHDR, LRESULT *pResult) { LV_DISPINFO* pDispInfo = (LV_DISPINFO*)pNMHDR; LV_ITEM* pItem= &(pDispInfo)->item; int iItemIndex= pItem->iItem; //行号 int col = pItem->iSubItem; //列号 if(pItem->mask & LVIF_TEXT) { if(col == 0) { //序号 char numberStr[10]; itoa(iItemIndex+1, numberStr, 10); lstrcpyn(pItem->pszText, numberStr, pItem->cchTextMax); } else if(col == 1) { lstrcpyn(pItem->pszText, m_pDataArray->GetAt(iItemIndex), pItem->cchTextMax); } } } }; 

上面一共只有两个函数。一个是ImportData,作用是导入需要显示的数据。里面只有两条语句,第一条为获取数据指针,第二条为设置列表长度(一共有多少条数据)。这个是自定义函数,可以自定义函数名和导入的数据结构。

第二个函数是OnLvnGetdispinfo。这个函数是事件函数,当列表中的一个单元格需显示的时候调用。

使用时,还需要将列表控件的“所有者数据”属性设为“true”。

你可能感兴趣的:(MFC)