Android RecyclerView使用详解(二)

在上一篇RecyclerView使用详解(一)文章中简单的介绍了RecyclerView的基本用法,接下来要来说讲RecyclerView的更多用法,要实现不一样的功能效果,大部分都仍是在于RecyclerView的Adapter写法,因此咱们着重来看看几种不一样功能的Adapter写法。html

##1、多Item布局实现(MultipleItem)java

若是以前你用过ListView实现过此功能,那么你必定对下面这两个方法并不陌生git

[代码]java代码:

?
1
2
3
4
5
6
7
8
9
@Override
public int getItemViewType( int position) {
     return super .getItemViewType(position);
}
 
@Override
public int getViewTypeCount() {
     return super .getViewTypeCount();
}

 

其中getItemViewType方法是用来获取当前项Item(position参数)是哪一种类型的布局,getViewTypeCount方法是用来获取当前listview总共有多少种类型的布局。github

若是你用RecyclerView,你会发现getViewTypeCount这个方法没有了,只有一个getItemViewType方法,用法和listview没有任何区别,这里要注意的就是这个函数onCreateViewHolder(ViewGroup parent, int viewType)这里的第二个参数就是View的类型,能够根据这个类型判断去建立不一样item的ViewHolder。app

[代码]java代码:

?
01
02
03
04
05
06
07
08
09
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
public class MultipleItemAdapter extends RecyclerView.Adapter<recyclerview.viewholder> {
     public static enum ITEM_TYPE {
         ITEM_TYPE_IMAGE,
         ITEM_TYPE_TEXT
     }
     
     private final LayoutInflater mLayoutInflater;
     private final Context mContext;
     private String[] mTitles;
 
     public MultipleItemAdapter(Context context) {
         mTitles = context.getResources().getStringArray(R.array.titles);
         mContext = context;
         mLayoutInflater = LayoutInflater.from(context);
     }
 
     @Override
     public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
         if (viewType == ITEM_TYPE.ITEM_TYPE_IMAGE.ordinal()) {
             return new ImageViewHolder(mLayoutInflater.inflate(R.layout.item_image, parent, false ));
         } else {
             return new TextViewHolder(mLayoutInflater.inflate(R.layout.item_text, parent, false ));
         }
     }
 
     @Override
     public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
         if (holder instanceof TextViewHolder) {
             ((TextViewHolder) holder).mTextView.setText(mTitles[position]);
         } else if (holder instanceof ImageViewHolder) {
             ((ImageViewHolder) holder).mTextView.setText(mTitles[position]);
         }
     }
 
     @Override
     public int getItemViewType( int position) {
         return position % 2 == 0 ? ITEM_TYPE.ITEM_TYPE_IMAGE.ordinal() : ITEM_TYPE.ITEM_TYPE_TEXT.ordinal();
     }
 
     @Override
     public int getItemCount() {
         return mTitles == null ? 0 : mTitles.length;
     }
 
     public static class TextViewHolder extends RecyclerView.ViewHolder {
         @InjectView (R.id.text_view)
         TextView mTextView;
 
         TextViewHolder(View view) {
             super (view);
             ButterKnife.inject( this , view);
             view.setOnClickListener( new View.OnClickListener() {
                 @Override
                 public void onClick(View v) {
                     Log.d( "TextViewHolder" , "onClick--> position = " + getPosition());
                 }
             });
         }
     }
 
     public static class ImageViewHolder extends RecyclerView.ViewHolder {
         @InjectView (R.id.text_view)
         TextView mTextView;
         @InjectView (R.id.image_view)
         ImageView mImageView;
 
         ImageViewHolder(View view) {
             super (view);
             ButterKnife.inject( this , view);
             view.setOnClickListener( new View.OnClickListener() {
                 @Override
                 public void onClick(View v) {
                     Log.d( "ImageViewHolder" , "onClick--> position = " + getPosition());
                 }
             });
         }
     }
     }</recyclerview.viewholder>

 

怎么样,是否是很简单,没错,就是这么简单,可是只要会了这个多Item,那么你就能够作出不少效果了,好比HeaderView和BottomView也是能够经过这种方式来实现的。(HeaderView Adapter)ide

##2、效果图以下:函数

最后给出代码下载地址–>Demo Code布局

相关文章
相关标签/搜索