如何在RecyclerView中使用fastScrollEnabled?

时间:2017-07-28 09:50:44

标签: android android-recyclerview

我是RecyclerView的新手,我想在垃圾回收视图中实现快速滚动功能,如google联系人应用程序和在互联网上搜索,我发现现在Android为RecyclerView正式提供了新的fastScrollEnabled布尔标志。所以我的问题是有人可以提供它的示例实现。

以下是谷歌的官方文件 https://developer.android.com/topic/libraries/support-library/revisions.html#26-0-0

4 个答案:

答案 0 :(得分:19)

通过支持库26,我们可以轻松地为RecyclerView启用快速滚动。我们来吧!

让我们一个接一个地浏览每个房产:

  1. fastScrollEnabled :布尔值以启用快速滚动。将此设置为true将要求我们提供以下四个 属性。
  2. fastScrollHorizo​​ntalThumbDrawable :一个StateListDrawable,用于绘制拇指,该拇指可以跨越 横轴。
  3. fastScrollHorizo​​ntalTrackDrawable :一个StateListDrawable,用于绘制代表滚动条的行 横轴。
  4. fastScrollVerticalThumbDrawable :一个StateListDrawable,用于绘制可在垂直轴上拖动的拇指。
  5. fastScrollVerticalTrackDrawable :一个StateListDrawable,用于绘制代表滚动条的行 垂直轴。
  6. 添加build.gradle

        dependencies {
        ....
        compile 'com.android.support:design:26.0.1'
        compile 'com.android.support:recyclerview-v7:26.0.1'
        ....
    }
    

    由于支持库26现已转移到Google的maven存储库,我们将其包含在项目级 build.gradle

    allprojects {
        repositories {
            jcenter()
            maven {
                url "https://maven.google.com"
            }
        }
    }
    

    activity_main.xml中

    <android.support.v7.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:fastScrollEnabled="true"
        app:fastScrollHorizontalThumbDrawable="@drawable/thumb_drawable"
        app:fastScrollHorizontalTrackDrawable="@drawable/line_drawable"
        app:fastScrollVerticalThumbDrawable="@drawable/thumb_drawable"
        app:fastScrollVerticalTrackDrawable="@drawable/line_drawable">
    
     </android.support.v7.widget.RecyclerView>
    

    在您的drawable文件夹中添加以下四个xml文件,

    <强> line_drawable.xml

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item
            android:state_pressed="true"
            android:drawable="@drawable/line"/>
    
        <item
            android:drawable="@drawable/line"/>
    </selector>
    

    <强> line.xml

    <?xml version="1.0" encoding="utf-8"?>
    <shape xmlns:android="http://schemas.android.com/apk/res/android"
           android:shape="rectangle">
    
        <solid android:color="@android:color/darker_gray" />
    
        <padding
            android:top="10dp"
            android:left="10dp"
            android:right="10dp"
            android:bottom="10dp"/>
    </shape>
    

    <强> thumb_drawable.xml

    <?xml version="1.0" encoding="utf-8"?>
    <selector xmlns:android="http://schemas.android.com/apk/res/android">
        <item
            android:state_pressed="true"
            android:drawable="@drawable/thumb"/>
    
        <item
            android:drawable="@drawable/thumb"/>
    </selector>
    

    <强> thumb.xml

    <?xml version="1.0" encoding="utf-8"?>
    <shape xmlns:android="http://schemas.android.com/apk/res/android"
           android:shape="rectangle">
    
        <corners
            android:topLeftRadius="44dp"
            android:topRightRadius="44dp"
            android:bottomLeftRadius="44dp" />
    
        <padding
            android:paddingLeft="22dp"
            android:paddingRight="22dp" />
    
        <solid android:color="@color/colorPrimaryDark" />
    
    </shape>
    

答案 1 :(得分:7)

将属性添加到布局文件中的RecyclerView标记:

<android.support.v7.widget.RecyclerView
    xmlns:app="http://schemas.android.com/apk/res-auto"
    ...
    app:fastScrollEnabled="true"
    app:fastScrollHorizontalThumbDrawable="@drawable/fast_scroll_thumb"
    app:fastScrollHorizontalTrackDrawable="@drawable/fast_scroll_track"
    app:fastScrollVerticalThumbDrawable="@drawable/fast_scroll_thumb"
    app:fastScrollVerticalTrackDrawable="@drawable/fast_scroll_track"
/>

制作两个drawables。 &#34;跟踪&#34; drawable可以是任何drawable,但&#34;拇指&#34; drawable必须是一个可绘制的状态列表。

示例drawable/fast_scroll_track.xml文件:

<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <solid android:color="#80ffffff" />
</shape>

示例drawable/fast_scroll_thumb.xml文件:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
        <shape android:shape="rectangle">
            <solid android:color="#ff0" />
        </shape>
    </item>
    <item>
        <shape android:shape="rectangle">
            <solid android:color="#fff" />
        </shape>
    </item>
</selector>

答案 2 :(得分:4)

如您所知,RecyclerView支持Support Library 26.0.0中的“快速滚动”。

  

注意:请注意,它仅限于XML。

usage

答案 3 :(得分:0)

对于糖果棒滚动条拇指(圆形边框):

   <android.support.v7.widget.RecyclerView
                android:id="@+id/netflixVideoGridView"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"

                app:fastScrollEnabled="true"
                app:fastScrollHorizontalThumbDrawable="@drawable/fast_scroll_thumb"
                app:fastScrollHorizontalTrackDrawable="@drawable/fast_scroll_track"
                app:fastScrollVerticalThumbDrawable="@drawable/fast_scroll_thumb"
                app:fastScrollVerticalTrackDrawable="@drawable/fast_scroll_track"
                 />

fast_scroll_thumb.xml

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:state_pressed="true"
        android:drawable="@drawable/thumb"/>

    <item
        android:drawable="@drawable/thumb"/>
</selector>

thumb.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">

    <corners
        android:radius="50dp" />

    <padding
        android:paddingLeft="22dp"
        android:paddingRight="22dp" />

    <solid android:color="@color/colorPrimaryDark" />

    <stroke
        android:width="1dp"
        android:color="#69f0ae" />

</shape>

track.xml:

<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
    <solid android:color="#80ffffff" />
    <padding
        android:padding="0dp"/>
</shape>

结果:

enter image description here