`

Windows API学习之滚动条系列函数

阅读更多

Windows API中滚动条相关函数有两个:
int SetScrollInfo(
HWND hwnd,
int fnBar,
LPSCROLLINFO lpsi,
BOOL fRedraw
);

BOOL GetScrollInfo(
HWND hwnd,
int fnBar,
LPSCROLLINFO lpsi
);


见名知意,SetScrollInfo就是用来设置窗口的滚动信息,GetScrollInfo就是用来获取窗口的滚动信息。SetScrollInfo的参数含义如下:
参数 意义
hwnd
滚动条控件的句柄或带有标准滚动栏的窗口的句柄
fnBar
用于指定哪一种滚动条,只能是下面的值之一:
SB_CTL :滚动条控件
SB_HORZ:水平滚动条
SB_VERT:垂直滚动条
lpsi
滚动条信息结构体指针。下面作进一步详细介绍。
fRedraw 值为TRUE表示要Windows重新绘制计算了新信息后的滚动条,FALSE表示不绘制。

GetScrollInfo的参数含义如下:

参数 意义
hwnd
滚动条控件的句柄或带有标准滚动栏的窗口的句柄
fnBar
用于指定哪一种滚动条,只能是下面的值之一:
SB_CTL :滚动条控件
SB_HORZ:水平滚动条
SB_VERT:垂直滚动条
lpsi
滚动条信息结构体指针。下面作进一步详细介绍。

值得注意的是在调用GetScrollInfo函数时要获取相关滚动信息,需要指定SCROLLINFO结构体中的fMask成员的值。fMask取下面的值的组合值:
值 意义
SIF_PAGE 获取SCROLLINFO中的nPage成员的值(即一页的大小)。
SIF_POS 获取SCROLLINFO中的nPos成员的值。
SIF_RANGE
获取SCROLLINFO中的nPos成员的nMin 和 nMax的值。
SIF_TRACKPOS
获取SCROLLINFO中的nTrackPos成员的值。
nTrackPos
SIF_RANGE、SIF_POS、SIF_PAGE和SIF_TRACKPOS的组合。

使用例程(据petzod的《windows程序设计》第四章,仅列出主要代码片段,具体请下载源码):


view plaincopy to clipboardprint?
01.case WM_SIZE:  
02.    {  
03.        // save the width and height of window when changed the size of window  
04.        cxClient = LOWORD(lp); // the width  
05.        cyClient = HIWORD(lp); // the height  
06.           // set vertical scroll bar range and page size  
07.        si.cbSize = sizeof(SCROLLBARINFO);  
08.        si.fMask = SIF_RANGE|SIF_PAGE;  
09.           si.nMin = 0;  
10.           si.nMax = NUMLINES - 1;  
11.        si.nPage = cyClient/cyChar;  
12.           SetScrollInfo(hWnd,SB_VERT,&si,TRUE);  
13.           // set horizontal scroll bar and page size  
14.        si.cbSize = sizeof(SCROLLBARINFO);  
15.        si.fMask = SIF_RANGE|SIF_PAGE;  
16.        si.nMin = 0;  
17.        si.nMax = 2 + nMaxWidth/cxChar;  
18.        si.nPage = cxClient/cxChar;  
19.        SetScrollInfo(hWnd,SB_HORZ,&si,TRUE);  
20.        return 0;  
21.    }  
22.case WM_VSCROLL:  
23.    {  
24.// get all vertical scroll bar information  
25.si.cbSize = sizeof(SCROLLINFO);  
26.si.fMask = SIF_ALL;  
27.::GetScrollInfo(hWnd,SB_VERT,&si);  
28.   // save the position for comparison later on  
29.nVertPos = si.nPos;  
30.    switch (LOWORD(wp))  
31.           {  
32.        case SB_LINEUP:  
33.            {  
34.                si.nPos -=1;// the height decrease 1 unit  
35.                break;  
36.            }  
37.        case SB_LINEDOWN:  
38.            {  
39.                si.nPos +=1;// the height increase 1 unit  
40.                break;  
41.            }  
42.        case SB_PAGEUP:  
43.            {  
44.                   // back to prev page, the cyClient/cyChar is the number of row in one page  
45.                si.nPos -= cyClient/cyChar;   
46.                break;  
47.            }  
48.        case SB_PAGEDOWN:  
49.            {  
50.                // back to next page  
51.                si.nPos += cyClient/cyChar;  
52.                break;  
53.            }  
54.        case SB_THUMBPOSITION:  
55.            {  
56.                si.nPos = HIWORD(wp);  
57.                break;  
58.            }  
59.        default:  
60.            break;  
61.           }  
62.           // set the position and then retrieve it.Due to adjustments  
63.        // by Windows it may not be the same as the value set.  
64.        si.fMask = SIF_POS;  
65.        SetScrollInfo(hWnd,SB_VERT,&si,TRUE);  
66.        GetScrollInfo(hWnd,SB_VERT,&si);  
67.        //if the position has changed,scroll the window update it  
68.        if (si.nPos!=nVertPos)  
69.        {  
70.            ::ScrollWindow(hWnd,0,cyChar*(nVertPos-si.nPos),NULL,NULL);  
71.            ::UpdateWindow(hWnd);  
72.        }  
73.        return 0;  
74.    }  
75.case WM_HSCROLL:  
76.    {  
77.        // get all the vertical scroll bar information  
78.        si.cbSize = sizeof(si);  
79.        si.fMask = SIF_ALL;  
80.        // save the position for comparison later on  
81.        ::GetScrollInfo(hWnd,SB_HORZ,&si);  
82.        nHorzPos = si.nPos;  
83.        switch (LOWORD(wp))  
84.        {  
85.        case SB_LINELEFT:  
86.            {  
87.                si.nPos -=1;  
88.                break;  
89.            }  
90.        case SB_LINERIGHT:  
91.            {  
92.                si.nPos +=1;  
93.                break;  
94.            }  
95.        case SB_PAGELEFT:  
96.            {  
97.                si.nPos -= si.nPage;  
98.                break;  
99.            }  
100.        case SB_PAGERIGHT:  
101.            {  
102.                si.nPos += si.nPage;  
103.                break;  
104.            }  
105.        case SB_THUMBPOSITION:  
106.            {  
107.                si.nPos = si.nTrackPos;  
108.                break;  
109.            }  
110.        default:  
111.               break;  
112.        }  
113.        // set the position and then retrieve it.due to adjustments  
114.        // by windows it may not be the same as the value set  
115.        si.fMask = SIF_POS;  
116.        ::SetScrollInfo(hWnd,SB_HORZ,&si,TRUE);  
117.        ::GetScrollInfo(hWnd,SB_HORZ,&si);  
118.        // if the postion has changed ,scroll the window  
119.        if (si.nPos!=nHorzPos)  
120.        {  
121.            ::ScrollWindow(hWnd,cxChar*(nHorzPos-si.nPos),0,NULL,NULL);  
122.        }  
123.        return 0;  
124.    }  
125.case WM_PAINT:  
126.    {  
127.        hdc = ::BeginPaint(hWnd,&ps);  
128.           // get vertical scroll bar position  
129.        si.cbSize = sizeof(si);  
130.           si.fMask = SIF_POS;  
131.        ::GetScrollInfo(hWnd,SB_VERT,&si);  
132.        nVertPos = si.nPos;  
133.        // get horizontal scroll bar position  
134.           GetScrollInfo(hWnd,SB_HORZ,&si);  
135.           nHorzPos = si.nPos;  
136.        // find painting limits   
137.           int nPaintBeg = max(0,nVertPos+ps.rcPaint.top/cyChar); // the begin row  
138.           int nPaintEnd = min(NUMLINES-1,nVertPos+ps.rcPaint.bottom/cyChar); // the end row  
139.        for (int i =nPaintBeg;i<=nPaintEnd;i++)  
140.        {  
141.               // calculate the y position of draw region, when y position less 0,skip  
142.            int x = cxChar*(1-nHorzPos);   
143.            int y = cyChar*(i-nVertPos);  
144.            ::TextOut(hdc,x,y,sysmetrics[i].szLabel,lstrlen(sysmetrics[i].szLabel));  
145.            ::TextOut(hdc,x+22*cxCaps,y,sysmetrics[i].szDesc,lstrlen(sysmetrics[i].szDesc));  
146.            ::SetTextAlign(hdc,TA_RIGHT|TA_TOP);  
147.            ::TextOut(hdc,x+22*cxCaps+40*cxChar,y,szBuffer,wsprintf(szBuffer,_T("%5d"),::GetSystemMetrics(sysmetrics[i].Index)));  
148.            ::SetTextAlign(hdc,TA_LEFT|TA_TOP);  
149.        }  
150.        ::EndPaint(hWnd,&ps);  
151.        return 0;  
152.    } 

 

原文地址:http://www.cnblogs.com/zzbbs/archive/2011/02/22/1961172.html

分享到:
评论

相关推荐

    Windows API学习之滚动条系列函数演示程序

    这个"Windows API学习之滚动条系列函数演示程序"旨在帮助开发者深入理解如何使用Windows API来操作和定制滚动条功能。滚动条不仅局限于窗口的垂直和水平方向,还可以在自定义控件中实现,为用户提供滚动浏览内容的...

    API滚动条操作.rar

    易语言API滚动条操作源码很可能是用易语言编写的一系列函数或类,用于处理Windows操作系统中的滚动条事件和行为。 在Windows API中,滚动条相关的函数主要包括以下几个: 1. `CreateWindowEx()`:用于创建窗口,...

    易语言API滚动条操作

    在标题“易语言API滚动条操作”中,主要涉及到的是如何使用API来控制和管理滚动条的行为。 滚动条是用户界面中常见的组件,常用于浏览超过当前窗口大小的内容。在Windows系统中,滚动条的操作通常通过发送特定的...

    C#利用API判断滚动条的位置

    在Windows API中,滚动条有自己的结构和消息处理机制。主要涉及的API函数可能包括`GetScrollPos`或`GetScrollInfo`,它们可以用来获取滚动条的当前位置。 `GetScrollPos`函数允许你获取一个窗口的水平或垂直滚动条...

    visual c++自定义滚动条外观 制作五颜六色的滚动条(水平滚动条,垂直滚动条).zip

    在Windows API中,滚动条控件可以通过`SCROLLINFO`结构来获取或设置其属性,如位置、范围、步长等。而自定义外观则需要重载控件的画图方法,通常是`WM_PAINT`消息的处理函数。 在VC++中,我们可以使用MFC...

    windows标准控件内嵌滚动条换肤的完美实现

    5、对滚动条操作的相关API函数都可以正常调用,返回结果不受任何影响。 6、SkinScrollBar.dll,导出函数少,使用极其方便,对滚动条的Attach和Detach操作可以在任意地方,任意时间,任意次数调用。 7、SkinScrollBar...

    易语言API滚动条操作源码

    易语言是一种专为中国人设计的...总之,易语言API滚动条操作源码提供了实践和学习易语言API控制滚动条功能的机会,通过对这些源码的分析和理解,开发者可以提升自己的编程技能,更好地实现GUI程序中滚动条的动态控制。

    windows滚动条编程

    Windows API提供了大量的函数、结构体和消息,使得开发者可以创建具有滚动条功能的窗口。滚动条分为两种类型:水平滚动条(HSCROLL)和垂直滚动条(VSCROLL)。它们通常出现在窗口的右侧和底部,用于浏览超过当前...

    易语言高级表格隐藏滚动条

    要实现隐藏滚动条,我们需要涉及到几个关键的API函数,这些函数在Windows API中被广泛使用。在描述中提到了`FlatSB_ShowScrollBar`、`ShowScrollBar`、`CallWindowProcA`以及`SetWindowLongA`,这些都是Windows API...

    易语言滚动条置颜色

    在Windows API中,滚动条的颜色通常由系统默认设置决定,但通过自定义窗口过程(Window Procedure)可以改变这一行为。"窗口处理"就是指编写自定义的窗口过程函数,替代系统默认的窗口过程,从而在接收到特定消息时...

    窗口加滚动条-给窗口加上滚动条并响应滚动条操作

    3. **滚动条操作**:Windows API提供了`CreateWindow`或`CreateWindowEx`函数来创建滚动条。滚动条有自己的样式,如`WS_VSCROLL`(垂直滚动条)和`WS_HSCROLL`(水平滚动条)。创建滚动条后,我们还需要设置其属性,...

    如何区分系统滚动条消息与控件滚动条消息

    此外,还可以利用Windows API函数如CreateWindowEx()创建自定义滚动条控件,或者使用第三方库如wxWidgets、Qt等,它们提供了更高级别的抽象,使得滚动条的定制更为便捷。 总之,了解系统滚动条和控件滚动条的区别,...

    易语言滚动条位置判断

    `GetScrollInfo`是Windows API中的一个函数,用于获取滚动条的详细信息。在易语言中,我们需要导入这个函数并设置参数,如窗口句柄(HWND)和一个结构体,该结构体包含了滚动条的最小值、最大值、滑块范围和当前位置...

    易语言屏蔽超级列表框滚动条

    总的来说,"易语言屏蔽超级列表框滚动条"涉及的是易语言中控件交互和Windows API的使用,通过自定义窗口过程来改变控件默认的行为,实现特定的界面效果。这需要对易语言的编程基础、Windows消息机制以及API调用有...

    API创建各种窗口及滚动条源码

    在这个特定的资源中,标题提到的是“API创建各种窗口及滚动条源码”,这通常指的是使用系统提供的API函数来创建和管理Windows操作系统中的用户界面元素,如窗口和滚动条。 在Windows编程中,API函数是开发者用来...

    mfc vc 界面编程之彩色按钮和彩色滚动条

    - 重载`OnCtlColor()`函数,当消息发送到滚动条时,返回一个HBRUSH类型的画刷对象,该对象使用我们想要的颜色填充滚动条。 - 要注意的是,滚动条的滑块、箭头和轨道部分都需要单独处理,可能需要使用`...

    窗口函数传递+滚动条+时钟控件

    在IT领域,窗口函数传递、滚动条操作以及时钟控件是GUI(图形用户界面)编程中的重要概念,尤其在Windows编程中应用广泛。这里我们将深入探讨这些知识点,并结合实际应用进行详细说明。 首先,我们要理解“窗口函数...

    易语言隐藏显示滚动条例程

    `FlatSB_ShowScrollBar`是Windows API中用于控制“平面样式”滚动条显示状态的一个函数,它属于Flat Scroll Bar (FSB) API的一部分。这个API允许开发者改变滚动条的外观和行为,使其与窗口风格更加一致,看起来更...

    MFC 通用自绘滚动条

    MFC中的“通用自绘滚动条”是一种高级技术,允许程序员自定义滚动条的外观和行为,超越了标准Windows控件的限制。通过自绘,我们可以实现更丰富的视觉效果,比如改变滚动条的颜色、样式,或者添加额外的图形元素。 ...

Global site tag (gtag.js) - Google Analytics