前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >用vc++做滚动条控件

用vc++做滚动条控件

作者头像
用户1154259
发布2018-01-17 15:53:21
6900
发布2018-01-17 15:53:21
举报

  首先用应用向导产生一名为scro的基于对话框的应用,再利用对话框编辑器加入两个一样的水平滚动条,两个滚动条的id分别取idc—scr1和idc—scr2,结果如下图,将其作为本文的示例。

  对话框编辑器虽然允许将滚动条控件加进对话框中,而且,类向导允许加入数据成员,但要使这两个水平滚动条工作,还必须加进一些代码。就本例程序,当用户拖动滚动块或用鼠标滚动箭头时,滚动条就会向对话框发送WM_HSCROLL消息,对话框消息控制函数必须对这一消息进行处理,然后将滚动块定位到相应的位置上。   一般情况下,对话框中的每一控件都有自己独立的消息控制函数,但滚动条控件则有点不同,因为对话框中所有的水平滚动条都只有一个WM_HSCROLL消息控制函数,而所有的垂直滚动条都只有一个WM_HSCROLL消息控制函数。如果对话框中只有一个水平(或垂直)滚动条,则不会出现什么问题,问题是本例程序有一特殊之处,笔者有意设置了两个水平滚动条,可按前述都用一个WM_HSCROLL消息控制函数,所以程序必须能识别出哪个滚动条在发送消息。下面是具体步骤。 1.定义滚动范围的最大值和最小值。   在scrodlg.h类声明中的最上面加入下面两行。

代码语言:javascript
复制
  enum {nmin=0};
  enum {nmax=100};

2.修改oninitdialog函数,初始化滚动范围,决定那一个滚动条发送消息。

代码语言:javascript
复制
// todo: add extra initialization here
  cscrollbar* psb = (cscrollbar*) getdlgitem(idc—scr1);
  psb-〉setscrollrange(nmin, nmax);
  psb = (cscrollbar*) getdlgitem(idc_scr2);
  psb-〉setscrollrange(nmin, nmax);

3.利用classwizard在cscrodlg中加入滚动条消息控制函数,即选择wm—hscroll消息,然后加进onhscroll成员函数,并在其中加入如下代码:

代码语言:javascript
复制
  void cscrodlg::onhscroll(uint nsbcode, uint npos, cscrollbar* pscrollbar) 
  {// todo: add your message handler code here and/or call default
    int ntemp1, ntemp2;
    ntemp1 = pscrollbar-〉getscrollpos();
    switch(nsbcode) 
    { 
      case sb—thumbposition:
         pscrollbar-〉setscrollpos(npos);
         break;
      case sb—lineleft: // 左按钮
         ntemp2 = (nmax - nmin) / 10; //划为10等份
         if ((ntemp1 - ntemp2) 〉 nmin) 
         {
            ntemp1 -= ntemp2; 
         }
         else 
         { 
            ntemp1 = nmin; 
         }
         pscrollbar-〉setscrollpos(ntemp1);
         break;
      case sb—lineright: // 右箭头按钮
         ntemp2 = (nmax - nmin) / 10;
         if ((ntemp1 + ntemp2) 〈 nmax) 
         {
             ntemp1 += ntemp2; 
         }
         else 
         {
             ntemp1 = nmax; 
         }
         pscrollbar-〉setscrollpos(ntemp1);
         break; 
    }
    cdialog::onhscroll(nsbcode, npos, pscrollbar);}

4.现在可以编译、测试程序了。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2012-10-30 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档