Android RecycleView(二)——添加分割线

     上一篇 Android RecycleView(一)完成了最最基本的recycleview的用法 这一篇,完成其分割线的设置。

recycleview 有其自己设置分割线的方法:recyclerView.addItemDecoration() 参数是我们自己定义的一个ItemDecoration通过自定义itemDecoration

我们可以根据自己的喜好来自定义分割线的样式,无论是color还是图片,或者自定义的shape。

自定义itemDecoration:

继承系统提供的RecyclerView.ItemDecoration重写onDraw或onDrawOver方法   一个实在childitem之前绘制一个是在childitem之后绘制。

package com.chs.myrecycleview.adapter;

import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Canvas;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.support.v7.widget.RecyclerView;
import android.view.View;

import com.chs.myrecycleview.R;

/**
 * 作者:chs on 2016/2/2 15:20
 * 邮箱:657083984@qq.com
 */
public class RecycleViewDivider extends RecyclerView.ItemDecoration{
    private Drawable drawable;
    public RecycleViewDivider(Context context) {
        drawable = context.getResources().getDrawable(R.mipmap.list_divider);
        drawable = context.getResources().getDrawable(R.drawable.shape);
    }
    @Override
    public void onDraw(Canvas c, RecyclerView parent, RecyclerView.State state) {
//        drawVertical(c, parent);
    }

    @Override
    public void onDrawOver(Canvas c, RecyclerView parent, RecyclerView.State state) {
        super.onDrawOver(c, parent, state);
        drawVertical(c, parent);
    }

    private void drawVertical(Canvas canvas, RecyclerView parent) {
        int left = parent.getPaddingLeft();
        int right = parent.getWidth()-parent.getPaddingRight();
        View child;
        RecyclerView.LayoutParams layoutParams;
        int top;
        int bottom;
        int count = parent.getChildCount();
        for(int i = 0;i<count;i++){
            child = parent.getChildAt(i);
            layoutParams = (RecyclerView.LayoutParams) child.getLayoutParams();
            top = child.getBottom()+layoutParams.bottomMargin;
            bottom = top+drawable.getIntrinsicHeight();
            drawable.setBounds(left,top,right,bottom);
            drawable.draw(canvas);
        }

    }
//如果等于分割线的高度或宽度的话可以不重写次方法
    @Override
    public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
        if (parent.getChildPosition(view) == parent.getChildCount() - 1) {
            outRect.set(0, 0, 0, 0);
        } else {
            outRect.set(0, 0, 0, drawable.getIntrinsicHeight());
        }
    }
}


</pre><p></p><pre>
效果图  一个是用的图片,一个是用的自定义的一个shape

这样就实现它的分割线了 并且我们可以随意的绘制。

这种方法比较简单,但是如果我们把上述代码放到编译器中,你会发现构造方法中的

context.getResources().getDrawable(R.mipmap.list_divider); 这个方法是被废弃的一个方法。最然现在可以用,但是毕竟有风险,反正我不喜欢看到一个横杠在代码上画着。
后来发现我们可以通过改变系统属性来实现  系统属性 listDivider
  <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
        <item name="android:listDivider">@drawable/shape</item>
    </style>
 

构造方法中改为:

   public RecycleViewDivider(Context context) {
//        drawable = context.getResources().getDrawable(R.mipmap.list_divider);
//        drawable = context.getResources().getDrawable(R.drawable.shape);
        TypedArray array = context.obtainStyledAttributes(new int[]{android.R.attr.listDivider});
        drawable = array.getDrawable(0);
        array.recycle();
    }


效果:


跟上面的效果一样而且没有被废弃的方法,还是比较完美哈哈

OK分割线已经搞定  但是我们还会发现一个让人郁闷的地方,它没有提供给我们 OnclickListener和OnLongClickListener方法

一种简单的方法我们可以去adapter中自己实现 ,下一篇在写吧~~


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值