recyclerview 分组_Android使用RecyclerView实现跨列分组

效果图:

942a2237b912c991cccf493ee17f374a.png

需求分析:

如上图所示,这是一个展示年级及学期的界面。年级分为三组高中、初中和小学。因学期太多若按一个一个控件的写既繁琐又不够优雅,所以我采用 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侧滑删除的功能

fa63e81db1412e625f266a12dbd9595f.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/245924.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

rtmp服务器_nginx+windwos 搭建 rtmp 流媒体服务器

喜欢就关注我们吧&#xff01;“ 写此篇文章属于笔者在开发项目中&#xff0c;对项目开发架构的一种选型&#xff0c;目前正在探索阿里云的视频直播服务和nginx自行搭建流媒体服务器&#xff0c;希望能选择最优的一种方案&#xff0c;进行开发。”以下是使用nginx自行搭建rtmp流…

r语言聚类分析_图说层次聚类分析原理和R语言实现

1、引言“物以类聚、人以群分”。但我们面对一群人或者一堆物的时候&#xff0c;我们都希望将他们分分类&#xff0c;分类之后&#xff0c;我们才能更加有针对性地采取措施&#xff0c;从而提高工作效率。如&#xff0c;我们将消费者分成若干类&#xff0c;有的是土豪、有的是工…

java web 导出word_JavaWeb Project使用FreeMaker导出Word文件

基本思路1. 导入freemaker2.3.jar2. 需要导出的Word模板3. 在Word内填入值的标签4. Word另存为xml(2003版本)5. Coding6. 导出Word文件具体操作1. Intellij IDEA > FIle > Project Structure > Libraries > ""(左下角) > OK导入Freemaker Jar2. Word模…

sql 除以_使用SQL分析游戏运营情况

数据来源&#xff1a;http://www.dcjingsai.com/common/cmpt/%E6%B8%B8%E6%88%8F%E7%8E%A9%E5%AE%B6%E4%BB%98%E8%B4%B9%E9%87%91%E9%A2%9D%E9%A2%84%E6%B5%8B%E5%A4%A7%E8%B5%9B_%E7%AB%9E%E8%B5%9B%E4%BF%A1%E6%81%AF.html游戏介绍&#xff1a;《野蛮时代》是一款SLG游戏。在…

好看的php验证码,一漂亮的PHP图片验证码实例

一、显示效果二、代码如下代码如下:/** Author fy*/$imgwidth 100; //图片宽度$imgheight 40; //图片高度$codelen 4; //验证码长度$fontsize 20; //字体大小$charset abcdefghkmnprstuvwxyzABCDEFGHKMNPRSTUVWXYZ23456789;$font Fonts/segoesc.ttf;$imimagecreatetruecolor…

检测到目标服务器启用了trace方法_深度学习检测小目标常用方法

引言在深度学习目标检测中&#xff0c;特别是人脸检测中&#xff0c;小目标、小人脸的检测由于分辨率低&#xff0c;图片模糊&#xff0c;信息少&#xff0c;噪音多&#xff0c;所以一直是一个实际且常见的困难问题。不过在这几年的发展中&#xff0c;也涌现了一些提高小目标检…

php自定义能过滤器,过滤器与自定义过滤器的介绍

angularjs中的过滤器为了实现对于表达式结果的筛选、过滤、格式化&#xff0c;达到更好的表现效果。过滤器的语法&#xff1a;支持多重过滤和传参{{expression | 过滤器名称 : ‘参数’ | 过滤器名称2&#xff1a;‘参数’ }}方式&#xff1a;| -》 管道常用的过滤器&#xff1…

大数据项目开发案例_大数据分析技术——项目案例1(猫眼电影数据分析上)...

壹猫眼Top100电影数据分析概述从这一节开始&#xff0c;我们就综合利用已学到的一些分析技术来尝试做一些比较复杂的实际数据分析项目。在这些实际的项目案例中&#xff0c;我们将会看到一个完整的数据分析流程&#xff1a;数据清理——数据分析——数据可视化(即数据解释)。最…

matlab广泛用于什么,目前,Matlab已成为世界上最受欢迎的科学和工程计算软件工具....

目前&#xff0c;Matlab已成为世界上最受欢迎的用于科学和工程计算的软件工具. 它是一种新型的计算机高级编程语言&#xff0c;具有广阔的应用前景. 有人将其称为“第四代”计算机语言. 就影响而言&#xff0c;仍然没有其他计算软件可与Matlab匹敌. Matlab简介Matlab于1984年发…

必须使用列别名命名此表达式_lambda表达式

