編輯:關於Android編程
前提概要:
上一篇文章已經介紹過了RecyclerView的基本使用方法,原文如下:android RecyclerView布局真的只是那麼簡單!此篇文章算是對RecyclerView更深使用的介紹。
FootView和HeadView在ListView中的本身就有相對應的函數,但是在新潮的RecyclerView中卻沒有了,FootView在分頁加載(上拉加載更多)中起著很重要的作用,因此也必須要學習一下了。(HeadView的添加與FootView的添加相比大致一樣,在此就只講FootView的添加了)
效果: (源碼在文章結尾)

實現關鍵
int getItemViewType(int position):此函數是RecyclerView中自帶的函數,參數為每個item的position,返回一個int類型表示類型。
此函數的作用是區分普通的item與FootView的Item,讓FootView這個Item能一直處在adapter中的最下端。
在例子中定義了兩種類型如下:
//兩個final int類型表示ViewType的兩種類型 private final int NORMAL_TYPE = 0; private final int FOOT_TYPE = 1111;
該函數如下:
@Override
public int getItemViewType(int position) {
if (position == max_count - 1) {
return FOOT_TYPE;
}
return NORMAL_TYPE;
}
實現步驟
1、定義getItemViewType(int position)並且定義自己所需要的ViewType的類型。
2、在定義ViewHolder(),onCreateViewHolder()和onBindViewHolder()中都考慮兩種情況,一種是普通的item,另一種是FootView。
另外默認的ViewHolder()函數中只會有View itemView一個參數,此處因為需要,所以要添加int viewType的參數,代碼中如下:
//初始化viewHolder,此處綁定後在onBindViewHolder中可以直接使用
public ViewHolder(View itemView, int viewType) {
super(itemView);
if (viewType == NORMAL_TYPE) {
tvViewHolder = (TextView) itemView.findViewById(R.id.tv_view_holder);
llViewHolder = (LinearLayout) itemView;
} else if (viewType == FOOT_TYPE) {
tvFootView = (TextView) itemView;
}
}
此處再說一下三個函數的大致作用:
ViewHolder(View itemView, int viewType):
將item布局中的控件與ViewHolder中所定義的屬性綁定,更便於在onBindViewHolder()中使用。
onCreateViewHolder(ViewGroup parent, int viewType):
此函數用來創建每一個item,最後返回的不是view,而是返回的一個ViewHolder。
onBindViewHolder(ViewHolder holder, int position):
此函數中一般用來將數據綁定到item中的控件中。
代碼:
結合以上分析看代碼,讀者應該比較容易理解了,下面附上關鍵adapter代碼和源碼地址:
public class RecyclerAdapter extends RecyclerView.Adapter<RecyclerAdapter.ViewHolder> {
private List<String> mData;//數據
private int max_count = 10;//最大顯示數
private Boolean isFootView = false;//是否添加了FootView
private String footViewText = "";//FootView的內容
//兩個final int類型表示ViewType的兩種類型
private final int NORMAL_TYPE = 0;
private final int FOOT_TYPE = 1111;
public RecyclerAdapter(List<String> data) {
mData = data;
}
public class ViewHolder extends RecyclerView.ViewHolder {
public TextView tvViewHolder;
public LinearLayout llViewHolder;
public TextView tvFootView;//footView的TextView屬於獨自的一個layout
//初始化viewHolder,此處綁定後在onBindViewHolder中可以直接使用
public ViewHolder(View itemView, int viewType) {
super(itemView);
if (viewType == NORMAL_TYPE) {
tvViewHolder = (TextView) itemView.findViewById(R.id.tv_view_holder);
llViewHolder = (LinearLayout) itemView;
} else if (viewType == FOOT_TYPE) {
tvFootView = (TextView) itemView;
}
}
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View normal_views = LayoutInflater.from(parent.getContext()).inflate(
R.layout.rc_item, parent, false);
View foot_view = LayoutInflater.from(parent.getContext()).inflate(
R.layout.foot_view, parent, false);
if (viewType == FOOT_TYPE)
return new ViewHolder(foot_view, FOOT_TYPE);
return new ViewHolder(normal_views, NORMAL_TYPE);
}
@Override
public int getItemViewType(int position) {
if (position == max_count - 1) {
return FOOT_TYPE;
}
return NORMAL_TYPE;
}
@Override
public void onBindViewHolder(ViewHolder holder, int position) {
//建立起ViewHolder中試圖與數據的關聯
Log.d("xjj", getItemViewType(position) + "");
//如果footview存在,並且當前位置ViewType是FOOT_TYPE
if (isFootView && (getItemViewType(position) == FOOT_TYPE)) {
holder.tvFootView.setText(footViewText);
} else {
holder.tvViewHolder.setText(mData.get(position) + position);
}
}
@Override
public int getItemCount() {
if (mData.size() < max_count) {
return mData.size();
}
return max_count;
}
//創建一個方法來設置footView中的文字
public void setFootViewText(String footViewText) {
isFootView = true;
this.footViewText = footViewText;
}
}
拓展延伸
下一篇文章中,筆者在此基礎上做了一下一點改動,很容易就實現了分頁加載的功能,文章地址如下:
http://blog.csdn.net/double2hao/article/details/52788708
源碼地址:http://xiazai.jb51.net/201610/yuanma/AndroidPullRecyclerView(jb51.net).rar
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
Android安卓---Hellword 簡單提示框
添加公用單元文件com..java package com.example.myapplication;import android.a
從零開始學android小示例程序
布局文件復制代碼 代碼如下:<RelativeLayout xmlns:android=http://schemas.android.com/apk/res/and
Android事件傳遞(二)ViewGroup事件的傳遞
經過上一篇的實驗,我門只是僅僅對View的事件的傳遞進行了分析,但是還有一個比較厲害的ViewGroup我們肯定是要說一下的,ViewGroup的二叉視圖分析 我們能看到
Android 項目的代碼混淆,Android proguard 使用說明
簡介 Java代碼是非常容易反編譯的。為了很好的保護Java源代碼,我們往往會對編譯好的class文件進行混淆處理。 ProGuard是一個混淆代