效果图:

需求分析:

如上图所示,这是一个展示年级及学期的界面。年级分为三组高中、初中和小学。因学期太多若按一个一个控件的写既繁琐又不够优雅,所以我采用 RecyclerView配合分组来实现效果。注意:我这边是使用一个 RecyclerView和一个 List,然后Adapter使用getItemViewType将填充视图分为标题和内容两个 ItemView,通过Bean中的 type 来决定加载哪个视图。因为是三列的列表,所以在插入 item 时,标题 item 会和内容 item 在同一行,顾在插入标题 item 的时候让它跨三列即可独占一行,具体实现如下:

实现过程:

xml相关文件

<layout    xmlns:android="http://schemas.android.com/apk/res/android">    <data>        <variable            name="gradeBean"            type="cn.toctec.wrongbook.grade.bean.GradeBean" />    data>    <TextView        android:orientation="vertical"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_marginTop="20dp"        android:text="@{gradeBean.gradeName}"        android:textSize="12dp"        android:textColor="@color/color888888">    TextView>layout>

标题 item.xml

<layout    xmlns:android="http://schemas.android.com/apk/res/android">    <data>        <variable            name="gradeBean"            type="cn.toctec.wrongbook.grade.bean.GradeBean" />    data>    <com.nanbox.ripplelayout.RippleLayout        android:layout_width="match_parent"        android:layout_height="35dp"        android:layout_marginTop="10dp"        android:layout_marginLeft="10dp"        android:layout_marginRight="10dp"        android:background="@drawable/bg_grade_gray_fillet">        <RelativeLayout            android:layout_width="match_parent"            android:layout_height="match_parent">            <TextView                android:layout_width="wrap_content"                android:layout_height="wrap_content"                android:layout_centerHorizontal="true"                android:layout_centerVertical="true"                android:text="@{gradeBean.gradeName}"                android:textColor="@color/color333333"                android:textSize="12dp"/>        RelativeLayout>    com.nanbox.ripplelayout.RippleLayout>layout>

内容 item.xml

<layout    xmlns:android="http://schemas.android.com/apk/res/android">    <RelativeLayout        android:orientation="vertical"        android:layout_width="match_parent"        android:layout_height="match_parent"        android:background="@color/white">        <ImageView            android:onClick="onBack"            android:layout_width="18dp"            android:layout_height="18dp"            android:layout_marginTop="45dp"            android:layout_marginLeft="15dp"            android:background="@mipmap/ic_back"/>        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:includeFontPadding="false"            android:layout_centerHorizontal="true"            android:layout_marginTop="43dp"            android:text="@string/grade"            android:textColor="@color/color333333"            android:textSize="18dp"/>        <androidx.recyclerview.widget.RecyclerView            android:id="@+id/gradeRv"            android:layout_width="match_parent"            android:layout_height="match_parent"            android:layout_marginTop="94dp"            android:layout_marginLeft="15dp"            android:layout_marginRight="15dp"/>    RelativeLayout>layout>

activity.xml

bean

public class GradeBean {    private int gradeId;    private String gradeName;    private boolean gradeType;    public GradeBean() {    }    public GradeBean(int gradeId, String gradeName, boolean gradeType) {        this.gradeId = gradeId;        this.gradeName = gradeName;        this.gradeType = gradeType;    }    public int getGradeId() {        return gradeId;    }    public void setGradeId(int gradeId) {        this.gradeId = gradeId;    }    public String getGradeName() {        return gradeName;    }    public void setGradeName(String gradeName) {        this.gradeName = gradeName;    }    public boolean isGradeType() {        return gradeType;    }    public void setGradeType(boolean gradeType) {        this.gradeType = gradeType;    }    @Override    public String toString() {        return "GradeBean{" +                "gradeId=" + gradeId +                ", gradeName='" + gradeName + '\'' +                ", gradeType=" + gradeType +                '}';    }}

adapter