一般的&#xff0c;如果一个类定义了函数调用运算符&#xff0c;则我们可以像使用函数一样使用这个类&#xff0c;例如&#xff1a;一个类A定义了函数调用运算符&#xff0c;我们就可以使用A()这样的形式调用对象&#xff0c;实际上调用了类的调用运算符函数。如果一个类定义了…

mysql数据库出现幻读,MySQL 幻读怎样处理?_数据库

MySQL 幻读怎样处理&#xff1f;1、MVCC快照&#xff0c;将历史数据存一份快照&#xff0c;在其事件增添与删除数据时&#xff0c;保证当前事件来说是不可见的&#xff1b;多半数据库都完成了多版本并发掌握&#xff0c;而且都是靠保留数据快照来完成的。以 InnoDB 为例&#x…

搜索引擎提交软件_增加SEO超级外链须知的高权重网站目录提交方法

做SEO的朋友对开放式网站目录应该不陌生吧。网站目录就是按一定的分类方法把收录的网站进行分类归档。网站目录本身是不主动抓取网页的&#xff0c;一般只记录网站的名称&#xff0c;网址和有限的说明文字。和网址站、导航站、酷站网址大全等如同一辙。一般高质量的聚合目录网站…

把模糊MATLAB波形的图变清晰,什么修图软件能把模糊图片清晰化?

图片和内容的契合度再高&#xff0c;配色再完美&#xff0c;如果图片不清晰&#xff0c;那才真的是一图毁所有。针对这种情况&#xff0c;我也为大家找来两个非常实用的工具。第一个工具&#xff0c;SmartDeblur。主要针对原图分辨率不高的情况。这个软件目前支持三种模式&…

遗传算法在交通路线matlab,Matlab遗传算法公交车路线优化

Matlab遗传算法公交车路线优化Matlab遗传算法公交车路线优化Matlab遗传算法公交车路线优化1 模型介绍2模型分析2.1整体设计2.2要点分析3结果展示1 模型介绍以乘客出行总时间最小为目标函数&#xff0c;求出其最小值即为最终接驳优化方案。模型约束条件在算法过程中可能会产生不…

mysql 连续签到天数_新版签到活动明天上线,福利活动抢鲜看~

明天游戏中心app旧版福利签到活动马上就要结束啦&#xff0c;虽然很多的魅友反馈说积分签到结束的太早&#xff0c;积分不够换5折券&#xff0c;不过更早的开启新版签到才能更快的享受到更好的福利嘛~今晚0点新版签到活动即将上线&#xff0c;接下来就一起来看看新版的签到活动…

java中nio怎么实现聊天,JAVA-NIO实现聊天室详细代码说明

JAVA-NIO实现聊天室详细代码说明JAVA-NIO实现聊天室详细代码说明github源码&#xff1a;https://github.com/JolyouLu/JAVAIO.gitsrc\main\java\com\JolyouLu\nio\groupchat 文件夹下public class GroupChatServer {//定义属性private Selector selector;private ServerSocketC…

vscode 调试_如何使用VSCode调试JS?

更多精彩&#xff0c;请点击上方蓝字关注我们&#xff01;序言做前端开发的朋友经常需要使用Visual Studio Code编辑代码&#xff0c;很多朋友就想在VSCode调试JS代码&#xff0c;下面我们就介绍下如何配置操作。一、环境准备首先安装好VSCode&#xff0c;准备好一个JS项目&…

基于matlab的信号合成与分解,基于matlab的信号合成与分解

基于matlab的信号合成与分解 - I - 摘 要 为了便于进行周期信号的分析与处理&#xff0c;常要把复杂的周期信号进行分解&#xff0c;即将周期 信号分解为正余弦等此类基本信号的线性组合&#xff0c;通过对这些基本信号单元在时域和频域 特性的分析来达到了解信号特性的目的。本…

基站位置查询系统_木牛导航网络基站服务免费了!——更便捷、更高效、更省心!...

布谷飞飞劝早耕&#xff0c;春锄扑扑趁初晴。千层石树通行路&#xff0c;一带水田放水声。《山行》-- 姚鼐(Photo by Quang Nguyen Vinh)农业生产作为人类最传统的产业自古以来都讲究及时耕种&#xff0c;即抢农时根据气候适宜而进行季节性生产随着科技的发展&#xff0c;农业生…

php cgi进程很多win2008,php cgi.exe 太多 在 windowserver2008 apache 这个怎么样限制下?...

php cgi.exe 太多 在 windowserver2008 apache 这个怎么样限制下&#xff1f;mip版 关注:61 答案:2 悬赏:70解决时间 2021-02-24 01:48已解决2021-02-23 09:13php cgi.exe 太多 在 windowserver2008 apache 这个怎么样限制下&#xff1f;最佳答案2021-02-23 09:57可以设置最…