復(fù)雜type頁(yè)面封裝庫(kù),支持多種狀態(tài)切換和下拉刷新上拉加載

目錄介紹

  • 1.復(fù)雜頁(yè)面庫(kù)介紹
  • 2.本庫(kù)優(yōu)勢(shì)亮點(diǎn)
    • 2.1 支持多種狀態(tài)切換管理
    • 2.2 支持添加多個(gè)header和footer
    • 2.3 支持側(cè)滑功能和拖拽移動(dòng)
    • 2.4 其他亮點(diǎn)介紹
  • 3.如何使用介紹
    • 3.1 最基礎(chǔ)的使用
    • 3.2 添加下拉刷新和加載更多監(jiān)聽
    • 3.3 添加header和footer操作
    • 3.4 設(shè)置數(shù)據(jù)和刷新
    • 3.5 設(shè)置adapter
    • 3.6 設(shè)置條目點(diǎn)擊事件
    • 3.7 設(shè)置側(cè)滑刪除功能[QQ側(cè)滑刪除]
    • 3.8 輕量級(jí)拖拽排序與滑動(dòng)刪除
  • 4.關(guān)于狀態(tài)切換
    • 4.1 關(guān)于布局內(nèi)容
    • 4.2 關(guān)于實(shí)現(xiàn)思路
    • 4.3 關(guān)于狀態(tài)切換api調(diào)用
    • 4.4 關(guān)于自定義狀態(tài)布局
    • 4.5 關(guān)于自定義布局交互事件處理
  • 5.常用api介紹
    • 5.1 狀態(tài)切換方法說明
    • 5.2 viewHolder方法說明
    • 5.3 adapter方法說明
    • 5.4 分割線方法說明
    • 5.5 swipe側(cè)滑方法說明
    • 5.6 其他api說明
  • 6.優(yōu)化實(shí)現(xiàn)點(diǎn)
    • 6.1 viewHolder優(yōu)化
    • 6.2 狀態(tài)管理器優(yōu)化
    • 6.3 recyclerView滑動(dòng)卡頓優(yōu)化
    • 6.4 多線程下插入數(shù)據(jù)優(yōu)化
    • 6.5 rv四級(jí)緩存
    • 6.6 異常情況下保存狀態(tài)
  • 7.實(shí)現(xiàn)效果展示
  • 8.版本更新說明
  • 9.參考資料說明
  • 10.其他內(nèi)容介紹

開源庫(kù)地址:https://github.com/yangchong211/YCRefreshView

  • 自定義支持上拉加載更多,下拉刷新,可以自定義頭部和底部,可以添加多個(gè)header,使用一個(gè)原生recyclerView就可以搞定復(fù)雜界面。支持自由切換狀態(tài)【加載中,加載成功,加載失敗,沒網(wǎng)絡(luò)等狀態(tài)】的控件,可以自定義狀態(tài)視圖View。拓展功能【支持長(zhǎng)按拖拽,側(cè)滑刪除】,輕量級(jí),可以選擇性添加 。持續(xù)更新……

1.復(fù)雜頁(yè)面庫(kù)介紹

  • 自定義支持上拉加載更多【加載中,加載失敗[比如沒有更多數(shù)據(jù)],加載異常[無網(wǎng)絡(luò)],加載成功等多種狀態(tài)】,下拉刷新,可以實(shí)現(xiàn)復(fù)雜的狀態(tài)頁(yè)面,支持自由切換狀態(tài)【加載中,加載成功,加載失敗,沒網(wǎng)絡(luò)等狀態(tài)】的控件,拓展功能[支持長(zhǎng)按拖拽,側(cè)滑刪除]可以選擇性添加。具體使用方法,可以直接參考demo案例。
  • 支持復(fù)雜type頁(yè)面,例如添加自定義頭部HeaderView和底部布局FooterView,支持橫向滑動(dòng)list,還可以支持粘貼頭部list[類似微信好友分組],支持不規(guī)則瀑布流效果,支持側(cè)滑刪除功能。

2.本庫(kù)優(yōu)勢(shì)亮點(diǎn)

2.1 支持多種狀態(tài)切換管理

  • 支持在布局中或者代碼設(shè)置自定義不同狀態(tài)的view,一行代碼既可以切換不同的狀態(tài),十分方便。
  • 針對(duì)自定義狀態(tài)view或者layout,可以實(shí)現(xiàn)交互功能,比如當(dāng)切換到網(wǎng)絡(luò)異常的頁(yè)面,可以點(diǎn)擊頁(yè)面控件取刷新數(shù)據(jù)或者跳轉(zhuǎn)設(shè)置網(wǎng)絡(luò)頁(yè)面

2.2 支持添加多個(gè)header和footer

  • 支持添加多個(gè)自定義header頭部布局,可以自定義footer底部布局。十分方便實(shí)現(xiàn)復(fù)雜type的布局頁(yè)面,結(jié)構(gòu)上層次分明,便于維護(hù)。
  • 支持復(fù)雜界面使用,比如有的頁(yè)面包含有輪播圖,按鈕組合,橫向滑動(dòng)list,還有復(fù)雜list,那么用這個(gè)控件就可以搞定。

2.3 支持側(cè)滑功能和拖拽移動(dòng)

  • 輕量級(jí)側(cè)滑刪除菜單,直接嵌套item布局即可使用,使用十分簡(jiǎn)單
  • 通過自定義ItemTouchHelper實(shí)現(xiàn)RecyclerView條目Item拖拽排序,只是設(shè)置是否拖拽,設(shè)置拖拽item的背景顏色,優(yōu)化了拖拽效果,比如在拖拽過程中設(shè)置item的縮放和漸變效果

2.4 其他亮點(diǎn)介紹

  • 支持上拉加載,下拉刷新。當(dāng)上拉加載更多失敗或者異常時(shí),可以設(shè)置自定義加載更多失敗或者異常布局(比如沒有網(wǎng)絡(luò)時(shí)的場(chǎng)景),同時(shí)點(diǎn)擊該異?;蛘呤〔季挚梢曰謴?fù)加載更多數(shù)據(jù);當(dāng)上拉加載更多沒有更多數(shù)據(jù)時(shí),可以設(shè)置自定義加載更多無數(shù)據(jù)布局。
  • 可以設(shè)置上拉加載更多后自動(dòng)加載下一頁(yè)數(shù)據(jù),也可以上拉加載更多后手動(dòng)觸發(fā)加載下一頁(yè)數(shù)據(jù)。在上拉加載更多時(shí),可以設(shè)置加載更多的布局,支持加載監(jiān)聽。
  • 支持粘貼頭部的需求效果,這種效果類似微信好友分組的那種功能界面。
  • 支持插入【插入指定索引】,更新【更新指定索引或者data數(shù)據(jù)】或者刪除某條數(shù)據(jù),支持刪除所有數(shù)據(jù)。同時(shí)在多線程條件下,添加了鎖機(jī)制避免數(shù)據(jù)錯(cuò)亂!
  • 支持橫向滑動(dòng)list效果,支持瀑布流的效果,還支持與CoordinatorLayout結(jié)合實(shí)現(xiàn)炫酷的效果。這種效果特別不錯(cuò)……
  • 已經(jīng)用于實(shí)際開發(fā)項(xiàng)目投資界,新芽,沙丘大學(xué)中……且經(jīng)過近三年時(shí)間的迭代與維護(hù),持續(xù)更新維護(hù)中!

3.如何使用介紹

3.1 最基礎(chǔ)的使用

  • 首先在集成:
    • implementation 'org.yczbj:YCRefreshViewLib:2.5.8'
  • 在布局中
    <org.yczbj.ycrefreshviewlib.YCRefreshView
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:id="@+id/recyclerView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_progress="@layout/view_custom_loading_data"
        app:layout_empty="@layout/view_custom_empty_data"
        app:layout_error="@layout/view_custom_data_error"/>
    
  • 在代碼中,初始化recyclerView
    adapter = new PersonAdapter(this);
    recyclerView.setAdapter(adapter);
    final LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
    recyclerView.setLayoutManager(linearLayoutManager);
    adapter.addAll(data);
    
  • 在代碼中,創(chuàng)建adapter實(shí)現(xiàn)RecyclerArrayAdapter<T>
    public class PersonAdapter extends RecyclerArrayAdapter<PersonData> {
    
        public PersonAdapter(Context context) {
            super(context);
        }
    
        @Override
        public BaseViewHolder OnCreateViewHolder(ViewGroup parent, int viewType) {
            return new PersonViewHolder(parent);
        }
    
        public class PersonViewHolder extends BaseViewHolder<PersonData> {
    
            private ImageView iv_news_image;
    
            PersonViewHolder(ViewGroup parent) {
                super(parent, R.layout.item_news);
                iv_news_image = getView(R.id.iv_news_image);
            }
    
            @Override
            public void setData(final PersonData person){
    
            }
        }
    }
    

3.2 添加下拉刷新和加載更多監(jiān)聽

  • 下拉刷新監(jiān)聽操作
    //設(shè)置刷新listener
    recyclerView.setRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
        @Override
        public void onRefresh() {
            //刷新操作
        }
    });
    //設(shè)置是否刷新
    recyclerView.setRefreshing(false);
    //設(shè)置刷新顏色
    recyclerView.setRefreshingColorResources(R.color.colorAccent);
    
  • 上拉加載更多監(jiān)聽操作
    • 第一種情況,上拉加載更多后自動(dòng)加載下一頁(yè)數(shù)據(jù)
    //設(shè)置上拉加載更多時(shí)布局,以及監(jiān)聽事件
    adapter.setMore(R.layout.view_more, new OnLoadMoreListener() {
        @Override
        public void onLoadMore() {
            //可以做請(qǐng)求下一頁(yè)操作
        }
    });
    
    • 第二種情況,上拉加載更多后手動(dòng)觸發(fā)加載下一頁(yè)數(shù)據(jù)
    adapter.setMore(R.layout.view_more2, new OnMoreListener() {
        @Override
        public void onMoreShow() {
            //不做處理
        }
    
        @Override
        public void onMoreClick() {
            //點(diǎn)擊觸發(fā)加載下一頁(yè)數(shù)據(jù)
        }
    });
    
  • 在上拉加載更多時(shí),可能出現(xiàn)沒有更多數(shù)據(jù),或者上拉加載失敗,該如何處理呢?
    //設(shè)置上拉加載沒有更多數(shù)據(jù)監(jiān)聽
    adapter.setNoMore(R.layout.view_no_more, new OnNoMoreListener() {
        @Override
        public void onNoMoreShow() {
            //上拉加載,沒有更多數(shù)據(jù)展示,這個(gè)方法可以暫?;蛘咄V辜虞d數(shù)據(jù)
            adapter.pauseMore();
        }
    
        @Override
        public void onNoMoreClick() {
            //這個(gè)方法是點(diǎn)擊沒有更多數(shù)據(jù)展示布局的操作,比如可以做吐司等等
            Log.e("逗比","沒有更多數(shù)據(jù)了");
        }
    });
    //設(shè)置上拉加載更多異常監(jiān)聽數(shù)據(jù)監(jiān)聽
    adapter.setError(R.layout.view_error, new OnErrorListener() {
        @Override
        public void onErrorShow() {
            //上拉加載,加載更多數(shù)據(jù)異常展示,這個(gè)方法可以暫?;蛘咄V辜虞d數(shù)據(jù)
            adapter.pauseMore();
        }
    
        @Override
        public void onErrorClick() {
            //這個(gè)方法是點(diǎn)擊加載更多數(shù)據(jù)異常展示布局的操作,比如恢復(fù)加載更多等等
            adapter.resumeMore();
        }
    });
    

3.3 添加header和footer操作

  • 添加headerView操作。至于添加footerView的操作,幾乎和添加header步驟是一樣的。
    • 添加普通的布局【非listView或者RecyclerView布局】
    adapter.addHeader(new InterItemView() {
        @Override
        public View onCreateView(ViewGroup parent) {
            View inflate = LayoutInflater.from(context).inflate(R.layout.header_view, null);
            return inflate;
        }
    
        @Override
        public void onBindView(View headerView) {
            TextView tvTitle = headerView.findViewById(R.id.tvTitle);
        }
    });
    
    • 添加list布局【以橫向recyclerView為例子】
    adapter.addHeader(new InterItemView() {
        @Override
        public View onCreateView(ViewGroup parent) {
            RecyclerView recyclerView = new RecyclerView(parent.getContext()){
                //為了不打擾橫向RecyclerView的滑動(dòng)操作,可以這樣處理
                @SuppressLint("ClickableViewAccessibility")
                @Override
                public boolean onTouchEvent(MotionEvent event) {
                    super.onTouchEvent(event);
                    return true;
                }
            };
            return recyclerView;
        }
    
        @Override
        public void onBindView(View headerView) {
            //這里的處理別忘了
            ((ViewGroup)headerView).requestDisallowInterceptTouchEvent(true);
        }
    });
    
  • 注意要點(diǎn)
    • 如果添加了HeaderView,凡是通過ViewHolder拿到的position都要減掉HeaderView的數(shù)量才能得到正確的position。

3.4 設(shè)置數(shù)據(jù)和刷新

  • 添加所有數(shù)據(jù),可以是集合,也可以是數(shù)組
    //添加所有數(shù)據(jù)
    adapter.addAll(data);
    //添加單挑數(shù)據(jù)
    adapter.add(data);
    
  • 插入,刷新和刪除數(shù)據(jù)
    //插入指定索引數(shù)據(jù),單個(gè)數(shù)據(jù)
    adapter.insert(data, pos);
    //插入指定索引數(shù)據(jù),多個(gè)數(shù)據(jù)
    adapter.insertAll(data, pos);
    //刷新指定索引數(shù)據(jù)
    adapter.update(data, pos);
    //刪除數(shù)據(jù),指定數(shù)據(jù)
    adapter.remove(data);
    //刪除數(shù)據(jù),指定索引
    adapter.remove(pos);
    //清空所有數(shù)據(jù)
    

3.5 設(shè)置adapter

  • 注意自定義adapter需要實(shí)現(xiàn)RecyclerArrayAdapter<T>,其中T是泛型,就是你要使用的bean數(shù)據(jù)類型
    public class PersonAdapter extends RecyclerArrayAdapter<PersonData> {
    
        public PersonAdapter(Context context) {
            super(context);
        }
    
        @Override
        public BaseViewHolder OnCreateViewHolder(ViewGroup parent, int viewType) {
            return new PersonViewHolder(parent);
        }
    
        public class PersonViewHolder extends BaseViewHolder<PersonData> {
    
            private TextView tv_title;
            private ImageView iv_news_image;
    
            PersonViewHolder(ViewGroup parent) {
                super(parent, R.layout.item_news);
                iv_news_image = getView(R.id.iv_news_image);
                tv_title = getView(R.id.tv_title);
    
                //添加孩子的點(diǎn)擊事件
                addOnClickListener(R.id.iv_news_image);
                addOnClickListener(R.id.tv_title);
            }
    
            @Override
            public void setData(final PersonData person){
                Log.i("ViewHolder","position"+getDataPosition());
                tv_title.setText(person.getName());
            }
        }
    }
    

3.6 設(shè)置條目點(diǎn)擊事件

  • 條目單擊點(diǎn)擊事件,長(zhǎng)按事件[省略,可以自己看代碼]
    adapter.setOnItemClickListener(new OnItemClickListener() {
        @Override
        public void onItemClick(int position) {
            if (adapter.getAllData().size()>position && position>=0){
                //處理點(diǎn)擊事件邏輯
            }
        }
    });
    
  • 條目中孩子的點(diǎn)擊事件
    //添加孩子的點(diǎn)擊事件,可以看3.5設(shè)置adapter
    addOnClickListener(R.id.iv_news_image);
    addOnClickListener(R.id.tv_title);
    
    //設(shè)置孩子的點(diǎn)擊事件
    adapter.setOnItemChildClickListener(new OnItemChildClickListener() {
        @Override
        public void onItemChildClick(View view, int position) {
            switch (view.getId()){
                case R.id.iv_news_image:
                    Toast.makeText(HeaderFooterActivity.this,
                            "點(diǎn)擊圖片了",Toast.LENGTH_SHORT).show();
                    break;
                case R.id.tv_title:
                    Toast.makeText(HeaderFooterActivity.this,
                            "點(diǎn)擊標(biāo)題",Toast.LENGTH_SHORT).show();
                    break;
                default:
                    break;
            }
        }
    });
    

3.7 設(shè)置側(cè)滑刪除功能[QQ側(cè)滑刪除]

  • 在布局文件中,這里省略部分代碼
    <org.yczbj.ycrefreshviewlib.swipeMenu.YCSwipeMenu
        android:orientation="horizontal">
        <!--item內(nèi)容-->
        <RelativeLayout
        </RelativeLayout>
    
        <!-- 側(cè)滑菜單 -->
        <Button
            android:id="@+id/btn_del"/>
        <Button
            android:id="@+id/btn_top"/>
    </org.yczbj.ycrefreshviewlib.swipeMenu.YCSwipeMenu>
    
  • 在代碼中設(shè)置
    • 在adapter中定義接口
    private OnSwipeMenuListener listener;
    public void setOnSwipeMenuListener(OnSwipeMenuListener listener) {
        this.listener = listener;
    }
    
    • 在adapter設(shè)置點(diǎn)擊事件
    View.OnClickListener clickListener = new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            switch (v.getId()){
                case R.id.btn_del:
                    if (null != listener) {
                        listener.toDelete(getAdapterPosition());
                    }
                    break;
                case R.id.btn_top:
                    if (null != listener) {
                        listener.toTop(getAdapterPosition());
                    }
                    break;
            }
        }
    };
    btn_del.setOnClickListener(clickListener);
    btn_top.setOnClickListener(clickListener);
    
  • 處理置頂或者刪除的功能
    adapter.setOnSwipeMenuListener(new OnSwipeMenuListener() {
        //刪除功能
        @Override
        public void toDelete(int position) {
    
        }
    
        //置頂功能
        @Override
        public void toTop(int position) {
    
        }
    });
    

3.8 輕量級(jí)拖拽排序與滑動(dòng)刪除

  • 處理長(zhǎng)按拖拽,滑動(dòng)刪除的功能。輕量級(jí),自由選擇是否實(shí)現(xiàn)。
    mCallback = new DefaultItemTouchHelpCallback(new DefaultItemTouchHelpCallback
                            .OnItemTouchCallbackListener() {
        @Override
        public void onSwiped(int adapterPosition) {
            // 滑動(dòng)刪除的時(shí)候,從數(shù)據(jù)庫(kù)、數(shù)據(jù)源移除,并刷新UI
        }
    
        @Override
        public boolean onMove(int srcPosition, int targetPosition) {
            return false;
        }
    });
    mCallback.setDragEnable(true);
    mCallback.setSwipeEnable(true);
    mCallback.setColor(this.getResources().getColor(R.color.colorAccent));
    ItemTouchHelper itemTouchHelper = new ItemTouchHelper(mCallback);
    itemTouchHelper.attachToRecyclerView(recyclerView);
    

4.關(guān)于狀態(tài)切換

4.1 關(guān)于布局內(nèi)容

  • YCRecyclerView是一個(gè)組合自定義控件,其布局如下所示
     <!--刷新控件    省略部分代碼-->
    <android.support.v4.widget.SwipeRefreshLayout>
        <FrameLayout>
            <!--RecyclerView控件-->
            <android.support.v7.widget.RecyclerView/>
            <!--加載數(shù)據(jù)為空時(shí)的布局-->
            <FrameLayout/>
            <!--正在加載數(shù)據(jù)中的布局-->
            <FrameLayout/>
            <!--加載錯(cuò)誤時(shí)的布局:網(wǎng)絡(luò)錯(cuò)誤或者請(qǐng)求數(shù)據(jù)錯(cuò)誤-->
            <FrameLayout/>
        </FrameLayout>
    </android.support.v4.widget.SwipeRefreshLayout>
    

4.2 關(guān)于實(shí)現(xiàn)思路

  • 關(guān)于頁(yè)面狀態(tài)切換的思路
    • 第一種方式:直接把這些界面include到main界面中,然后動(dòng)態(tài)去切換界面,后來發(fā)現(xiàn)這樣處理不容易復(fù)用到其他項(xiàng)目中,而且在activity中處理這些狀態(tài)的顯示和隱藏比較亂
    • 第二種方式:利用子類繼承父類特性,在父類中寫切換狀態(tài),但有些界面如果沒有繼承父類,又該如何處理
  • 而本庫(kù)采用的做法思路
    • 一個(gè)幀布局FrameLayout里寫上4種不同類型布局,正常布局,空布局,加載loading布局,錯(cuò)誤布局[網(wǎng)絡(luò)異常,加載數(shù)據(jù)異常]
    • 當(dāng)然也可以自定義這些狀態(tài)的布局,通過addView的形式,將不同狀態(tài)布局添加到對(duì)應(yīng)的FrameLayout中。而切換狀態(tài),只需要設(shè)置布局展示或者隱藏即可。

4.3 關(guān)于狀態(tài)切換api調(diào)用

  • 如下所示
    //設(shè)置加載數(shù)據(jù)完畢狀態(tài)
    recyclerView.showRecycler();
    //設(shè)置加載數(shù)據(jù)為空狀態(tài)
    recyclerView.showEmpty();
    //設(shè)置加載錯(cuò)誤狀態(tài)
    recyclerView.showError();
    //設(shè)置加載數(shù)據(jù)中狀態(tài)
    recyclerView.showProgress();
    

4.4 關(guān)于自定義狀態(tài)布局

  • 如下所示
    //設(shè)置空狀態(tài)頁(yè)面自定義布局
    recyclerView.setEmptyView(R.layout.view_custom_empty_data);
    recyclerView.setEmptyView(view);
    //獲取空頁(yè)面自定義布局
    View emptyView = recyclerView.getEmptyView();
    
    //設(shè)置異常狀態(tài)頁(yè)面自定義布局
    recyclerView.setErrorView(R.layout.view_custom_data_error);
    recyclerView.setErrorView(view);
    
    //設(shè)置加載loading狀態(tài)頁(yè)面自定義布局
    recyclerView.setProgressView(R.layout.view_progress_loading);
    recyclerView.setProgressView(view);
    

4.5 關(guān)于自定義布局交互事件處理

  • 有時(shí)候,加載頁(yè)面出現(xiàn)異常情況,比如沒有網(wǎng)絡(luò)會(huì)顯示自定義的網(wǎng)絡(luò)異常頁(yè)面。現(xiàn)在需要點(diǎn)擊異常頁(yè)面按鈕等等操作,那么該如何做呢?
    //注意需要
    LinearLayout ll_error_view = (LinearLayout) recyclerView.findViewById(R.id.ll_error_view);
    ll_error_view.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            //比如,跳轉(zhuǎn)到網(wǎng)絡(luò)設(shè)置頁(yè)面,或者再次刷新數(shù)據(jù),或者其他操作等等
        }
    });
    

5.常用api介紹

  • 狀態(tài)切換方法說明
    //設(shè)置加載數(shù)據(jù)完畢狀態(tài)
    recyclerView.showRecycler();
    //設(shè)置加載數(shù)據(jù)為空狀態(tài)
    recyclerView.showEmpty();
    //設(shè)置加載錯(cuò)誤狀態(tài)
    recyclerView.showError();
    //設(shè)置加載數(shù)據(jù)中狀態(tài)
    recyclerView.showProgress();
    //設(shè)置自定義布局,其他幾個(gè)方法同理
    recyclerView.setEmptyView(R.layout.view_custom_empty_data);
    
  • viewHolder方法說明
    //子類設(shè)置數(shù)據(jù)方法
    setData方法
    //findViewById方式
    iv_news_image = getView(R.id.iv_news_image);
    //獲取上下文
    Context context = getContext();
    //獲取數(shù)據(jù)索引的位置
    int dataPosition = getDataPosition();
    //添加item中子控件的點(diǎn)擊事件
    addOnClickListener(R.id.tv_title);
    
  • adapter方法說明
    //刪除索引處的數(shù)據(jù)
    adapter.remove(0);
    //觸發(fā)清空所有數(shù)據(jù)
    adapter.removeAll();
    //添加數(shù)據(jù),注意這個(gè)是在最后索引處添加
    adapter.add(new PersonData());
    //添加所有數(shù)據(jù)
    adapter.addAll(DataProvider.getPersonList(0));
    //插入數(shù)據(jù)
    adapter.insert(data,3);
    //在某個(gè)索引處插入集合數(shù)據(jù)
    adapter.insertAll(data,3);
    //獲取item索引位置
    adapter.getPosition(data);
    //觸發(fā)清空所有的數(shù)據(jù)
    adapter.clear();
    //獲取所有的數(shù)據(jù)
    adapter.getAllData();
    
    //清除所有footer
    adapter.removeAllFooter();
    //清除所有header
    adapter.removeAllHeader();
    //添加footerView
    adapter.addFooter(view);
    //添加headerView
    adapter.addHeader(view);
    //移除某個(gè)headerView
    adapter.removeHeader(view);
    //移除某個(gè)footerView
    adapter.removeFooter(view);
    //獲取某個(gè)索引處的headerView
    adapter.getHeader(0);
    //獲取某個(gè)索引處的footerView
    adapter.getFooter(0);
    //獲取footer的數(shù)量
    adapter.getFooterCount();
    //獲取header的數(shù)量
    adapter.getHeaderCount();
    
    //設(shè)置上拉加載更多的自定義布局和監(jiān)聽
    adapter.setMore(R.layout.view_more,listener);
    //設(shè)置上拉加載更多的自定義布局和監(jiān)聽
    adapter.setMore(view,listener);
    //設(shè)置上拉加載沒有更多數(shù)據(jù)布局
    adapter.setNoMore(R.layout.view_nomore);
    //設(shè)置上拉加載沒有更多數(shù)據(jù)布局
    adapter.setNoMore(view);
    //設(shè)置上拉加載沒有更多數(shù)據(jù)監(jiān)聽
    adapter.setNoMore(R.layout.view_nomore,listener);
    //設(shè)置上拉加載異常的布局
    adapter.setError(R.layout.view_error);
    //設(shè)置上拉加載異常的布局
    adapter.setError(view);
    //設(shè)置上拉加載異常的布局和異常監(jiān)聽
    adapter.setError(R.layout.view_error,listener);
    //暫停上拉加載更多
    adapter.pauseMore();
    //停止上拉加載更多
    adapter.stopMore();
    //恢復(fù)上拉加載更多
    adapter.resumeMore();
    
    //獲取上下文
    adapter.getContext();
    //應(yīng)該使用這個(gè)獲取item個(gè)數(shù)
    adapter.getCount();
    //設(shè)置操作數(shù)據(jù)[增刪改查]后,是否刷新adapter
    adapter.setNotifyOnChange(true);
    
    //設(shè)置孩子點(diǎn)擊事件
    adapter.setOnItemChildClickListener(listener);
    //設(shè)置條目點(diǎn)擊事件
    adapter.setOnItemClickListener(listener);
    //設(shè)置條目長(zhǎng)按事件
    adapter.setOnItemLongClickListener(listener);
    
  • 分割線方法說明
    //可以設(shè)置線條顏色和寬度的分割線
    //四個(gè)參數(shù),上下文,方向,線寬,顏色
    final RecycleViewItemLine line = new RecycleViewItemLine(this, LinearLayout.HORIZONTAL,
            (int)AppUtils.convertDpToPixel(1,this),
            this.getResources().getColor(R.color.color_f9f9f9));
    recyclerView.addItemDecoration(line);
    
    //適用于瀑布流中的間距設(shè)置
    SpaceViewItemLine itemDecoration = new SpaceViewItemLine(
            (int) AppUtils.convertDpToPixel(8,this));
    itemDecoration.setPaddingEdgeSide(true);
    itemDecoration.setPaddingStart(true);
    itemDecoration.setPaddingHeaderFooter(true);
    recyclerView.addItemDecoration(itemDecoration);
    
    //可以設(shè)置線條顏色和寬度,并且可以設(shè)置距離左右的間距
    DividerViewItemLine itemDecoration = new
            DividerViewItemLine( this.getResources().getColor(R.color.color_f9f9f9)
            , LibUtils.dip2px(this, 1f),
            LibUtils.dip2px(this, 72), 0);
    itemDecoration.setDrawLastItem(false);
    recyclerView.addItemDecoration(itemDecoration);
    
  • 其他api說明

7.實(shí)現(xiàn)效果展示

7.1 使用過YCRefreshView庫(kù)的案例代碼

7.2 圖片展示效果

1.jpg

2.jpg

3.jpg

4.jpg

5.jpg

6.jpg

7.jpg

8.jpg

9.jpg

10.jpg

11.jpg

12.jpg

7.3 部分案例圖展示[部分案例圖可以參考7.1]

image

image

8.版本更新說明

  • v1.0 更新于2016年11月2日
  • v1.1 更新于2017年3月13日
  • v1.3 更新于2017年8月9日
  • v1.…… 更新于2018年1月5日
  • v2.2 更新于2018年1月17日
  • v2.3 更新于2018年2月9日
  • v2.4 更新于2018年3月19日
  • v2.5.6 更新于2018年8月6日
  • v2.5.7 更新于2019年3月3日
  • v2.5.8 更新于2019年3月4日

9.參考資料說明

10.其他內(nèi)容介紹

01.關(guān)于博客匯總鏈接

02.關(guān)于我的博客

03.勘誤及提問

  • 如果有疑問或者發(fā)現(xiàn)錯(cuò)誤,可以在相應(yīng)的 issues 進(jìn)行提問或勘誤。如果喜歡或者有所啟發(fā),歡迎star,對(duì)作者也是一種鼓勵(lì)。

04.關(guān)于LICENSE

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

關(guān)于開源庫(kù)地址:https://github.com/yangchong211/YCRefreshView

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容