博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android零基础入门第65节:RecyclerView分割线开发技巧
阅读量:6304 次
发布时间:2019-06-22

本文共 4226 字,大约阅读时间需要 14 分钟。

hot3.png

   在上一期通过简单学习,已经领略到了RecyclerView的灵活性,当然都是一些最基础的用法,那么本期一起来学习RecyclerView的分割线使用。

    相信有的比较细心的同学已经发现了,使用RecyclerView实现的List列表和ListView实现的列表有一些细微差距,item之间没有分割线,导致item之间相隔不明显,但在实际开发中有又往往需要。

    由于RecyclerView并没有支持divider这样的属性,需要我们自己想办法来完成。主要有两种实现方式,接下来分别对其进行学习。

0Gmb0GTd40O

 

 

一、背景设置显示间隔 

 

    先给RecyclerView添加黑色背景,然后再给每个item添加白色背景并设置间隔1dp,这样自然就用背景空隙当做分割线了。

    在上一期的基础上进行简单修改即可,修改后的recyclerview_layout.xml文件代码如下:

    修改后的recyclerview_item.xml文件代码如下:

    其他地方的代码不变,重新运行程序,可以看到下图所示的分割线。

0Gmb0DZQr4q

 

 

二、自定义分割线

 

    上面第一种实现方式非常简单,但有时候还是不足以完成实际需求,这就需要用到自定义分割线了。

    还记得上期里面提到的ItemDecoration类的作用了吗?RecyclerView类也提供了一个addItemDecoration方法,我们可以通过该方法添加分割线。

    首先我们自定义一个drawable文件recyclerview_item_divider,具体内容后续会进行学习的,这里不做过多介绍,代码如下:

    由于RecyclerView.ItemDecoration为抽象类,需要自定义一个实现类,该类很好的实现了为RecyclerView添加分割线。新建RecyclerViewItemDivider类,具体代码如下:

package com.jinyu.cqkxzsxy.android.advancedviewsample.view;import android.content.Context;import android.graphics.Canvas;import android.graphics.Rect;import android.graphics.drawable.Drawable;import android.support.v7.widget.RecyclerView;import android.view.View;/** * @创建者 鑫鱻 * @描述 Android零基础入门到精通系列教程 * 首发微信公众号分享达人秀(ShareExpert) */public class RecyclerViewItemDivider extends RecyclerView.ItemDecoration {    private Drawable mDrawable;    public RecyclerViewItemDivider(Context context, int resId) {        mDrawable = context.getResources().getDrawable(resId);    }    @Override    public void onDrawOver(Canvas c, RecyclerView parent, RecyclerView.State state) {        int left = parent.getPaddingLeft();        int right = parent.getWidth() - parent.getPaddingRight();        int childCount = parent.getChildCount();        for (int i = 0; i < childCount; i++) {            View child = parent.getChildAt(i);            RecyclerView.LayoutParams params = (RecyclerView.LayoutParams) child.getLayoutParams();            int top = child.getBottom() + params.bottomMargin;            int bottom = top + mDrawable.getIntrinsicHeight();            mDrawable.setBounds(left, top, right, bottom);            mDrawable.draw(c);        }    }    @Override    public void getItemOffsets(Rect outRect, View view, RecyclerView parent,                               RecyclerView.State state) {        outRect.set(0, 0, 0, mDrawable.getIntrinsicWidth());    }}

    然后在将自定义的分割线添加到RecyclerView中,局部代码如下:

// 设置管理器        LinearLayoutManager layoutManager = new LinearLayoutManager(this);        mRecyclerView.setLayoutManager(layoutManager);        // 自定义分割线        RecyclerView.ItemDecoration itemDecoration = new RecyclerViewItemDivider(this,                R.drawable.recyclerview_item_divider);        mRecyclerView.addItemDecoration(itemDecoration);        // 如果可以确定每个item的高度是固定的,设置这个选项可以提高性能        mRecyclerView.setHasFixedSize(true);

    其余代码不变,重新运行程序,可以看到下图所示界面效果。

0Gmb0Exqups

    可以看到,自定义分割线的自由度和灵活性较大,也更加炫丽,完全可以根据实际需要来定制。

    上面学习的自定义分割线只适合纵向列表,由于横向列表和网格布局每一行都有多个子视图,需要重新定义一个ItemDecoration类,这里就不作过多介绍了。

 

    今天就先到这里,如果有问题欢迎留言一起探讨,也欢迎加入Android零基础入门技术讨论微信群,共同成长!

   此文章版权为微信公众号分享达人秀(ShareExpert)——鑫鱻所有,若需转载请联系作者授权,特此声明!

 

往期总结分享:

Android零基础入门第1节:

Android零基础入门第2节:

Android零基础入门第3节:

Android零基础入门第4节:

Android零基础入门第5节:

Android零基础入门第6节:

Android零基础入门第7节:

Android零基础入门第8节:

Android零基础入门第9节:

Android零基础入门第10节:

Android零基础入门第11节:

Android零基础入门第12节:

Android零基础入门第13节:

Android零基础入门第14节:

Android零基础入门第15节:

Android零基础入门第16节:

Android零基础入门第17节:

Android零基础入门第18节:

Android零基础入门第19节:

Android零基础入门第20节:

Android零基础入门第21节:

Android零基础入门第22节:

Android零基础入门第23节:

Android零基础入门第24节:

Android零基础入门第25节:

Android零基础入门第26节:

Android零基础入门第27节:

Android零基础入门第28节:

Android零基础入门第29节:

Android零基础入门第30节:

Android零基础入门第31节:

Android零基础入门第32节:

Android零基础入门第33节:

Android零基础入门第34节:

Android零基础入门第35节:

Android零基础入门第36节:

Android零基础入门第37节:

Android零基础入门第38节:

Android零基础入门第39节:

Android零基础入门第40节:

Android零基础入门第41节:

Android零基础入门第42节:

Android零基础入门第43节:

Android零基础入门第44节:

Android零基础入门第45节:

Android零基础入门第46节:

Android零基础入门第47节:

Android零基础入门第48节:

Android零基础入门第49节:

Android零基础入门第50节:

Android零基础入门第51节:

Android零基础入门第52节:

Android零基础入门第53节:

Android零基础入门第54节:

Android零基础入门第55节:

Android零基础入门第56节:

Android零基础入门第57节:

Android零基础入门第58节:

Android零基础入门第59节:

Android零基础入门第60节:

Android零基础入门第61节:

Android零基础入门第62节:

Android零基础入门第63节:

Android零基础入门第64节:

0Gmb02M7zVY

0Gmb03lMzpI

转载于:https://my.oschina.net/u/3598984/blog/1540279

你可能感兴趣的文章
分享10款漂亮实用的CSS3按钮
查看>>
安装nginx 常见错误及 解决方法
查看>>
Gorun8电子商城
查看>>
在之前链表的基础上改良的链表
查看>>
android编译系统makefile(Android.mk)写法
查看>>
MD5源代码C++
查看>>
Eclipse 添加 Ibator
查看>>
Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义
查看>>
Python编程语言
查看>>
十四、转到 linux
查看>>
Got error 241 'Invalid schema
查看>>
ReferenceError: event is not defined
查看>>
男人要内在美,更要外在美
查看>>
为什么要跟别人比?
查看>>
app启动白屏
查看>>
Oracle 提高查询性能(基础)
查看>>
学习知识应该像织网一样去学习——“网状学习法”
查看>>
Hadoop集群完全分布式安装
查看>>
QString,char,string之间赋值
查看>>
我的友情链接
查看>>