ScrollView(滚动条)

本节引言:

本节带来的是Android基本UI控件中的第十个:ScrollView(滚动条),或者我们应该叫他 竖直滚动条,对应的另外一个水平方向上的滚动条:HorizontalScrollView,先来一发官方文档 的链接:ScrollView,我们可以看到类的结构如下:

嘿嘿,原来是一个FrameLayout的容器,不过在他的基础上添加了滚动,允许显示的比实际多的内容!

另外,只能够往里面放置一个子元素,可以是单一的组件,又或者一个布局包裹着的复杂的层次结构!

一般对于可能显示不完的情况,我们可以直接在布局的外层套上一个: ScrollView或者HorizontalScrollView!就这么简单~!


可能遇到的一些需求

好的,就不一个个扣文档了,直接说实际开发中可能会遇到的一些需求吧:

另外有一个很典型的问题就是:ScrollView和ListView的嵌套问题,这个放到ListView那一章节 再来讲解~


1.滚动到底部:

我们可以直接利用ScrollView给我们提供的:fullScroll()方法

scrollView.fullScroll(ScrollView.FOCUS_DOWN);滚动到底部

scrollView.fullScroll(ScrollView.FOCUS_UP);滚动到顶部

另外用这玩意的时候要小心异步的玩意,就是addView后,有可能还没有显示完, 如果这个时候直接调用该方法的话,可能会无效,这就需要自己写handler来更新了~

实现代码:

布局比较简单,就不贴了,直接贴MainActivity MainActivity.java

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

    private Button btn_down;
    private Button btn_up;
    private ScrollView scrollView;
    private TextView txt_show;

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        bindViews();
    }


    private void bindViews() {
        btn_down = (Button) findViewById(R.id.btn_down);
        btn_up = (Button) findViewById(R.id.btn_up);
        scrollView = (ScrollView) findViewById(R.id.scrollView);
        txt_show = (TextView) findViewById(R.id.txt_show);
        btn_down.setOnClickListener(this);
        btn_up.setOnClickListener(this);

        StringBuilder sb = new StringBuilder();
        for (int i = 1; i <= 100; i++) {
            sb.append("呵呵 * " + i + "\n");
        }
        txt_show.setText(sb.toString());

    }

    @Override
    public void onClick(View v) {
        switch (v.getId()) {
            case R.id.btn_down:
                scrollView.fullScroll(ScrollView.FOCUS_DOWN);
                break;
            case R.id.btn_up:
                scrollView.fullScroll(ScrollView.FOCUS_UP);
                break;
        }
    }
}

当然除了这种方法还,你还可以使用另一种复杂一点的写法:

public static void scrollToBottom(final View scroll, final View inner) {
    Handler mHandler = new Handler();
    mHandler.post(new Runnable() {
        public void run() {
            if (scroll == null || inner == null) {
                return;
            }
            int offset = inner.getMeasuredHeight() - scroll.getHeight();
            if (offset < 0) {
                offset = 0;
            }
            scroll.scrollTo(0, offset);
        }
    });
}  

scrollTo()参数依次为x,y滚到对应的x,y位置!


2.设置滚动的滑块图片

这个更加简单: 垂直方向滑块:android:scrollbarThumbVertical
水平方向滑块:android:scrollbarThumbHorizontal


3.隐藏滑块

好吧,这个好像没什么卵用:

方法有两种: 1.android:scrollbars="none"
2.Java代码设置:scrollview.setVerticalScrollBarEnabled(false);


4.设置滚动速度:

这个并没有给我们提供可以直接设置的方法,我们需要自己继承ScrollView,然后重写一个 public void fling (int velocityY)的方法:

