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;
}
}
});
mRecyclerView.setLayoutManager(gridLayoutManager);
mAdapter = new DemoAdapter(this);
mRecyclerView.setAdapter(mAdapter);
/**
-
设置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;
}
}
}
});
initData();
}
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
**。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-4kUaFr8X-1715812132051)]
[外链图片转存中…(img-gKGVfQ1D-1715812132053)]
[外链图片转存中…(img-OgPT2MIg-1715812132054)]
[外链图片转存中…(img-ol7m0u7j-1715812132055)]
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!