Android RecyclerView 實現(xiàn)快速滾動的示例代碼
簡評:Android Support Library 26 中終于實現(xiàn)了一個等待已久的功能: RecyclerView 的快速滾動 。
Android 官方早就在建議開發(fā)者使用 RecyclerView 替代 ListView,RecyclerView 也確實表現(xiàn)要好于 ListView,除了沒有快速滾動,就像下面這樣:
因此,之前要想在 RecyclerView 上實現(xiàn)快速滾動,往往是依賴第三方庫,比如:FutureMind/recycler-fast-scroll 或 timusus/RecyclerView-FastScroll 。
現(xiàn)在 RecyclerView 終于原生支持了快速滾動,現(xiàn)在就讓我們來看一下怎么實現(xiàn):
首先,在 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 計劃未來將所有的倉庫都只通過 http:// maven.google.com 來發(fā)布。所以,需要參考 官方指南 使用 Google Maven 倉庫。
現(xiàn)在,來看一看具體怎么實現(xiàn) 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>
效果如下:
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- RecyclerView實現(xiàn)縱向和橫向滾動
- RecyclerView實現(xiàn)抖音縱向滾動ViewPager效果
- Android RecyclerView 滾動到中間位置的方法示例
- Android使用Recyclerview實現(xiàn)圖片水平自動循環(huán)滾動效果
- XRecyclerView實現(xiàn)下拉刷新、滾動到底部加載更多等功能
- Android_RecyclerView實現(xiàn)上下滾動廣告條實例(帶圖片)
- Android中RecyclerView實現(xiàn)分頁滾動的方法詳解
- Android使用RecyclerView實現(xiàn)水平滾動控件
- Android代碼實現(xiàn)AdapterViews和RecyclerView無限滾動
- RecyclerView實現(xiàn)橫向滾動效果
相關文章
android中webview控件和javascript交互實例
這篇文章主要介紹了android中webview控件和javascript交互實例,例子中包括javascript調(diào)用java的方法,java代碼中調(diào)用javascript的方法,需要的朋友可以參考下2014-07-07Android開發(fā)之創(chuàng)建可點擊的Button實現(xiàn)方法
這篇文章主要介紹了Android創(chuàng)建可點擊的Button實現(xiàn)方法,實例分析了Android創(chuàng)建button按鈕過程中的界面配置,功能實現(xiàn)與相關注意事項,需要的朋友可以參考下2016-03-03Android android:exported = true 用法詳解
在本篇文章里小編給大家整理了關于Android android:exported = true 用法,需要的朋友們參考下。2019-09-09