@Override
public void fling(int velocityY) {
    super.fling(velocityY / 2);    //速度变为原来的一半
}
### WPF 和其他平台下 ScrollView 滚动条美化的实现方法 #### WPF 下 ScrollViewer 的滚动条美化 在 WPF 中,可以通过模板重写的方式来自定义 `ScrollViewer` 的外观。具体来说,可以重新定义 `Style` 来控制滚动条的各个部分(如滑块、轨道等)。以下是基于引用中的描述以及标准实践的一个示例: ```xml <Window.Resources> <!-- 定义滚动条样式 --> <Style x:Key="CustomScrollBar" TargetType="{x:Type ScrollBar}"> <Setter Property="Background" Value="#F0F0F0"/> <Setter Property="Template"> <Setter.Value> <ControlTemplate TargetType="{x:Type ScrollBar}"> <Grid> <Track Name="PART_Track" IsDirectionReversed="True"> <Track.Thumb> <Thumb Background="#8BC34A"/> <!-- 设置滑块背景颜色 --> </Track.Thumb> </Track> </Grid> </ControlTemplate> </Setter.Value> </Setter> </Style> <!-- 应用到 ScrollViewer 上 --> <Style x:Key="CustomScrollViewer" TargetType="{x:Type ScrollViewer}"> <Setter Property="HorizontalScrollBarVisibility" Value="Auto"/> <Setter Property="VerticalScrollBarVisibility" Value="Auto"/> <Setter Property="Template"> <Setter.Value> <ControlTemplate TargetType="{x:Type ScrollViewer}"> <Border BorderThickness="1" BorderBrush="#E0E0E0"> <DockPanel> <ScrollBar DockPanel.Dock="Right" Orientation="Vertical" Style="{StaticResource CustomScrollBar}"/> <ContentPresenter Content="{TemplateBinding Content}" /> </DockPanel> </Border> </ControlTemplate> </Setter.Value> </Setter> </Style> </Window.Resources> <!-- 使用自定义样式的 ScrollViewer --> <ScrollViewer Style="{StaticResource CustomScrollViewer}"> <TextBlock TextWrapping="Wrap">这里是需要滚动的内容。</TextBlock> </ScrollViewer> ``` 上述代码展示了如何通过 XAML 实现滚动条的自定义样式[^1]。 --- #### Android WebView 下滚动条的美化 对于 Android 平台上的 `WebView`,虽然无法像原生控件那样完全自由地定制滚动条,但仍可通过设置属性来调整其显示效果。例如更改滚动条的颜色和宽度: ```java // Java 代码:设置 WebView 滚动条样式 webView.setVerticalScrollbarOverlay(true); // 将滚动条叠加在内容上 webView.setScrollBarSize(20); // 设置滚动条宽度 webView.setScrollBarDefaultDelayBeforeFade(1000); // 设置淡出延迟时间 webView.setScrollBarFadeDuration(500); // 设置淡出持续时间 // 修改滚动条颜色 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { webView.setLayerType(View.LAYER_TYPE_HARDWARE, null); webView.setOverScrollMode(View.OVER_SCROLL_NEVER); StateListDrawable drawable = new StateListDrawable(); drawable.addState(new int[]{android.R.attr.state_pressed}, new ColorDrawable(Color.argb(255, 75, 196, 117))); // 按压状态下的颜色 drawable.addState(new int[] {}, new ColorDrawable(Color.argb(128, 75, 196, 117))); // 默认状态下的颜色 webView.setScrollBarThumbVertical(drawable); } ``` 此代码片段实现了对 `WebView` 滚动条的颜色和行为进行基本的自定义[^3]。 --- #### 微信小程序中 scroll-view 的滚动条美化 在微信小程序中,由于框架本身的限制,无法直接操作 DOM 或 CSS 属性,因此通常采用模拟滚动条的方式来替代默认的滚动指示器。以下是一个完整的例子: ```html <!-- 页面结构 --> <scroll-view class="content-scroll" scroll-y="{{true}}" bindscroll="onScroll"> <view wx:for="{{items}}" wx:key="id">{{item}}</view> </scroll-view> <view class="custom-scrollbar" style="transform: translateY({{scrollTop}}px)"> <view></view> </view> ``` ```javascript Page({ data: { scrollTop: 0, items: Array.from({ length: 50 }, (_, i) => 'Item ' + (i + 1)) }, onScroll(e) { this.setData({ scrollTop: e.detail.scrollTop / 3 // 调整比例以适配高度 }); } }); ``` ```css /* 样式 */ .content-scroll { height: 400px; } .custom-scrollbar { position: absolute; top: 0; right: 0; width: 8px; background-color: rgba(0, 0, 0, 0.1); } .custom-scrollbar view { height: 50px; background-color: #8BC34A; border-radius: 4px; } ``` 该方案利用了绑定事件监听滚动位置并动态更新虚拟滚动条的位置[^4]。 --- #### 总结 不同平台上针对 `ScrollView` 或类似组件的滚动条美化方式各有差异。WPF 提供了强大的模板机制支持全面定制;Android 则允许一定程度上的属性配置;而微信小程序则需借助逻辑层配合渲染层完成更灵活的效果展示。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值