繪制RecyclerView的分隔線

RecyclerView

現(xiàn)在開發(fā)Android的都知道,RecyclerView可以替代ListView和GridView,因為它的自由度很高,我們可以很隨意的展示我們的數(shù)據(jù)集,還有默認的動畫!但是有一個瑕疵,那就是沒有提供一個分隔線的實現(xiàn)類,只有一個抽象類(RecyclerView.ItemDecoration)等著我們自己去實現(xiàn)!不過實現(xiàn)起來還是很簡單的。

自定義ItemDecoration的步驟(我以豎向舉例)

  1. 新建一個類,繼承自RecyclerView.ItemDecoration
  2. 把各個item之間的距離加大!留出空間給我們要繪制的分隔線。所以要重寫getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state)方法,設(shè)置偏移量!
  3. 繪制分隔線到上面設(shè)置的間距,重寫onDraw()方法。

代碼實現(xiàn)

public class MyItemDecoration extends RecyclerView.ItemDecoration {
    //分隔線
    Drawable mDivider;

    //我們通過獲取系統(tǒng)屬性中的listDivider來添加,在系統(tǒng)中的AppTheme中設(shè)置
    public static final int[] ATRRS  = new int[]{
            android.R.attr.listDivider
    };
    public MyItemDecoration(Context context, int orientation){
        TypedArray ta = context.obtainStyledAttributes(ATRRS);
        mDivider = ta.getDrawable(0);
        ta.recycle();
    }

    @Override
    public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
       int pos =parent.getChildLayoutPosition(view);//得到當(dāng)前view的位置
       if(pos != parent.getAdapter().getItemCount()-1) {//如果不是最后一個view 那么留出空間
            //設(shè)置paddingLeft,paddingTop, paddingRight, paddingBottom
            outRect.set(0,0,0,mDivider.getIntrinsicHeight());
            //mDivider.getIntrinsicHeight()是獲取我們定義的分隔線的高度!
          }
    }
}
設(shè)置offset后的效果

我們可以看到已經(jīng)有白色的空間了!我們想用自定義的顏色去填充它,接來下我們先在drawable目錄下建一個shape,作為我們的divider:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="@color/grey"></solid>
<size android:height="4dp"></size>
</shape>

然后在styles的主題AppTheme里設(shè)置:

<item name="android:listDivider">@drawable/divider_bg</item>

然后我們繼續(xù)繪制我們的分隔線,重寫onDraw()方法:

    @Override
    public void onDraw(Canvas c, RecyclerView parent, RecyclerView.State state) {
        //設(shè)置分隔線的left和right
        int left = parent.getPaddingLeft();
        int right = parent.getWidth() - parent.getPaddingRight();

        for (int i = 0; i < parent.getChildCount(); i++) {
            View view = parent.getChildAt(i);
            RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) view.getLayoutParams();
            //分隔線的top和bottom
            int top = view.getBottom()+params.bottomMargin;
            int bottom = top + mDivider.getIntrinsicHeight();
            //分隔線的繪制區(qū)域
            mDivider.setBounds(left,top,right,bottom);
            //把分隔線繪制到canvas
            mDivider.draw(c);
        }
    }

然后運行結(jié)果:


運行結(jié)果

我們可以在shape中畫出漸變效果,然后分隔符就變成這樣了:

漸變運行結(jié)果

到此我們就完工了,很簡單,只需要重寫兩個方法就可以了!
下一篇:繪制分組懸浮分隔欄

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

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

  • 解密RecyclerView自定義分割線 RecyclerView的分割線ItemDecoration是可以自定制...
    孤獨的追尋著閱讀 2,267評論 0 5
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,007評論 25 709
  • 這篇文章分三個部分,簡單跟大家講一下 RecyclerView 的常用方法與奇葩用法;工作原理與ListView比...
    LucasAdam閱讀 4,700評論 0 27
  • 懸浮ItemDecoration 先來一個效果圖: 思路步驟 設(shè)置回調(diào)接口,用于判斷每個item的類型,以及各個類...
    CSU_IceLee閱讀 914評論 1 8
  • 昨晚是我們第93期讀書會,去的路上我的眼皮很重,困的不行。迷迷糊糊的做地鐵,來到了上次和華一起吃飯的地方~吉祥餛飩...
    心理咨詢師萍閱讀 596評論 2 2

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