您的位置:首页 > 编程语言

关于List Control控件实现翻页操作的基本代码

2014-07-10 17:10 531 查看
功能效果图:



这是我在自己写一个项目的时候,突然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;

3.添加控件,并通过类向导添加响应函数,核心代码如下:

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);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: