SmartRefreshLayout上拉加載下拉刷新(基礎篇)

前言

本文主要講解一下SmartRefreshLayout的一些基礎使用和常用設置剔难,包括如何自定義header胆屿、footer等。
更加具體的使用方式可以到SmartRefreshLayout官網(wǎng)查看偶宫。

一非迹、簡單使用方法

1.在 build.gradle 中添加依賴

 /**
* 刷新布局分成三個包啦,用到哪個引用哪個就行
* SmartRefreshLayout 刷新布局核心實現(xiàn)纯趋,自帶ClassicsHeader(經(jīng)典)憎兽、BezierRadarHeader(貝塞爾雷達)兩個 Header.
* SmartRefreshHeader 各種Header的集成,除了Layout自帶的Header吵冒,其它都在這個包中.
* SmartRefreshFooter 各種Footer的集成纯命,除了Layout自帶的Footer,其它都在這個包中.
*/

//1.1.0 API改動過大痹栖,老用戶升級需謹慎
compile 'com.scwang.smartrefresh:SmartRefreshLayout:1.1.0-alpha-21'//基本的功能有這行就夠了
compile 'com.scwang.smartrefresh:SmartRefreshHeader:1.1.0-alpha-21'//沒有使用特殊Header亿汞,可以不加這行
compile 'com.android.support:appcompat-v7:25.3.1'//版本 23以上(必須)

//1.1.0 androidx 版本
implementation 'com.scwang.smartrefresh:SmartRefreshLayout:1.1.0-andx-4'
implementation 'com.scwang.smartrefresh:SmartRefreshHeader:1.1.0-andx-4'

//1.0.5 當1.1.0出現(xiàn)問題可以回退到1.0.5.1
compile 'com.scwang.smartrefresh:SmartRefreshLayout:1.0.5.1'
compile 'com.scwang.smartrefresh:SmartRefreshHeader:1.0.5.1'//沒有使用特殊Header,可以不加這行
compile 'com.android.support:appcompat-v7:25.3.1'//版本 23以上(必須)
compile 'com.android.support:design:25.3.1'//版本隨意(非必須揪阿,引用可以解決無法預覽問題)

2.在XML布局文件中添加 SmartRefreshLayout

<?xml version="1.0" encoding="utf-8"?>
<com.scwang.smartrefresh.layout.SmartRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/refreshLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <android.support.v7.widget.RecyclerView
        android:id="@+id/recyclerView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:overScrollMode="never"
        android:background="#fff" />
</com.scwang.smartrefresh.layout.SmartRefreshLayout>

3.在 Activity 或者 Fragment 中添加代碼

RefreshLayout refreshLayout = (RefreshLayout)findViewById(R.id.refreshLayout);
refreshLayout.setOnRefreshListener(new OnRefreshListener() {
    @Override
    public void onRefresh(RefreshLayout refreshlayout) {
        refreshlayout.finishRefresh(2000/*,false*/);//傳入false表示刷新失敗
    }
});
refreshLayout.setOnLoadMoreListener(new OnLoadMoreListener() {
    @Override
    public void onLoadMore(RefreshLayout refreshlayout) {
        refreshlayout.finishLoadMore(2000/*,false*/);//傳入false表示加載失敗
    }
});

二留夜、如何使用指定的 Header 和 Footer匙铡,有三種方法

1.方法一 全局設置

public class App extends Application {
    //static 代碼段可以防止內存泄露
    static {
        //設置全局的Header構建器
        SmartRefreshLayout.setDefaultRefreshHeaderCreator(new DefaultRefreshHeaderCreator() {
                @Override
                public RefreshHeader createRefreshHeader(Context context, RefreshLayout layout) {
                    layout.setPrimaryColorsId(R.color.colorPrimary, android.R.color.white);//全局設置主題顏色
                    return new ClassicsHeader(context);//.setTimeFormat(new DynamicTimeFormat("更新于 %s"));//指定為經(jīng)典Header图甜,默認是 貝塞爾雷達Header
                }
            });
        //設置全局的Footer構建器
        SmartRefreshLayout.setDefaultRefreshFooterCreator(new DefaultRefreshFooterCreator() {
                @Override
                public RefreshFooter createRefreshFooter(Context context, RefreshLayout layout) {
                    //指定為經(jīng)典Footer碍粥,默認是 BallPulseFooter
                    return new ClassicsFooter(context).setDrawableSize(20);
                }
            });
    }
}

注意:方法一 設置的Header和Footer的優(yōu)先級是最低的,如果同時還使用了方法二黑毅、三嚼摩,將會被其它方法取代

2.方法二 XML布局文件指定

<com.scwang.smartrefresh.layout.SmartRefreshLayout
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/refreshLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#444444"
    app:srlPrimaryColor="#444444"
    app:srlAccentColor="@android:color/white"
    app:srlEnablePreviewInEditMode="true">
    <!--srlAccentColor srlPrimaryColor 將會改變 Header 和 Footer 的主題顏色-->
    <!--srlEnablePreviewInEditMode 可以開啟和關閉預覽功能-->
    <com.scwang.smartrefresh.layout.header.ClassicsHeader
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>
    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:padding="@dimen/dimenPaddingCommon"
        android:background="@android:color/white"
        android:text="@string/description_define_in_xml"/>
    <com.scwang.smartrefresh.layout.footer.ClassicsFooter
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>
</com.scwang.smartrefresh.layout.SmartRefreshLayout>

注意:方法二 XML設置的Header和Footer的優(yōu)先級是中等的,會被方法三覆蓋矿瘦。而且使用本方法的時候枕面,Android Studio 會有預覽效果,如下圖:

jpg_preview_xml_define.jpg

不過不用擔心缚去,只是預覽效果潮秘,運行的時候只有下拉才會出現(xiàn)~

3.方法三 Java代碼設置
final RefreshLayout refreshLayout = (RefreshLayout) findViewById(R.id.refreshLayout);
//設置 Header 為 貝塞爾雷達 樣式
refreshLayout.setRefreshHeader(new BezierRadarHeader(this).setEnableHorizontalDrag(true));
//設置 Footer 為 球脈沖 樣式
refreshLayout.setRefreshFooter(new BallPulseFooter(this).setSpinnerStyle(SpinnerStyle.Scale));

三、常用的樣式

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末易结,一起剝皮案震驚了整個濱河市枕荞,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌搞动,老刑警劉巖躏精,帶你破解...
    沈念sama閱讀 216,919評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異鹦肿,居然都是意外死亡矗烛,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評論 3 392
  • 文/潘曉璐 我一進店門箩溃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來瞭吃,“玉大人,你說我怎么就攤上這事涣旨⊥峒埽” “怎么了?”我有些...
    開封第一講書人閱讀 163,316評論 0 353
  • 文/不壞的土叔 我叫張陵开泽,是天一觀的道長牡拇。 經(jīng)常有香客問我,道長穆律,這世上最難降的妖魔是什么惠呼? 我笑而不...
    開封第一講書人閱讀 58,294評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮峦耘,結果婚禮上剔蹋,老公的妹妹穿的比我還像新娘。我一直安慰自己辅髓,他們只是感情好泣崩,可當我...
    茶點故事閱讀 67,318評論 6 390
  • 文/花漫 我一把揭開白布少梁。 她就那樣靜靜地躺著,像睡著了一般矫付。 火紅的嫁衣襯著肌膚如雪凯沪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,245評論 1 299
  • 那天买优,我揣著相機與錄音妨马,去河邊找鬼。 笑死杀赢,一個胖子當著我的面吹牛烘跺,可吹牛的內容都是我干的。 我是一名探鬼主播脂崔,決...
    沈念sama閱讀 40,120評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼滤淳,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了砌左?” 一聲冷哼從身側響起脖咐,我...
    開封第一講書人閱讀 38,964評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎绊困,沒想到半個月后文搂,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,376評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡秤朗,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,592評論 2 333
  • 正文 我和宋清朗相戀三年煤蹭,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片取视。...
    茶點故事閱讀 39,764評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡硝皂,死狀恐怖,靈堂內的尸體忽然破棺而出作谭,到底是詐尸還是另有隱情稽物,我是刑警寧澤,帶...
    沈念sama閱讀 35,460評論 5 344
  • 正文 年R本政府宣布折欠,位于F島的核電站贝或,受9級特大地震影響,放射性物質發(fā)生泄漏锐秦。R本人自食惡果不足惜咪奖,卻給世界環(huán)境...
    茶點故事閱讀 41,070評論 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望酱床。 院中可真熱鬧羊赵,春花似錦、人聲如沸扇谣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,697評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至靡挥,卻和暖如春序矩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背芹血。 一陣腳步聲響...
    開封第一講書人閱讀 32,846評論 1 269
  • 我被黑心中介騙來泰國打工贮泞, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人幔烛。 一個月前我還...
    沈念sama閱讀 47,819評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像囊蓝,于是被迫代替她去往敵國和親饿悬。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,665評論 2 354