RecyclerView 實現快速滾動 (轉)


RecyclerView 實現快速滾動


極小光  簡書作者
 

簡評:Android Support Library 26 中終於實現了一個等待已久的功能:RecyclerView 的快速滾動。

Android 官方早就在建議開發者使用 RecyclerView 替代 ListView,RecyclerView 也確實表現要好於 ListView,除了沒有快速滾動,就像下面這樣:

 

因此,之前要想在 RecyclerView 上實現快速滾動,往往是依賴第三方庫,比如:FutureMind/recycler-fast-scrolltimusus/RecyclerView-FastScroll

現在 RecyclerView 終於原生支持了快速滾動,現在就讓我們來看一下怎么實現:

首先,在 build.gradle 中添加依賴:

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

注意 Support Library 從版本 26 開始移到了 Google 的 maven 倉庫,並且 Google 計划未來將所有的倉庫都只通過maven.google.com來發布。所以,需要參考官方指南使用 Google Maven 倉庫。

現在,來看一看具體怎么實現 RecyclerView 的快速滾動:

<?xml version="1.0" encoding="utf-8"?> <android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" app:layout_behavior="@string/appbar_scrolling_view_behavior" tools:context="com.shaishavgandhi.fastscrolling.MainActivity" tools:showIn="@layout/activity_main"> <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> </android.support.constraint.ConstraintLayout> 

其中增加了幾個屬性:

  • fastScrollEnabled:boolean 類型,決定是否啟用快速滾動,當設置為 true 時需要設置下面的四個屬性。

  • fastScrollHorizontalThumbDrawable:水平滾動塊。

  • fastScrollHorizontalTrackDrawable:水平滾動欄背景。

  • fastScrollVerticalThumbDrawable:豎直滾動塊。

  • fastScrollVerticalTrackDrawable:豎直滾動欄背景。

接下來看一下具體的 drawable:

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> 

效果如下:


 
gif


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM