編輯:關於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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
添加公用單元文件com..java package com.example.myapplication;import android.a
布局文件復制代碼 代碼如下:<RelativeLayout xmlns:android=http://schemas.android.com/apk/res/and
經過上一篇的實驗,我門只是僅僅對View的事件的傳遞進行了分析,但是還有一個比較厲害的ViewGroup我們肯定是要說一下的,ViewGroup的二叉視圖分析 我們能看到
簡介 Java代碼是非常容易反編譯的。為了很好的保護Java源代碼,我們往往會對編譯好的class文件進行混淆處理。 ProGuard是一個混淆代