public class GradeAdapter extends RecyclerView.Adapter<BindingViewHolder> {    private LayoutInflater layoutInflater;    private List beanList;    private OnItemClickListener listener;    public GradeAdapter(Context context) {        layoutInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);        beanList = new ArrayList<>();    }    public interface OnItemClickListener {        void onItemClick(GradeBean gradeBean);    }    public void setOnItemClickListener(OnItemClickListener listener) {        this.listener = listener;    }    /**     * item 分类     */    public enum ItemType {        LEVEL,  //年级级别        GRADE   //年级    }    /**     * 设置每个 item 类型     * @param position     * @return     */    @Override    public int getItemViewType(int position) {        final GradeBean bean = beanList.get(position);        if (bean.isGradeType()) {            return ItemType.LEVEL.ordinal();    //级别        }else {            return ItemType.GRADE.ordinal();    //年级        }    }    @NonNull    @Override    public BindingViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {        ViewDataBinding binding;        if (viewType == ItemType.LEVEL.ordinal()) {            binding = DataBindingUtil.inflate(layoutInflater, R.layout.item_level, parent, false);        }else {            binding = DataBindingUtil.inflate(layoutInflater, R.layout.item_grade_number, parent, false);        }        return new BindingViewHolder(binding);    }    @Override    public void onBindViewHolder(@NonNull BindingViewHolder holder, int position) {        final GradeBean bean = beanList.get(position);        holder.getBinding().setVariable(BR.gradeBean, bean);        holder.getBinding().executePendingBindings();        holder.itemView.setOnClickListener(new View.OnClickListener() {            @Override            public void onClick(View v) {                if (listener != null) {                    listener.onItemClick(bean);                }            }        });    }    @Override    public int getItemCount() {        return beanList == null ? 0 : beanList.size();    }    public void addAll(List beans) {        beanList.clear();        beanList.addAll(beans);        notifyDataSetChanged();    }}

activity

public class GradeActivity extends BaseActivity {    ActivityGradeBinding binding;    private List gradeBeanList;    private GradeAdapter adapter;    @Override    protected void onCreate(@Nullable Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        binding = DataBindingUtil.setContentView(this, R.layout.activity_grade);        gradeBeanList = new ArrayList<>();        gradeBeanList.add(new GradeBean(1, "小学", true));        gradeBeanList.add(new GradeBean(2, "一年级 上", false));        gradeBeanList.add(new GradeBean(3, "一年级 下", false));        gradeBeanList.add(new GradeBean(4, "二年级 上", false));        gradeBeanList.add(new GradeBean(5, "二年级 下", false));        gradeBeanList.add(new GradeBean(6, "三年级 上", false));        gradeBeanList.add(new GradeBean(7, "三年级 下", false));        gradeBeanList.add(new GradeBean(8, "四年级 上", false));        gradeBeanList.add(new GradeBean(9, "四年级 下", false));        gradeBeanList.add(new GradeBean(10, "五年级 上", false));        gradeBeanList.add(new GradeBean(11, "五年级 下", false));        gradeBeanList.add(new GradeBean(12, "六年级 上", false));        gradeBeanList.add(new GradeBean(13, "六年级 下", false));        gradeBeanList.add(new GradeBean(14, "初中", true));        gradeBeanList.add(new GradeBean(15, "七年级 上", false));        gradeBeanList.add(new GradeBean(16, "七年级 下", false));        gradeBeanList.add(new GradeBean(17, "八年级 上", false));        gradeBeanList.add(new GradeBean(18, "八年级 下", false));        gradeBeanList.add(new GradeBean(19, "九年级 上", false));        gradeBeanList.add(new GradeBean(20, "九年级 下", false));        gradeBeanList.add(new GradeBean(21, "高中", true));        gradeBeanList.add(new GradeBean(22, "高一 上", false));        gradeBeanList.add(new GradeBean(23, "高一 下", false));        gradeBeanList.add(new GradeBean(24, "高二 上", false));        gradeBeanList.add(new GradeBean(25, "高二 下", false));        gradeBeanList.add(new GradeBean(26, "高三 上", false));        gradeBeanList.add(new GradeBean(27, "高三 下", false));        GridLayoutManager gridLayoutManager = new GridLayoutManager(GradeActivity.this, 3, GridLayoutManager.VERTICAL, false);        gridLayoutManager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {            @Override            public int getSpanSize(int position) {                if (gradeBeanList.get(position).isGradeType()) {                    return 3;   //如果是标题 item 则跨三列                } else {                    return 1;   //如果是内容 item 则不夸咧                }            }        });        gridLayoutManager.setOrientation(LinearLayoutManager.VERTICAL);        binding.gradeRv.setLayoutManager(gridLayoutManager);        adapter = new GradeAdapter(GradeActivity.this);        adapter.addAll(gradeBeanList);        binding.gradeRv.setAdapter(adapter);        adapter.setOnItemClickListener(new GradeAdapter.OnItemClickListener() {            @Override            public void onItemClick(GradeBean gradeBean) {                Log.e("onItemClick", "onItemClick: " + gradeBean.getGradeName());            }        });    }}

到这里就结束啦。往期精彩回顾:

  • Android实现短信验证码自动填充功能

  • Android仿小红书实现长图片自动循环滚动效果

  • Android实现头像重叠排列功能

  • Android仿QQ个性标签功能

  • Android仿QQ侧滑删除的功能

recyclerview 分组_Android使用RecyclerView实现跨列分组相关推荐

  1. python分组函数_Python中如何按列分组和按自己的函数汇总

    让df作为我们来自熊猫的测试数据框:import pandas as pd import numpy as np df = pd.DataFrame({'A' : ['foo', 'bar', 'fo ...

  2. java 下拉列表 可折叠 qq分组_Java 在Excel中创建多级分组、折叠或展开分组

    以下经验内容分享通过Java程序在Excel中创建多级分组.折叠或展开分组. 可对行或列分组进行分组并设置明细数据是否展开或折叠.设置数据分组并展开或折叠时,可通过以下方法: 方法一: 通过方法she ...

  3. recycler 刷新图片闪烁_android 解决RecyclerView notifyDataSetChanged刷新闪屏问题(图片刷新)...

    最近遇到了RecyclerView  在执行notifyDataSetChanged操作时会出现闪屏,图片刷新,然后根据网上资料提示使用 修改动画,设置动画时间 recyclerView.getIte ...

  4. 【RecyclerView】 六、RecyclerView.ItemDecoration 条目装饰 ( 简介 | onDraw | onDrawOver | getItemOffsets )

    文章目录 一.RecyclerView.ItemDecoration 简介 1.onDraw() 方法 2.onDrawOver () 方法 3.getItemOffsets () 方法 二.Recy ...

  5. 【RecyclerView】 五、RecyclerView 布局 ( 瀑布流 | 交错网格局管理器 StaggeredGridLayoutManager )

    文章目录 一.交错网格局管理器 StaggeredGridLayoutManager ( 瀑布流 ) 二.交错网格局管理器默认设置 三.交错网格局管理器水平方向设置 四.完整代码示例 五.Recycl ...

  6. 【RecyclerView】 四、RecyclerView 布局 ( 网格局管理器 GridLayoutManager )

    文章目录 一.网格局管理器 GridLayoutManager 二.网格局管理器默认设置 三.网格局管理器水平方向设置 四.完整代码示例 五.RecyclerView 相关资料 本篇博客主要讨论设置不 ...

  7. csstable跨列居中_CSS进阶11-表格table

    (注1:如果有问题欢迎留言探讨,一起学习!转载请注明出处,喜欢可以点个赞哦!) (注2:更多内容请查看我的目录.) 1. 表格简介 本文定义了CSS中表格的处理模型.这种处理模式的一部分就是布局.对于 ...

  8. a按钮居中显示 bootstrap_Excel合并后居中,跨越合并,及跨列居中的区别你都知道吗...

    一."合并后居中"我们选择指定行区域,它就在哪个区域进行内容居中. 在"开始"选项卡下的"对齐方式"选项组里点击"合并后居中&qu ...

  9. R语言vtreat包自动处理dataframe的缺失值、使用分组的中位数来标准化数据列中每个数据的值(和中位数表连接并基于中位数进行数据标化)、计算数据列的中位数或者均值并进行数据标准化

    R语言vtreat包自动处理dataframe的缺失值.使用分组的中位数来标准化数据列中每个数据的值(和中位数表连接并基于中位数进行数据标化).计算数据列的中位数或者均值并基于中位数或者均值进行数据标 ...

最新文章

  1. [UOJ55]紫荆花之恋
  2. 安卓 存储---SharedPreferences
  3. [转载]动态规划之0-1背包问题
  4. SAE去掉index.php实现自定义固定链接
  5. Spring 5.X系列教程:满足你对Spring5的一切想象-持续更新
  6. JAVA-基础(查找文件夹内文件)
  7. ATL学习笔记〔一〕
  8. Asp.Net Core中利用Seq组件展示结构化日志功能
  9. hibernate的Configuration和配置文件
  10. 用存储过程实现的分页程序
  11. atitit。 hb Hibernate sql 查询使用
  12. 分布式事务解决方案之2PC(两阶段提交)介绍
  13. 缠中说禅形态挖掘之九笔形态
  14. 微型计算机的外存储器 现在普遍采用什么,当前微型计算机上大部分采用的外存储器,不包含什么? 有选择A 硬盘 B 光盘 C 软盘 D 磁带...
  15. Oracle Database 11g SQL开发指南store模式脚本
  16. forms组件与Dango回顾
  17. 【CQF Math Class 数学笔记】
  18. css 图片居中_你需掌握的CSS知识都在这了(长文建议收藏,文末有福利)
  19. echart自定义动画_ECharts使用—折线图动态加载
  20. WriteFile操作时返回87错误

热门文章

  1. python svg转png_Python实现批量把SVG格式转成png、pdf格式的代码分
  2. 卸料装置弹性零件的计算方法_冲裁力、卸料力及推件力的计算-常见问题.doc
  3. Generate a String CodeForces - 710E(dp)
  4. 灯泡四个闪烁c语言程序设计教程课后答案,c语言编程题及答案4.doc
  5. dingo php,详细介绍Laravel+Dingo/Api 自定义响应
  6. mysql安装教程8.0.22_mysql 8.0.22 安装配置方法图文教程
  7. python安装库后无法调用摄像头_银川监控摄像头安装,有人在代码里下毒!慎用 pip install 命令...
  8. 天云大数据_天云大数据三度蝉联毕马威领先金融科技50强
  9. 图神经网络(一)图信号处理与图卷积神经网络(3)图傅里叶变换
  10. 用于安装python第三方库的工具是_Python第三方库安装