功能效果图:
这是我在自己写一个项目的时候,突然List Control如果数据过多,那么在查看的时候就不方便,因此百度找到了 用这一种方式来实现如上的界面的效果
原文地址:点http://mayemfc.blog.163.com/blog/static/214969209201302752654169/
在这儿是访问数据库里面的数据,数据库连接采用odbc
1.创造工程 testDlg,在对话框头文件中定义,四个公有变量
int pageNo; //页数编号
int pageSize; // 每页显示条数
int intStart; // 开始记录
int intEnd; // 结束记录
int max_page; // 记录最大页数
2.在构造函数中初始化
pageSize=10;
pageNo=1;
void CTestDlg::OnBtnFirst() // 第一页
{
if (pageNo == 1)
{
AfxMessageBox(_T("已是第一页"));
}
else
{
pageNo = 1;
m_ctlList.DeleteAllItems();
ListShow();
}
}
void CTestDlg::OnBtnPageup() // 上一页
{
if(pageNo==1)
{
AfxMessageBox(_T("已是第一页"));
}
if(pageNo>1)
{
pageNo--;
m_ctlList.DeleteAllItems();
ListShow();
}
}
void CTestDlg::OnBtnPagedown() // 下一页
{
pageNo++;
if (pageNo > max_page)
{
pageNo--;
AfxMessageBox("已是最后一页");
return;
}
m_ctlList.DeleteAllItems();
ListShow();
}
void CTestDlg::OnBtnLast() // 最后一页
{
if (pageNo == max_page)
{
AfxMessageBox("已是最后一页");
return;
}
else
{
pageNo = max_page;
m_ctlList.DeleteAllItems();
ListShow();
}
}
4.在对话框初始化中设置List Control的风格
5.添加ListShow函数的实现,通过数据库实现
int i_num = 0;
char chrTemp='%';
intStart = pageSize * (pageNo-1);
intEnd = pageSize * pageNo;
try
{
if(testSet.IsOpen())
{
testSet.Close();
}
testSet.m_strFilter.Format("学号 like '%c%s%c' ", chrTemp , "", chrTemp);
testSet.Open(CRecordset::snapshot,NULL,CRecordset::none);
while(!testSet.IsEOF()) // 输出匹配上查询条件用户记录,直到记录为空
{
if (i_num >= intStart && i_num < intEnd) // 根据页数显示相应数据
{
i_num = i_num % pageSize;
CString strTemp;
strTemp.Format("%d",testSet.m_column1);
m_ctlList.InsertItem(i_num,strTemp);
m_ctlList.SetItemText(i_num, 1,testSet.m_column2);
strTemp.Format("%d",testSet.m_column3);
m_ctlList.SetItemText(i_num, 2, strTemp);
strTemp.Format("%d",testSet.m_column4);
m_ctlList.SetItemText(i_num, 3, strTemp);
if (pageNo >= 2) // 当页数为1时,i的值就是其本身,如果页数大于1时,i的值恢复到取余以前
{
i_num += (pageNo -1) * pageSize;
}
}
i_num++;
testSet.MoveNext(); // 记录游标移到下一条记录
}
if (i_num % pageSize == 0)
{
max_page = i_num / pageSize;
}
else
{
max_page = i_num / pageSize + 1;
}
if(testSet.IsOpen()) // 关闭记录集
{
testSet.Close();
}
}
catch(CDBException*e)
{
e->ReportError ();
return;
}
CString strShowPage, strpageNo, strMaxPage;
strpageNo.Format("第 %d 页 ", pageNo);
strMaxPage.Format("共 %d 页", max_page);
strShowPage.Format(strpageNo + strMaxPage);
GetDlgItem(IDC_STATIC_SHOWPAGE)->SetWindowText(strShowPage);