程序需要从数据库某一个活动表中,定时取数据,更新界面的列表显示,比如有20条数据(变化),则这20数据 不停的变化,(通过其他程序实现)
方案(1),先在列表中查找,后插入比如每条记录都有一个唯一的编号,查询的时候,首先查找该编号的记录在列表中是否存在,如果存在则找到Item后,直接更新各个列的数据,如
LVFINDINFO lv;
lv.flags=LVFI_STRING;
lv.psz=“关键字”;
int nItem=m_list.FindItem(&lv,-1);
如果Item>0则直接更新数据,用SetItemText(nItem,0,“值1”),。。。。
如果Item<0,则插入一条Item,InsertItem(),然后SetItemText(nItem,0,“”);。。。。
方案2:
每次查询之前,把当前的记录全部删掉,然后在依次插入到列表框中。
//其他方法
//方法1:采用禁止重绘的方法
SetWindowRedraw(hwnd, FALSE);
... add the items ...
SetWindowRedraw(hwnd, TRUE);
方法2:采用锁定窗口,禁止刷新的方法
m_list.LockWindowUpdate()
m_list.SetItemText()
//修改后
m_list.UnlockWindowUpdate()
方法3:采用虚拟列表技术。
每次都把数据先放到一个数组中,然后根据显示的多少更新数据。需要LVN_GETDISPINFO消息
即(OnGetdispinfoList(NMHDR* pNMHDR, LRESULT* pResult))函数,
方法 4:使用内存缓冲技术
虚拟表可以解决,如果数据更新还是大量闪烁,需要进行对OnDraw函数修改,采用memDC可以实现无闪烁方案
方法5:重载一下OnEraseBkgnd(CDC* pDC)函数
重载一下OnEraseBkgnd(CDC* pDC)函数,在背景中把客户区画成白色的试试;如果不行的话,插入数据的时候计算一下数据区的大小,如果数据区覆盖整个客户区,则不画背景。以前是这么做的,1s更新几十条数据还是看不出闪烁的。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/aleonchen/archive/2010/09/28/5911367.aspx