程序需要从数据库某一个活动表中,定时取数据,更新界面的列表显示,比如有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()