zoukankan      html  css  js  c++  java
  • Android 自定义ListView滚动条样式

    使用ListView FastScroller,默认滑块和自定义滑块图片的样子:

    设置快速滚动属性很容易,只需在布局的xml文件里设置属性即可:

        <ListView
            android:id="@+id/listView"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:fastScrollEnabled="true"
            android:focusable="true" />

    但是有时候会发现设置属性无效,滚动ListView并未出现滑块。原因是该属性生效有最小记录限制。当ListView记录能够在4屏以内显示(也就是说滚动4页)就不会出现滑块。可能是api设计者认为这么少的记录不需要快速滚动。

    我的依据是android源代码,见FastScroller的常量声明:

    // Minimum number of pages to justify showing a fast scroll thumb
    private static int MIN_PAGES = 4;

    以及:

    // Are there enough pages to require fast scroll? Recompute only if total count changes
    if (mItemCount != totalItemCount && visibleItemCount > 0) {
      mItemCount = totalItemCount;
      mLongList = mItemCount / visibleItemCount >= MIN_PAGES;
    }

    通篇查看了ListView及其超累AbsListView,都未找到自定义图片的设置接口。看来是没打算让开发者更改了。但是用户要求我们自定义这个图片。那只能用非常手段了。

    经过分析发现,该图片是ListView超类AbsListView的一个成员mFastScroller对象的成员 mThumbDrawable。这里mThumbDrawable是Drawable类型的。mFastScroller是FastScroller类 型,这个类型比较麻烦,类的声明没有modifier,也就是default(package),只能供包内的类调用。

    因此反射代码写的稍微麻烦一些:

    try {
        Field f = AbsListView.class.getDeclaredField(“mFastScroller”);
        f.setAccessible(true);
        Object o=f.get(listView);
        f=f.getType().getDeclaredField(“mThumbDrawable”);
        f.setAccessible(true);
        Drawable drawable=(Drawable) f.get(o);
        drawable=getResources().getDrawable(R.drawable.icon);
        f.set(o,drawable);
        Toast.makeText(this, f.getType().getName(), 1000).show();
    } catch (Exception e) {
        throw new RuntimeException(e);
    }
  • 相关阅读:
    tcp滑动窗口详解(2)
    jQuery火箭图标返回顶部代码
    jQuery火箭图标返回顶部代码
    jQuery火箭图标返回顶部代码
    jQuery火箭图标返回顶部代码
    jQuery火箭图标返回顶部代码
    jQuery火箭图标返回顶部代码
    SpringCloud(3)----Eureka服务注册与发现
    SpringCloud(2)----SpringCloud理解篇
    SpringCloud(1)----基于RestTemplate微服务项目
  • 原文地址:https://www.cnblogs.com/zhujiabin/p/4224581.html
Copyright © 2011-2022 走看看