滚动控件(ScrollBar)

滚动控件(ScrollBar)

  滚动条(ScrollBar)主要用来从某一预定义值范围内快速有效地进行选择。滚动条分垂直滚动条和水平滚动条两种。在滚动条内有一个滚动框,用来表示当前的值。用鼠标单击滚动条,可以使滚动框移动一页,鼠标单击滚动条两端的剪头可以使滚动框移动一行,也可以直接拖动滚动框。许多窗口控件如列表框和组合框等都带有滚动条子窗口。Win32的滚动条支持比例滚动框,即用滚动框的大小来反映页相对于整个范围的大小。
  当CreateWindowEx创建滚动条时,其风格常数中带SBS_VERT为水平滚动条,不带SBS_VERT或带SBS_HORZ为垂直滚动条。
  创建控件时应初始化滚动条的各种参数。
  应用程序可以通过调用SendMessage向控件发送如下消息来设定控件各种参数。
uMsgwParamlParam说明
SBM_ENABLE_ARROWSESB_DISABLE_BOTH0禁止双向滚动剪头
ESB_DISABLE_DOWN0禁止向下滚动剪头
ESB_DISABLE_LTUP0禁止向上和向左滚动剪头
ESB_DISABLE_LEFT0禁止向左滚动剪头
ESB_DISABLE_RTDN0禁止向下和向右滚动剪头
ESB_DISABLE_UP0禁止向上滚动剪头
ESB_ENABLE_BOTH0允许双向滚动剪头(撤消各种禁止)
SBM_SETPOS指定位置TRUE设置滚动框位置,并重绘控件
FALSE设置滚动框位置,不重绘控件
SBM_SETRANGE最小值最大值设置滚动框位置的变化范围
SBM_SETRANGEREDRAW最小值最大值设置滚动框位置的变化范围,并重绘控件
SBM_SETSCROLLINFOTRUE或FALSESCROLLINFO结构指针本消息通过一个SCROLLINFO结构来同时指定控件的多种参数,具体指定哪些参数由结构中的fMask成员确定。wParam指定是否重绘控件,详见“SCROLLINFO结构”
  当用户在滚动条控件上进行各种操作时,其父窗口将收到WM_HSCROLL或WM_VSCROLL通知消息,同时wParam的低16位带有如下表的消息代码(nScrollCode),wParam的高16位带滚动框的指定位置(nPos),该值在消息代码等于SB_THUMBPOSITION或SB_THUMBTRACK时才有效。lParam带控件句柄(hwndScrollBar)。
  应用程序可以根据消息代码做相应的操作,重新设置滚动框位置,控件本身是不会改变滚动框位置的。
消息代码动作响应
SB_LINEUP
SB_LINELEFT
用户点击了向上(左)剪头滚动框位置减一,客户窗口向上(左)滚动一行。
注:这两个代码数值相等,因此可以混用,下同。
SB_LINEDOWN
SB_LINERIGHT
用户点击了向下(右)剪头滚动框位置加一,客户窗口向下(右)滚动一行。
SB_PAGEUP
SB_PAGELEFT
用户点击了滚动框以上(左)剪杆滚动框位置减去一个大单位,客户窗口向上(左)滚动一页。
SB_PAGEDOWN
SB_PAGERIGHT
用户点击了滚动框以下(右)剪杆滚动框位置加上一个大单位,客户窗口向下(右)滚动一页。
SB_THUMBPOSITION用户拖动并释放滚动框到指定位置设定滚动框到指定位置。客户窗口滚动到指定位置。
SB_THUMBTRACK用户正在拖动滚动框设定滚动框到指定位置。客户窗口滚动到指定位置。如果应用程序需要快速浏览窗口,可以响应本消息重绘窗口,如果不需要快速浏览,可以等待收到SB_THUMBPOSITION消息时重绘窗口。
SB_ENDSCROLL用户释放按下剪头或剪杆的鼠标无须做任何响应
  应用程序可以通过调用SendMessage向控件发送如下消息来取得当前控件各种参数。
uMsgwParamlParam说明
SBM_GETPOS00返回滚动框当前位置。
SBM_GETRANGE最小值地址指针最大值地址指针在指定地址中填入32位的滚动框位置的变化范围
SBM_GETSCROLLINFO0SCROLLINFO结构指针在一个SCROLLINFO结构中返回控件的多种参数,必须事先设定结构的fMask成员来确定具体要取得哪些参数。详见“SCROLLINFO结构”
  当控件需要重画时向每父窗口发送WM_CTLCOLORSCROLLBAR消息,同时在wParam中带控件的设备场景句柄(hDC),lParam中带控件句柄。如果应用程序响应这个消息并返回一个画刷(brush)句柄,控件将根据这个句柄绘制背景色。

SCROLLINFO结构:
SCROLLINFO STRUCT
  cbSize        DWORD      ?
  fMask         DWORD      ?
  nMin          DWORD      ?
  nMax          DWORD      ?
  nPage         DWORD      ?
  nPos          DWORD      ?
  nTrackPos     DWORD      ?
