MFC经常使用控件之滚动条

近期学习了鸡啄米大神的博客,对其中的一些知识点作了一些本身的总结。不过,博客内容大部分来自鸡啄米。所以,这个博客算是转载博客,只是加了一些我本身的理解而已。若想学习鸡啄米大神的博客总结,请点击链接:http://www.jizhuomi.com/software/257.htmlhtml

1.滚动条分为水平滚动条(Horizontal Scroll Bar)和垂直滚动条(Vertical Scroll Bar)两种.  MFC也为滚动条控件的操做提供了类,即为CScrollBar类。像列表框和组合框设置了WS_HSCROLL 或WS_VSCROLL风格之后出现的滚动条,不是一个独立的窗口,而是这些窗口的一部分,这就是标准滚动条。而滚动条控件是一个独立的窗口,它能够得到焦点,响应某些操做。
ide

2.建立滚动条:
virtual BOOL Create(
   DWORD dwStyle,
   const RECT& rect,
   CWnd* pParentWnd,
   UINT nID
);
下面针对dwStyle参数进行详细讲解:
    SBS_HORZ:指定滚动条为水平滚动条。若是没有指定SBS_BOTTOMALIGN或SBS_TOPALIGN风格,则滚动条的高度、宽度和位置由Create函数的rect参数给出。
    SBS_VERT:指定滚动条为垂直滚动条。若是没有指定SBS_RIGHTALIGN或SBS_LEFTALIGN风格,则滚动条的高度、宽度和位置由Create函数的rect参数给出。
    SBS_TOPALIGN:与SBS_HORZ配合使用。滚动条的上边缘与Create函数的rect参数指定矩形的上边缘对齐。滚动条高度为系统滚动条的默认高度。
    SBS_BOTTOMALIGN:与SBS_HORZ配合使用。滚动条的下边缘与Create函数的rect参数指定矩形的下边缘对齐。滚动条高度为系统滚动条的默认高度。
    SBS_LEFTALIGN:与SBS_VERT配合使用。滚动条的左边缘与Create函数的rect参数指定矩形的左边缘对齐。滚动条宽度为系统滚动条的默认宽度。
    SBS_RIGHTALIGN:与SBS_VERT配合使用。滚动条的右边缘与Create函数的rect参数指定矩形的右边缘对齐。滚动条宽度为系统滚动条的默认宽度。
    dwStyle参数能够是以上风格中某几个的组合,另一般也会用到WS_CHILD、WS_VISIBLE风格。
函数

3.获取滚动条参数信息函数:BOOL GetScrollInfo(LPSCROLLINFO lpScrollInfo, UINT nMask = SIF_ALL);
获取的滚动条的参数信息,该信息为SCROLLINFO结构体的形式。参数lpScrollInfo为指向SCROLLINFO结构体变量的指针。
学习

 1     typedef struct tagSCROLLINFO {  2         UINT cbSize;         // 结构的尺寸(字节为单位) 
 3         UINT fMask;          // 说明结构中的哪些参数是有效的,能够是屏蔽值的组合,如SIF_POS|SIF_PAGE,若为SIF_ALL则整个结构都有效 
 4         int  nMin;           // 滚动范围最小值,当fMask 中包含SIF_RANGE 时有效 
 5         int  nMax;           // 滚动范围最大值,当fMask 中包含SIF_RANGE 时有效 
 6         UINT nPage;          // 页尺寸,用来肯定比例滚动框的大小,当fMask中包含SIF_PAGE时有效 
 7         int  nPos;           // 滚动框的位置,当fMask 中包含SIF_POS 有效 
 8         int  nTrackPos;      // 滚动时滚动框的位置,当fMask 中包含SIF_TRACKPOS 时有效,该参数只能查询,不能设置,最好不要用该参数来查询拖动时滚动框的位置 
 9     }   SCROLLINFO, *LPSCROLLINFO; 10     typedef SCROLLINFO CONST *LPCSCROLLINFO;  
View Code

4.设置滚动条参数信息:BOOL SetScrollInfo(LPSCROLLINFO lpScrollInfo, BOOL bRedraw = TRUE);参数bRedraw表示是否须要重绘滚动条,若是为TRUE,则重绘。

5.获取滚动条位置: int GetScrollPos()const;

6.将滚动块移动到指定位置:int SetScrollPos(int nPos, BOOL bRedraw = TRUE);

7.获取滚动条的滚动范围:void GetScrollRange(LPINT lpMinPos, LPINT lpMaxPos) const;

6.消息处理函数:滚动条的通知消息都是用WM_HSCROLL 和WM_VSCROLL消息发送出去的。对这两个消息的默认处理函数是CWnd::OnHScroll和CWnd::OnVScroll,通常须要在派生类中对这两个函数进行重载,以实现滚动功能。函数声明以下:
    afx_msg void OnHScroll(UINT nSBCode,UINT nPos,CScrollBar* pScrollBar);
    afx_msg void OnVScroll(UINT nSBCode,UINT nPos,CScrollBar* pScrollBar);
    参数:
    nSBCode是通知消息码;nPos 是滚动框的位置,只有在nSBCode为SB_THUMBPOSITION或SB_THUMBTRACK时,该参数才有意义。若是通知消息是滚动条控件发来的,那么pScrollBar 是指向该控件的指针,若是是标准滚动条发来的,则pScrollBar 为NULL。
    滚动条消息通知码nSBCode:
       SB_BOTTOM/SB_RIGHT:滚动到底端(右端)
       SB_TOP/SB_LEFT:滚动到顶端(左端)
       SB_LINEDOWN/SB_LINERIGHT:向下(向右)滚动一行(列)
       SB_LINEUP/SB_LINELEFT:向上(向左)滚动一行(列)
       SB_PAGEDOWN/SB_PAGERIGHT:向下(向右)滚动一页
       SB_PAGEUP/SB_PAGELEFT:向上(向左)滚动一页
       SB_THUMBPOSITION:滚动到指定位置
       SB_THUMBTRACK:滚动框被拖动。可利用该消息来跟踪对滚动框的拖动
       SB_ENDSCROLL:滚动结束
this

示例代码:spa

 

 1 建立滚动条:  2 m_scrollBar.Create(WS_CHILD|WS_VISIBLE|SBS_HORZ,CRect(10,10,250,50),this,1136);  3     m_scrollBar.SetScrollRange(1,100);  4 
 5 滚动条响应事件:  6 void CMFC_NoramlControlDlg::OnHScroll(UINT nSBCode, UINT nPos, CScrollBar* pScrollBar)  7 {  8     
 9     static int pos=0; 10     pos=m_scrollBar.GetScrollPos(); 11     switch(nSBCode) 12  { 13     case SB_THUMBPOSITION: 14         pos=nPos+10; 15         break; 16     case SB_THUMBTRACK: 17         pos=nPos; 18         break; 19     case SB_LINELEFT: 20         pos=nPos-5; 21         break; 22     case SB_PAGELEFT: 23         pos=nPos-10; 24         break; 25     case SB_LINERIGHT: 26         pos=nPos+5; 27         break; 28     case SB_PAGERIGHT: 29         pos=nPos+10; 30         break; 31  } 32  m_scrollBar.SetScrollPos(pos); 33  CString strPos; 34     strPos.Format("%d",pos); 35     GetDlgItem(IDC_STATIC1)->SetWindowText(strPos); 36  CDialog::OnHScroll(nSBCode, nPos, pScrollBar); 37 }
View Code
相关文章
相关标签/搜索