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来操作和定制滚动条功能。滚动条不仅局限于窗口的垂直和水平方向,还可以在自定义控件中实现,为用户提供滚动浏览内容的...
易语言API滚动条操作源码很可能是用易语言编写的一系列函数或类,用于处理Windows操作系统中的滚动条事件和行为。 在Windows API中,滚动条相关的函数主要包括以下几个: 1. `CreateWindowEx()`:用于创建窗口,...
在标题“易语言API滚动条操作”中,主要涉及到的是如何使用API来控制和管理滚动条的行为。 滚动条是用户界面中常见的组件,常用于浏览超过当前窗口大小的内容。在Windows系统中,滚动条的操作通常通过发送特定的...
在Windows API中,滚动条有自己的结构和消息处理机制。主要涉及的API函数可能包括`GetScrollPos`或`GetScrollInfo`,它们可以用来获取滚动条的当前位置。 `GetScrollPos`函数允许你获取一个窗口的水平或垂直滚动条...
在Windows API中,滚动条控件可以通过`SCROLLINFO`结构来获取或设置其属性,如位置、范围、步长等。而自定义外观则需要重载控件的画图方法,通常是`WM_PAINT`消息的处理函数。 在VC++中,我们可以使用MFC...
5、对滚动条操作的相关API函数都可以正常调用,返回结果不受任何影响。 6、SkinScrollBar.dll,导出函数少,使用极其方便,对滚动条的Attach和Detach操作可以在任意地方,任意时间,任意次数调用。 7、SkinScrollBar...
易语言是一种专为中国人设计的...总之,易语言API滚动条操作源码提供了实践和学习易语言API控制滚动条功能的机会,通过对这些源码的分析和理解,开发者可以提升自己的编程技能,更好地实现GUI程序中滚动条的动态控制。
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函数来创建和管理Windows操作系统中的用户界面元素,如窗口和滚动条。 在Windows编程中,API函数是开发者用来...
- 重载`OnCtlColor()`函数,当消息发送到滚动条时,返回一个HBRUSH类型的画刷对象,该对象使用我们想要的颜色填充滚动条。 - 要注意的是,滚动条的滑块、箭头和轨道部分都需要单独处理,可能需要使用`...
在IT领域,窗口函数传递、滚动条操作以及时钟控件是GUI(图形用户界面)编程中的重要概念,尤其在Windows编程中应用广泛。这里我们将深入探讨这些知识点,并结合实际应用进行详细说明。 首先,我们要理解“窗口函数...
`FlatSB_ShowScrollBar`是Windows API中用于控制“平面样式”滚动条显示状态的一个函数,它属于Flat Scroll Bar (FSB) API的一部分。这个API允许开发者改变滚动条的外观和行为,使其与窗口风格更加一致,看起来更...
MFC中的“通用自绘滚动条”是一种高级技术,允许程序员自定义滚动条的外观和行为,超越了标准Windows控件的限制。通过自绘,我们可以实现更丰富的视觉效果,比如改变滚动条的颜色、样式,或者添加额外的图形元素。 ...