SCROLLINFO ENDS
成员说明:
  cbSize: SCROLLINFO结构长度字节数,该值在设置和查询参数时都必须填写。
  fMask: 指定结构中的哪些成员是有效,该值共有如下5种选择,可以选择多种用“OR”组合起来,该值在设置和查询参数时都必须填写。
    SIF_ALL      :整个结构都有效
    SIF_DISABLENOSCROLL:该值仅在设定参数时使用,视控件参数设定的需要来对本结构的成员进行取舍。
    SIF_PAGE      :nPage成员有效
    SIF_POS      :nPos成员有效
    SIF_RANGE     :nMin和nMax成员有效
  nMin:滚动范围最小值
  nMax:滚动范围最大值
  nPage:页尺寸,用来确定比例滚动框的大小
  nPos:滚动框的位置
  nTrackPos:拖动时滚动框的位置,该参数只能查询,不能设置。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要修改 WPF ScrollBar滚动量,可以使用 ScrollViewer 控件。在 ScrollViewer 中,可以通过修改 VerticalScrollBar 或 HorizontalScrollBar 的 SmallChange 或 LargeChange 属性来修改滚动量。 例如,如果要将 ScrollBar滚动量从默认的 16 修改为 20,可以在 XAML 中添加以下代码: ```xml <ScrollViewer> <ScrollViewer.Resources> <!-- 获取垂直 ScrollBar --> <Style TargetType="ScrollBar"> <Setter Property="OverridesDefaultStyle" Value="True"/> <Setter Property="Width" Value="18"/> <Setter Property="Minimum" Value="0"/> <Setter Property="Maximum" Value="100"/> <Setter Property="Orientation" Value="Vertical"/> <Setter Property="Foreground" Value="White"/> <Setter Property="Template"> <Setter.Value> <ControlTemplate TargetType="ScrollBar"> <Grid x:Name="GridRoot" Width="18" Background="{StaticResource DarkBrush}"> <Grid.RowDefinitions> <RowDefinition MaxHeight="18"/> <RowDefinition Height="0.00001*"/> <RowDefinition MaxHeight="18"/> </Grid.RowDefinitions> <RepeatButton x:Name="LineUpButton" Command="ScrollBar.LineUpCommand" Background="{StaticResource DarkBrush}" Content="M 0 4 L 8 4 L 4 0 Z" Height="18" Visibility="Collapsed"/> <Track x:Name="PART_Track" Grid.Row="1" IsDirectionReversed="true"> <Track.DecreaseRepeatButton> <RepeatButton Command="ScrollBar.PageUpCommand" Background="{StaticResource DarkBrush}"/> </Track.DecreaseRepeatButton> <Track.Thumb> <Thumb x:Name="Thumb" Background="{StaticResource LightBrush}" BorderBrush="{StaticResource DarkBrush}" BorderThickness="1" Width="12"/> </Track.Thumb> <Track.IncreaseRepeatButton> <RepeatButton Command="ScrollBar.PageDownCommand" Background="{StaticResource DarkBrush}"/> </Track.IncreaseRepeatButton> </Track> <RepeatButton x:Name="LineDownButton" Grid.Row="2" Command="ScrollBar.LineDownCommand" Background="{StaticResource DarkBrush}" Content="M 0 0 L 4 4 L 8 0 Z" Height="18" Visibility="Collapsed"/> </Grid> <ControlTemplate.Triggers> <Trigger Property="IsEnabled" Value="False"> <Setter TargetName="Thumb" Property="Visibility" Value="Collapsed"/> </Trigger> <Trigger Property="Orientation" Value="Horizontal"> <Setter TargetName="GridRoot" Property="LayoutTransform"> <Setter.Value> <RotateTransform Angle="-90"/> </Setter.Value> </Setter> <Setter TargetName="PART_Track" Property="LayoutTransform"> <Setter.Value> <RotateTransform Angle="-90"/> </Setter.Value> </Setter> <Setter Property="Width" Value="Auto"/> <Setter Property="Height" Value="18"/> <Setter TargetName="LineUpButton" Property="LayoutTransform"> <Setter.Value> <RotateTransform Angle="90"/> </Setter.Value> </Setter> <Setter TargetName="LineDownButton" Property="LayoutTransform"> <Setter.Value> <RotateTransform Angle="90"/> </Setter.Value> </Setter> </Trigger> <!-- 修改 SmallChange 和 LargeChange --> <Trigger Property="IsMouseOver" Value="True"> <Setter Property="Background" TargetName="GridRoot" Value="{StaticResource LightBrush}"/> <Setter Property="Visibility" TargetName="LineUpButton" Value="Visible"/> <Setter Property="Visibility" TargetName="LineDownButton" Value="Visible"/> </Trigger> <Trigger Property="IsDragging" Value="True"> <Setter Property="Background" TargetName="GridRoot" Value="{StaticResource LightBrush}"/> </Trigger> </ControlTemplate.Triggers> </ControlTemplate> </Setter.Value> </Setter> </Style> </ScrollViewer.Resources> <!-- 添加内容 --> <StackPanel> <TextBlock Text="1"/> <TextBlock Text="2"/> <TextBlock Text="3"/> <TextBlock Text="4"/> <TextBlock Text="5"/> <TextBlock Text="6"/> <TextBlock Text="7"/> <TextBlock Text="8"/> <TextBlock Text="9"/> <TextBlock Text="10"/> <TextBlock Text="11"/> <TextBlock Text="12"/> <TextBlock Text="13"/> <TextBlock Text="14"/> <TextBlock Text="15"/> <TextBlock Text="16"/> <TextBlock Text="17"/> <TextBlock Text="18"/> <TextBlock Text="19"/> <TextBlock Text="20"/> </StackPanel> </ScrollViewer> ``` 在上面的代码中,我们通过修改 ScrollBar 的 SmallChange 和 LargeChange 属性,将滚动量从默认的 16 修改为 20。 请注意,这里的代码是针对垂直 ScrollBar 的。如果需要修改水平 ScrollBar滚动量,可以在上面的代码中,将 Orientation 属性设置为 Horizontal,并将 Width 和 Height 的值交换。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值