RecyclerView的多条目展示

2024-03-03 22:18
文章标签 展示 recyclerview 条目

本文主要是介绍RecyclerView的多条目展示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本技术博客来自 http://blog.csdn.net/qq_35353487
在项目中基本上都会用到的 多种item(条目)的加载 比如大家常见的app( <网易新闻>app的新闻的列表,<新闻头条>app的新闻列表) 都是采用了加载多种item的布局 我们先来看一下效果.

这是一张来自 今日头条的新闻界面 我们今天就按着这个界面的布局来写 . 首先看这个界面 分为三部分 第一条item 是加载的大图片,第二个item 左边是文字 右边是一个小图片,第三个item上面是文字,底部分为三个相同的小图片


这里写图片描述

**

下面这张图是咱们今天所实现的图

:**
(有点丑 但是 和<今日头条>实现的逻辑,所编写的代码 还是一样的..不要在意细节 不要在意细节…)


这里写图片描述


今天咱们是用RecyclerView来实现这个多种Item的加载.
其实最关键的是要复写RecyclerView的Adapter中的getItemViewType()方法 这个方法就根据条件返回条目的类型 这个MoreTypeBean 是用来传数据的 没必要跟我写的一样,
其实就是从activity中传到adapter中的数据中必须要有一个type字段来判断这个item对象需要那种视图,然后return出一个标记,在onCreateViewHolder中在引用所对应的item布局.

//重写getItemViewType方法 根据条件返回条目的类型@Overridepublic int getItemViewType(int position) {MoreTypeBean moreTypeBean = mData.get(position);if (moreTypeBean.type == 0) {return TYPE_PULL_IMAGE;} else if (moreTypeBean.type == 1) {return TYPE_RIGHT_IMAGE;} else {return TYPE_THREE_IMAGE;}}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

一般有多少种类型我们定义多少种常量.(我今天写了三种布局 所以我定义了三个)

  //定义三种常量  表示三种条目类型public static final int TYPE_PULL_IMAGE = 0;public static final int TYPE_RIGHT_IMAGE = 1;public static final int TYPE_THREE_IMAGE = 2;
  • 1
  • 2
  • 3
  • 4

有了上面定义的常量之后 在onCreateViewHolder里根据viewtype来判断 所引用的item布局类型 这样每一条item就会不一样了

    @Overridepublic RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {//创建不同的 ViewHolderView view;//根据viewtype来判断if (viewType == TYPE_PULL_IMAGE) {view =View.inflate(parent.getContext(),R.layout.item_pull_img,null);return new PullImageHolder(view);} else if (viewType == TYPE_RIGHT_IMAGE) {view =View.inflate(parent.getContext(),R.layout.item_right_img,null);return new RightImageHolder(view);} else {view =View.inflate(parent.getContext(),R.layout.item_three_img,null);return new ThreeImageHolder(view);}}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

创建三种不同的ViewHolder

private class PullImageHolder extends RecyclerView.ViewHolder {public PullImageHolder(View itemView) {super(itemView);}}private class RightImageHolder extends RecyclerView.ViewHolder {public RightImageHolder(View itemView) {super(itemView);}}private class ThreeImageHolder extends RecyclerView.ViewHolder {public ThreeImageHolder(View itemView) {super(itemView);}}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

下面把所有的代码都给大家:
Activity中的代码

public class Recycler_variety_Activity extends Activity {private int[] icons = {R.drawable.test, R.drawable.test1, R.drawable.test2, R.drawable.test3, R.drawable.test4, R.drawable.test5, R.drawable.test6};private RecyclerView mRecy;private List<MoreTypeBean> mData;@Overrideprotected void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.recycler_variety_activity);initView();initData();initViewOper();}private void initView() {mRecy = (RecyclerView) findViewById(R.id.act_recycler_variety_recycler);}private void initData() {mData = new ArrayList<>();
//        随机数 用来标记item界面的类型Random random = new Random();for (int i = 0; i < icons.length; i++) {MoreTypeBean more = new MoreTypeBean();more.pic = icons[i];more.type = random.nextInt(3);mData.add(more);}}private void initViewOper() {LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);mRecy.setLayoutManager(linearLayoutManager);Recycler_variety_Adapter adapter = new Recycler_variety_Adapter(mData);mRecy.setAdapter(adapter);}}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42

recyclerview_test_layout的布局就是只有一个RecyclerView

