MFC常用控件之滚动条

it2022-05-06  4

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

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

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:滚动结束

示例代码:

 

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

 

 

 

 

转载于:https://www.cnblogs.com/HPAHPA/p/7885759.html

相关资源:MFC VS2010 图片控件 滚动条

最新回复(0)