不一样的RecyclerView优雅实现复杂列表布局(二)

/**

  • @author :huangxianfeng on 2017/3/14.

  • 为了实现三种不同类型的数据类型

  • 此处虽名称相同,实际中是不同的

*/

public class DataModeOne {

public int avatarColor;

public String name;

}

/**

  • @author :huangxianfeng on 2017/3/14.

  • 为了实现三种不同类型的数据类型

  • 此处虽名称相同,实际中是不同的

*/

public class DataModeTwo {

public int avatarColor;

public String name;

public String content;

}

/**

  • @author :huangxianfeng on 2017/3/14.

  • 为了实现三种不同类型的数据类型

  • 此处虽名称相同,实际中是不同的

*/

public class DataModeThree {

public int avatarColor;

public String name;

public String content;

public int contentColor;

}

2.Holder改动的时候,采用了泛型,在TypeAbstractViewHolder类中加入泛型,然后传入不同的数据实体:

/**

  • @author :huangxianfeng on 2017/3/14.

  • ViewHolder基类

  • 每一种布局都封装成一个ViewHolder,继承此类实现BindHolder方法

*/

public abstract class TypeAbstractViewHolder extends RecyclerView.ViewHolder{

public TypeAbstractViewHolder(View itemView) {

super(itemView);

}

public abstract void bindHolder(T model);

}

此处贴出一例:

/**

  • @author :huangxianfeng on 2017/3/14.

*/

public class TypeOneViewHolder extends TypeAbstractViewHolder {

public ImageView avatar;

public TextView name;

public TypeOneViewHolder(View itemView) {

super(itemView);

avatar = (ImageView)itemView.findViewById(R.id.avatar);

name = (TextView)itemView.findViewById(R.id.name);

itemView.setBackgroundColor(Color.BLACK);

}

@Override

public void bindHolder(DataModeOne model){

avatar.setBackgroundResource(model.avatarColor);

name.setText(model.name);

}

}

3.在Holder改造完成之后,那么我们看看Adapter的改造:

**

  • @author :huangxianfeng on 2017/3/14.

  • RecyclerView的适配器

*/

public class DemoAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder> {

public static final int TYPE_ONE = 1;

public static final int TYPE_TWO = 2;

public static final int TYPE_THREE = 3;

private LayoutInflater mLayoutInflater;

public DemoAdapter(Context context) {

mLayoutInflater = LayoutInflater.from(context);

}

private ArrayList list1;

private ArrayList list2;

private ArrayList list3;

private ArrayList types = new ArrayList<>();

private Map<Integer,Integer> mPosition = new HashMap<>();

/**

  • 创建一个方法供外面操作此数据

*/

public void addList(ArrayList list1,ArrayList list2,ArrayList list3){

addListByType(TYPE_ONE,list1);

addListByType(TYPE_TWO,list2);

addListByType(TYPE_THREE,list3);

this.list1 = list1;

this.list2 = list2;

this.list3 = list3;

}

private void addListByType(int type,ArrayList list){

mPosition.put(type,types.size());

for (int i = 0; i < list.size(); i++) {

types.add(type);

}

}

@Override

public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

switch (viewType){

case DataModel.TYPE_ONE:

return new TypeOneViewHolder(mLayoutInflater.inflate(R.layout.item_type_one,parent,false));

case DataModel.TYPE_TWO:

return new TypeTwoViewHolder(mLayoutInflater.inflate(R.layout.item_type_two,parent,false));

case DataModel.TYPE_THREE:

return new TypeThreeViewHolder(mLayoutInflater.inflate(R.layout.item_type_three,parent,false));

}

return null;

}

@Override

public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {

int viewType = getItemViewType(position);

int realPosition = position -mPosition.get(viewType);

switch (viewType){

case DataModel.TYPE_ONE:

((TypeOneViewHolder)holder).bindHolder(list1.get(realPosition));

break;

case DataModel.TYPE_TWO:

((TypeTwoViewHolder)holder).bindHolder(list2.get(realPosition));

break;

case DataModel.TYPE_THREE:

((TypeThreeViewHolder)holder).bindHolder(list3.get(realPosition));

break;

}

}

/**

  • 多种布局时候至关重要的方法

  • @param position

  • @return

*/

@Override

public int getItemViewType(int position) {

//得到不同的布局类型

return types.get(position);

}

@Override

public int getItemCount() {

return types.size();

}

}

变动不是很大,就是在onBindViewHolder()方法中添加单个Holder的获取。

4.其中MainActivity中,给RecyclerView添加一个方法实现间距重新赋值:

/**

  • 设置RecyclerView的间距

  • 这样可以实现Grid和RecyclerView单条显示时,很好的区分开

*/

mRecyclerView.addItemDecoration(new RecyclerView.ItemDecoration() {

@Override

public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {

GridLayoutManager.LayoutParams layoutParams = (GridLayoutManager.LayoutParams)view.getLayoutParams();

int spanSize = layoutParams.getSpanSize();

int spanIndex = layoutParams.getSpanIndex();

outRect.top = 20;

/**

  • 不相等时说明是Grid形式显示的

  • 然后判断是左边还有右边显示,分别设置间距为10

*/

if (spanSize!=gridLayoutManager.getSpanCount()){

if (spanIndex ==1){

outRect.left = 10;

}else{

outRect.right = 10;

}

}

}

});

MainActivity全部代码:

public class MainActivity extends AppCompatActivity {

private RecyclerView mRecyclerView;

private DemoAdapter mAdapter;

/**

  • 随机一下颜色

*/

int colors[] ={android.R.color.holo_red_dark,

android.R.color.holo_blue_dark,

android.R.color.holo_orange_dark};

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initUI();

}

private void initUI() {

mRecyclerView = (RecyclerView) findViewById(R.id.recyclerview);

final GridLayoutManager gridLayoutManager = new GridLayoutManager(this,2);

gridLayoutManager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {

@Override

public int getSpanSize(int position) {

//得到每个type的值

int type = mRecyclerView.getAdapter().getItemViewType(position);

if (type == DataModel.TYPE_THREE){

return gridLayoutManager.getSpanCount();

}else{

return 1;

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

最后

其实Android开发的知识点就那么多,面试问来问去还是那么点东西。所以面试没有其他的诀窍,只看你对这些知识点准备的充分程度。so,出去面试时先看看自己复习到了哪个阶段就好。

虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司21年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

试时先看看自己复习到了哪个阶段就好。

虽然 Android 没有前几年火热了,已经过去了会四大组件就能找到高薪职位的时代了。这只能说明 Android 中级以下的岗位饱和了,现在高级工程师还是比较缺少的,很多高级职位给的薪资真的特别高(钱多也不一定能找到合适的),所以努力让自己成为高级工程师才是最重要的。

这里附上上述的面试题相关的几十套字节跳动,京东,小米,腾讯、头条、阿里、美团等公司21年的面试题。把技术点整理成了视频和PDF(实际上比预期多花了不少精力),包含知识脉络 + 诸多细节。

由于篇幅有限,这里以图片的形式给大家展示一小部分。

[外链图片转存中…(img-Xq6iEUoz-1712863978905)]

网上学习 Android的资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。希望这份系统化的技术体系对大家有一个方向参考。

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 27
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值