   <android.support.v7.widget.RecyclerViewandroid:id="@+id/act_recycler_variety_recycler"android:layout_width="match_parent"android:background="#d3d3d3"android:layout_height="match_parent"/>
  • 1
  • 2
  • 3
  • 4
  • 5

RecyclerView的Adapter

public class Recycler_variety_Adapter extends RecyclerView.Adapter {//定义三种常量  表示三种条目类型public static final int TYPE_PULL_IMAGE = 0;public static final int TYPE_RIGHT_IMAGE = 1;public static final int TYPE_THREE_IMAGE = 2;private List<MoreTypeBean> mData;public Recycler_variety_Adapter(List<MoreTypeBean> data) {this.mData = data;}@Overridepublic RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {//创建不同的 ViewHolderView view;//根据viewtype来创建条目if (viewType == TYPE_PULL_IMAGE) {view =View.inflate(parent.getContext(),R.layout.item_pull_img,null);return new PullImageHolder(view);} else if (viewType == TYPE_RIGHT_IMAGE) {view =View.inflate(parent.getContext(),R.layout.item_right_img,null);return new RightImageHolder(view);} else {view =View.inflate(parent.getContext(),R.layout.item_three_img,null);return new ThreeImageHolder(view);}}@Overridepublic void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {}@Overridepublic int getItemCount() {if (mData != null) {return mData.size();}return 0;}//根据条件返回条目的类型@Overridepublic int getItemViewType(int position) {MoreTypeBean moreTypeBean = mData.get(position);if (moreTypeBean.type == 0) {return TYPE_PULL_IMAGE;} else if (moreTypeBean.type == 1) {return TYPE_RIGHT_IMAGE;} else {return TYPE_THREE_IMAGE;}}/*** 创建三种ViewHolder*/private class PullImageHolder extends RecyclerView.ViewHolder {public PullImageHolder(View itemView) {super(itemView);}}private class RightImageHolder extends RecyclerView.ViewHolder {public RightImageHolder(View itemView) {super(itemView);}}private class ThreeImageHolder extends RecyclerView.ViewHolder {public ThreeImageHolder(View itemView) {super(itemView);}}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84

item_pull_img布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical"><LinearLayout
        android:layout_width="match_parent"android:padding="7dp"android:background="#fff"android:orientation="vertical"android:layout_height="wrap_content"><TextView
        android:layout_width="wrap_content"android:layout_height="wrap_content"android:textColor="#000"android:text="多种条目类型,多种条目类型,多种条目类型,多种条目类型,多种条目类型"android:textSize="16sp"/><ImageView
        android:layout_width="match_parent"android:layout_height="150dp"android:background="@drawable/sucai6"android:scaleType="fitXY"/></LinearLayout><View
        android:layout_marginTop="3dp"android:layout_width="match_parent"android:layout_height="1dp"android:background="#d3d3d3"/>
</LinearLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33

item_right_img布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="100dp"android:orientation="vertical"><LinearLayout
        android:layout_width="match_parent"android:layout_height="wrap_content"android:background="#fff"android:orientation="horizontal"android:padding="7dp"><TextView
            android:layout_width="0dp"android:layout_height="wrap_content"android:layout_weight="1"android:text="多种条目类型,多种条目类型,多种条目类型,多种条目类型,多种条目类型,多种条目类型,多种条目类型,多种条目类型"android:textColor="#000"android:textSize="16sp" /><ImageView
            android:layout_width="120dp"android:layout_height="90dp"android:background="@drawable/sucai" /></LinearLayout><View
        android:layout_marginTop="3dp"android:layout_width="match_parent"android:layout_height="1dp"android:background="#d3d3d3"/>
</LinearLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34

item_three_img布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="vertical"><LinearLayout
        android:orientation="vertical"android:layout_width="match_parent"android:background="#fff"android:padding="7sp"android:layout_height="wrap_content"><TextView
        android:layout_width="match_parent"android:layout_height="wrap_content"android:text="多种条目类型,多种条目类型,多种条目类型,多种条目类型,多种条目类型,多种条目类型多种条目类型"android:textColor="#000"android:textSize="16sp" /><LinearLayout
        android:layout_width="match_parent"android:layout_height="wrap_content"android:orientation="horizontal"><ImageView
            android:layout_width="0dp"android:layout_height="80dp"android:layout_weight="1"android:scaleType="fitXY"android:src="@drawable/sucai3" /><View
            android:layout_width="6dp"android:layout_height="0dp"/><ImageView
            android:layout_width="0dp"android:layout_height="80dp"android:layout_weight="1"android:scaleType="fitXY"android:src="@drawable/sucai4" /><View
            android:layout_width="6dp"android:layout_height="0dp"/><ImageView
            android:layout_width="0dp"android:layout_height="80dp"android:layout_weight="1"android:scaleType="fitXY"android:src="@drawable/sucai5" /></LinearLayout></LinearLayout><View
        android:layout_marginTop="3dp"android:background="#d3d3d3"android:layout_width="match_parent"android:layout_height="1dp"/>
</LinearLayout>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62

MoreTypeBean

public class MoreTypeBean {public int type;public int pic;
}

这篇关于RecyclerView的多条目展示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/771085

相关文章

起点中文网防止网页调试的代码展示

起点中文网对爬虫非常敏感。如图,想在页面启用调试后会显示“已在调试程序中暂停”。 选择停用断点并继续运行后会造成cpu占用率升高电脑卡顿。 经简单分析网站使用了js代码用于防止调试并在强制继续运行后造成电脑卡顿,代码如下: function A(A, B) {if (null != B && "undefined" != typeof Symbol && B[Symbol.hasInstan

通过Ajax请求后台数据,返回JSONArray(JsonObject),页面(Jquery)以table的形式展示

点击“会商人员情况表”,弹出层,显示一个表格,如下图: 利用Ajax和Jquery和JSONArray和JsonObject来实现: 代码如下: 在hspersons.html中: <!DOCTYPE html><html><head><meta charset="UTF-8"><title>会商人员情况表</title><script type="text/javasc

Jasperreports+jaspersoft studio 实现单个或多个jrxml(jasper)文件生成一个pdf文件,并利用Servlet发送该pdf文件到浏览器中展示

Jasperreports+jaspersoft studio 实现单个或多个jrxml(jasper)文件生成一个pdf文件,并利用Servlet发送该pdf文件到浏览器中展示; 代码如下: Demo07.jrxml <?xml version="1.0" encoding="UTF-8"?><!-- Created with Jaspersoft Studio version 6.6.

【CSS】flex布局 - 左边超过打点, 右边完整展示

场景:宽度一定的情况下右边自适应,左边被挤压。 需要的效果如下: flex 的三个参数分别对应:flex-grow、flex-shrink、flex-basis。 flex-grow:定义项目的放大比例,默认为0。即如果存在剩余空间,也不放大。flex-shrink:定义项目的缩小比例,默认为1。即如果空间不足,该项目将缩小。flex-basis:定义在分配多余空间之前,项目占据的主轴空间。

C# 无法删除 Winform的PictureBox正在展示的图片

最近用C#的前端项目,写了PictureBox展示并上传图片。想删除掉已经展示和上传的图片,提示资源正在使用中不能删除。 查了一些原因,总结原因是PictureBox控件占用着图片资源,不允许删除。 从PictureBox展示图片入手,可以采用以下两个解决办法: 1:使用Bitmap类转接图片资源 Image bmp = new Bitmap(img); this.twoPictureBo

各种算法动画展示,效果不错。

各种算法动画展示: http://www.yxqzzx.cn/teacher/ShowArticle.asp?ArticleID=417

QT4.8 不展示JPG图片问题解决办法

最近遇到一个很奇怪的问题,项目在自己机上展示JPG图片都是正常的,打包给客户机上始终不展示,试过很多方法,比如本机Debug下不管是运行工程文件还是直接运行 .exe文件 都是可以展示JPG图片的 ,而Release下 发现运行工程文件时 JPG文件也是可以展示的 但是直接运行 Release下exe文件 是不展示JPG文件的。最终经过大神的提示和网上的搜索 知道是由于缺少jpg插件 , 也就是

ELK系列之四---如何通过Filebeat和Logstash优化K8S集群的日志收集和展示

前 言 上一篇文章《日志不再乱: 如何使用Logstash进行高效日志收集与存储》介绍了使用ELK收集通用应用的日志,在目前大多应用都已运行在K8S集群上的环境,需要考虑怎么收集K8S上的日志,本篇就介绍一下如何使用现有的ELK平台收集K8S集群上POD的日志。 K8S日志文件说明 一般情况下,容器中的日志在输出到标准输出(stdout)时,会以.log的命名方式保存在/var/log/po

Cesium 展示——实现昼夜交替

文章目录 需求分析1. 添加2. 移除 需求 Cesium 展示——实现昼夜交替 分析 1. 添加 <

RecyclerView的itemView的点击效果

1,需要在 itemView 的布局 根节点上添加  android:clickable="true" 2、或者通过代码实现 @Override public void onBindViewHolder(RecyclerView.ViewHolder viewHolder, int i) {  ((ViewHolder)viewHolder).textView