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);
    }
  • 相关阅读:
    AdvDataList分页 例码
    问一个关于生成静态页面的问题
    使用XMLDataSource简单实现多级下拉菜单
    简单的封装一个HTML 弹出对话框的空间
    JS 语言强大, 动态修改标准库
    Eclipse IDE 学习
    分布式程序的开发
    Http request Post pk Put
    Forward: X Forwarding with Putty on Windows
    转载: 颠覆了对于design 的认识
  • 原文地址:https://www.cnblogs.com/zhujiabin/p/4224581.html
Copyright © 2011-2022 走看看