2019独角兽企业重金招聘Python工程师标准>>>

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

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

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

一、背景设置显示间隔

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

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

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical"android:layout_width="match_parent"android:layout_height="match_parent"><android.support.v7.widget.RecyclerViewandroid:id="@+id/recyclerview"android:background="#5000"android:layout_width="wrap_content"android:layout_height="wrap_content"/>
</LinearLayout>

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

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="wrap_content"android:layout_height="wrap_content"android:background="#fff"android:layout_marginBottom="1dp"android:padding="6dp" ><ImageViewandroid:id="@+id/icon_img"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerVertical="true"android:layout_marginRight="6dp"android:contentDescription="null"android:src="@mipmap/ic_launcher" /><TextViewandroid:id="@+id/title_tv"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_toRightOf="@id/icon_img"android:layout_alignParentTop="true"android:layout_marginTop="5dp"android:gravity="center_vertical"android:text="Title"android:textSize="16sp" /><TextViewandroid:id="@+id/content_tv"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_toRightOf="@id/icon_img"android:layout_alignParentRight="true"android:layout_below="@id/title_tv"android:layout_marginTop="5dp"android:text="content"android:textSize="12sp" /></RelativeLayout>

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

二、自定义分割线

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

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

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

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="rectangle"><gradientandroid:centerColor="#ff00ff00"android:endColor="#ff0000ff"android:startColor="#ffff0000"android:type="linear" /><size android:height="1dp"/>
</shape>

由于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);}@Overridepublic 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);}}@Overridepublic 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);

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

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

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

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

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

往期总结分享:

Android零基础入门第1节:Android的前世今生

Android零基础入门第2节:Android 系统架构和应用组件那些事

Android零基础入门第3节:带你一起来聊一聊Android开发环境

Android零基础入门第4节:正确安装和配置JDK, 高富帅养成第一招

Android零基础入门第5节:善用ADT Bundle, 轻松邂逅女神

Android零基础入门第6节:配置优化SDK Manager, 正式约会女神

Android零基础入门第7节:搞定Android模拟器,开启甜蜜之旅

Android零基础入门第8节:HelloWorld,我的第一趟旅程出发点

Android零基础入门第9节:Android应用实战,不懂代码也可以开发

Android零基础入门第10节:开发IDE大升级,终于迎来了Android Studio

Android零基础入门第11节:简单几步带你飞,运行Android Studio工程

Android零基础入门第12节:熟悉Android Studio界面,开始装逼卖萌

Android零基础入门第13节:Android Studio个性化配置,打造开发利器

Android零基础入门第14节:使用高速Genymotion,跨入火箭时代

Android零基础入门第15节:掌握Android Studio项目结构,扬帆起航

Android零基础入门第16节:Android用户界面开发概述

Android零基础入门第17节:文本框TextView

Android零基础入门第18节:输入框EditText

Android零基础入门第19节:按钮Button

Android零基础入门第20节:复选框CheckBox和单选按钮RadioButton

Android零基础入门第21节:开关组件ToggleButton和Switch

Android零基础入门第22节:图像视图ImageView

Android零基础入门第23节:图像按钮ImageButton和缩放按钮ZoomButton

Android零基础入门第24节:自定义View简单使用,打造属于你的控件

Android零基础入门第25节:简单且最常用的LinearLayout线性布局

Android零基础入门第26节:两种对齐方式,layout_gravity和gravity大不同

Android零基础入门第27节:正确使用padding和margin

Android零基础入门第28节:轻松掌握RelativeLayout相对布局

Android零基础入门第29节:善用TableLayout表格布局

Android零基础入门第30节:两分钟掌握FrameLayout帧布局

Android零基础入门第31节:少用的AbsoluteLayout绝对布局

Android零基础入门第32节:新推出的GridLayout网格布局

Android零基础入门第33节:Android事件处理概述

Android零基础入门第34节:Android中基于监听的事件处理

Android零基础入门第35节:Android中基于回调的事件处理

Android零基础入门第36节:Android系统事件的处理

Android零基础入门第37节:初识ListView

Android零基础入门第38节:初识Adapter

Android零基础入门第39节:ListActivity和自定义列表项

Android零基础入门第40节:自定义ArrayAdapter

Android零基础入门第41节:使用SimpleAdapter

Android零基础入门第42节:自定义BaseAdapter

Android零基础入门第43节:ListView优化和列表首尾使用

Android零基础入门第44节:ListView数据动态更新

Android零基础入门第45节:网格视图GridView

Android零基础入门第46节:列表选项框Spinner

Android零基础入门第47节:自动完成文本框AutoCompleteTextView

Android零基础入门第48节:可折叠列表ExpandableListView

Android零基础入门第49节:AdapterViewFlipper图片轮播

Android零基础入门第50节:StackView卡片堆叠

Android零基础入门第51节:进度条ProgressBar

Android零基础入门第52节:自定义ProgressBar炫酷进度条

Android零基础入门第53节:拖动条SeekBar和星级评分条RatingBar

Android零基础入门第54节:视图切换组件ViewSwitcher

Android零基础入门第55节:ImageSwitcher和TextSwitcher

Android零基础入门第56节:翻转视图ViewFlipper

Android零基础入门第57节:DatePicker和TimePicker选择器

Android零基础入门第58节:数值选择器NumberPicker

Android零基础入门第59节:常用三大Clock时钟组件

Android零基础入门第60节:日历视图CalendarView和定时器Chronometer

Android零基础入门第61节:滚动视图ScrollView

Android零基础入门第62节:搜索框组件SearchView

Android零基础入门第63节:值得借鉴学习的选项卡TabHost

Android零基础入门第64节:揭开RecyclerView庐山真面目

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

Android零基础入门第65节:RecyclerView分割线开发技巧相关推荐

  1. Android零基础入门第68节:完善RecyclerView,添加首尾视图

    2019独角兽企业重金招聘Python工程师标准>>> 在之前学习ListView的时候,有学习过如何给ListView添加列表头和列表尾.但是通过近几期的学习,发现Recycler ...

  2. Android零基础入门第77节:Activity任务栈和启动模式

    2019独角兽企业重金招聘Python工程师标准>>> 通过前面的学习,Activity的基本使用都已掌握,接下来一起来学习更高级的一些内容. Android采用任务栈(Task)的 ...

  3. Android零基础入门第89节:Fragment回退栈及弹出方法

    2019独角兽企业重金招聘Python工程师标准>>> 在上一期分享的文章末尾留了一个课后作业,有去思考如何解决吗?如果已经会了那么恭喜你,如果还不会也没关系,本期一起来学习. 一. ...

  4. Android零基础入门第81节:Activity数据传递

    在Android开发中,经常要在Activity之间传递数据.前面也学习了Activity和Intent相关基础,接下来一起来学习Activity的数据传递. 一.简介 通过前面的学习知道,Inten ...

  5. Android零基础入门第83节:Activity间数据传递方法汇总

    2019独角兽企业重金招聘Python工程师标准>>> 在Activity间传递的数据一般比较简单,但是有时候实际开发中也会传一些比较复杂的数据,本节一起来学习更多Activity间 ...

  6. Android零基础入门第85节:Fragment使用起来非常简单

    2019独角兽企业重金招聘Python工程师标准>>> Fragment创建完成后并不能单独使用,还需要将Fragment加载到Activity中,在Activity中添加Fragm ...

  7. Android零基础入门第87节:Fragment添加、删除、替换

    2019独角兽企业重金招聘Python工程师标准>>> 前面一起学习了Fragment的创建和加载,以及其生命周期方法,那么接下来进一步来学习Fragment的具体使用,本期先来学习 ...

  8. Android零基础入门第86节:探究Fragment生命周期

    2019独角兽企业重金招聘Python工程师标准>>> 一个Activity可以同时组合多个Fragment,一个Fragment也可被多个Activity 复用.Fragment可 ...

  9. Android零基础入门第75节:Activity状态和生命周期方法

    前面两期我们学习了Activity的创建和注册.以及启动和关闭,也学会了重写onCraete方法,这些知识在实际开发中远远不够,还需要学习了解更多. 生命周期就是一个对象从创建到销毁的过程,每一个对象 ...

最新文章

  1. 虚拟机VMWare“提示:软件虚拟化与此平台上的长模式不兼容”的解决方法
  2. 原创 | 看过《中国机长》,我开始关心航空预测性维修这件事了
  3. DB2命令行查看执行计划
  4. SAP 开发陷阱一箩筐(01)——创建了函数组却无法激活
  5. P3521-[POI2011]ROT-Tree【线段树合并】
  6. 操作符offset和seg
  7. (连通图 ) Redundant Paths --POJ --3177
  8. zabbix4.2学习笔记--监控tomcat
  9. php怎么循环显示图片,thinkphp 循环显示图片问题!!!~~~~
  10. 3D物理引擎JiglibFlash
  11. poj3263 Tallest Cow 题解报告
  12. 常量、变量;基本数据类型;input()、if、while、break、continue
  13. javascript 绘制uml_Javascript 设计模式之面向对象与 UML 类图
  14. 自动驾驶 7-1 Carla 概述 - 自动驾驶汽车模拟Carla Overview - Self-Driving Car Simulation
  15. 项目保密协议书(范本)
  16. python定义数组长度_python数组长度
  17. Python 爬楼梯问题--有n阶台阶,上楼可以一步上1阶,2阶,3阶,计算共有多少种不同的走法?
  18. Macos安装lightgbm时遇到的坑
  19. matlab模拟超声波信号_MATLAB模拟超声波声速测量实验
  20. Win7宝典 / Windows7宝典

热门文章

  1. Android之热修复框架Nuwa
  2. Arduino(新手之路1)
  3. TCP断开连接为什么是4次挥手?
  4. 大连理工大学计算机原理实验交通灯,大连理工大学计算机原理第四次实验.docx...
  5. 编码区和非编码区的关系
  6. select,poll,epoll
  7. Java排序算法之归并排序
  8. MySQL 单表百万数据记录分页性能优化
  9. [小明学Shader]1.Diffuse
  10. 1005. 继续(3n+1)猜想 (25) (ZJUPAT 数学)