欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android RecycleView添加head配置封裝的實(shí)例

 更新時(shí)間:2017年08月30日 16:32:42   作者:龍哥IT  
這篇文章主要介紹了Android RecycleView添加head配置封裝的實(shí)例的相關(guān)資料,這里提供實(shí)例幫助大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下

Android RecycleView添加head配置封裝的實(shí)例

這個(gè)是把RecycleView的適配器給封裝了,直接調(diào)用就可以了,還添加了可以添加head頭部功能,很贊的,今天記下來,下次直接用 

實(shí)例代碼:

package com.wwl.android; 
 
import android.support.v7.widget.GridLayoutManager; 
import android.support.v7.widget.RecyclerView; 
import android.support.v7.widget.StaggeredGridLayoutManager; 
import android.view.View; 
import android.view.ViewGroup; 
 
import java.util.ArrayList; 
 
 
public abstract class BaseRecyclerAdapter<T> extends RecyclerView.Adapter<RecyclerView.ViewHolder> { 
 
  public static final int TYPE_HEADER = 0; 
  public static final int TYPE_NORMAL = 1; 
 
  private ArrayList<T> mDatas = new ArrayList<>(); 
 
  private View mHeaderView; 
 
  private OnItemClickListener mListener; 
 
  public void setOnItemClickListener(OnItemClickListener li) { 
    mListener = li; 
  } 
 
  public void setHeaderView(View headerView) { 
    mHeaderView = headerView; 
    notifyItemInserted(0); 
  } 
 
  public View getHeaderView() { 
    return mHeaderView; 
  } 
 
  public void addDatas(ArrayList<T> datas) { 
    mDatas.addAll(datas); 
    notifyDataSetChanged(); 
  } 
 
  @Override 
  public int getItemViewType(int position) { 
    if(mHeaderView == null) return TYPE_NORMAL; 
    if(position == 0) return TYPE_HEADER; 
    return TYPE_NORMAL; 
  } 
 
  @Override 
  public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, final int viewType) { 
    if(mHeaderView != null && viewType == TYPE_HEADER) return new Holder(mHeaderView); 
    return onCreate(parent, viewType); 
  } 
 
 
  @Override 
  public void onBindViewHolder(RecyclerView.ViewHolder viewHolder, int position) { 
    if(getItemViewType(position) == TYPE_HEADER) return; 
 
    final int pos = getRealPosition(viewHolder); 
    final T data = mDatas.get(pos); 
    onBind(viewHolder, pos, data); 
 
    if(mListener != null) { 
      viewHolder.itemView.setOnClickListener(new View.OnClickListener() { 
        @Override 
        public void onClick(View v) { 
          mListener.onItemClick(pos, data); 
        } 
      }); 
    } 
  } 
 
  @Override 
  public void onAttachedToRecyclerView(RecyclerView recyclerView) { 
    super.onAttachedToRecyclerView(recyclerView); 
 
    RecyclerView.LayoutManager manager = recyclerView.getLayoutManager(); 
    if(manager instanceof GridLayoutManager) { 
      final GridLayoutManager gridManager = ((GridLayoutManager) manager); 
      gridManager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() { 
        @Override 
        public int getSpanSize(int position) { 
          return getItemViewType(position) == TYPE_HEADER 
              ? gridManager.getSpanCount() : 1; 
        } 
      }); 
    } 
  } 
 
  @Override 
  public void onViewAttachedToWindow(RecyclerView.ViewHolder holder) { 
    super.onViewAttachedToWindow(holder); 
    ViewGroup.LayoutParams lp = holder.itemView.getLayoutParams(); 
    if(lp != null 
        && lp instanceof StaggeredGridLayoutManager.LayoutParams 
        && holder.getLayoutPosition() == 0) { 
      StaggeredGridLayoutManager.LayoutParams p = (StaggeredGridLayoutManager.LayoutParams) lp; 
      p.setFullSpan(true); 
    } 
  } 
 
  public int getRealPosition(RecyclerView.ViewHolder holder) { 
    int position = holder.getLayoutPosition(); 
    return mHeaderView == null ? position : position - 1; 
  } 
 
  @Override 
  public int getItemCount() { 
    return mHeaderView == null ? mDatas.size() : mDatas.size() + 1; 
  } 
 
  public abstract RecyclerView.ViewHolder onCreate(ViewGroup parent, final int viewType); 
  public abstract void onBind(RecyclerView.ViewHolder viewHolder, int RealPosition, T data); 
 
  public class Holder extends RecyclerView.ViewHolder { 
    public Holder(View itemView) { 
      super(itemView); 
    } 
  } 
 
  public interface OnItemClickListener<T> { 
    void onItemClick(int position, T data); 
  } 
} 

  然后在外面自己的適配器中直接繼承就可以了

package com.wwl.android; 
 
import android.support.v7.widget.RecyclerView; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.TextView; 
 
/** 
 * wwl 
 */ 
public class MyAdapter extends BaseRecyclerAdapter<String> { 
 
  @Override 
  public RecyclerView.ViewHolder onCreate(ViewGroup parent, int viewType) { 
    View layout = LayoutInflater.from(parent.getContext()).inflate(R.layout.item, parent, false); 
    return new MyHolder(layout); 
  } 
 
  @Override 
  public void onBind(RecyclerView.ViewHolder viewHolder, int RealPosition, String data) { 
    if(viewHolder instanceof MyHolder) { 
      ((MyHolder) viewHolder).text.setText(data); 
    } 
  } 
 
  class MyHolder extends BaseRecyclerAdapter.Holder { 
    TextView text; 
    public MyHolder(View itemView) { 
      super(itemView); 
      text = (TextView) itemView.findViewById(R.id.text); 
    } 
  } 
} 
 

 然后在類中調(diào)用,

public class MainActivity extends AppCompatActivity { 
 
  private RecyclerView mRecyclerView; 
  private RecyclerView.LayoutManager mLayoutManager; 
  private MyAdapter mAdapter; 
 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
 
    mRecyclerView = (RecyclerView) findViewById(R.id.list); 
//    mLayoutManager = new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false); 
    mLayoutManager = new GridLayoutManager(this, 2); 
//    mLayoutManager = new StaggeredGridLayoutManager(2, StaggeredGridLayoutManager.VERTICAL); 
    mRecyclerView.setLayoutManager(mLayoutManager); 
    mRecyclerView.setItemAnimator(new DefaultItemAnimator()); 
    mRecyclerView.addItemDecoration(new GridItemDecoration(this, true)); 
 
    mAdapter = new MyAdapter(); 
    mRecyclerView.setAdapter(mAdapter); 
    mAdapter.addDatas(generateData()); 
    setHeader(mRecyclerView); 
    mAdapter.setOnItemClickListener(new BaseRecyclerAdapter.OnItemClickListener<String>() { 
      @Override 
      public void onItemClick(int position, String data) { 
        Toast.makeText(MainActivity.this, position + "," + data, Toast.LENGTH_SHORT).show(); 
      } 
    }); 
  } 
 
  private void setHeader(RecyclerView view) { 
    View header = LayoutInflater.from(this).inflate(R.layout.header, view, false); 
     
    mAdapter.setHeaderView(header); 
  } 
 
  private ArrayList<String> generateData() { 
    ArrayList<String> data = new ArrayList<String>() { 
      { 
        for(int i=0;i<21;i++) add("數(shù)據(jù)" + i); 
      } 
    }; 
    return data; 
  } 
   
} 

 這樣就OK啦。 

布局文件:

R.layout.activity_main 

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  xmlns:tools="http://schemas.android.com/tools" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent"> 
 
  <android.support.v7.widget.RecyclerView 
    android:id="@+id/list" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" /> 
 
</LinearLayout> 

header.xml 

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:orientation="vertical"> 
 
  <ImageView 
    android:layout_gravity="center_horizontal" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:src="@mipmap/ic_launcher"/> 
 
</LinearLayout> 

   item.xml 

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="match_parent" 
  android:layout_height="wrap_content" 
  android:padding="20dp" 
  android:orientation="vertical"> 
 
  <TextView 
    android:id="@+id/text" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_centerInParent="true" 
    android:text="數(shù)據(jù)"/> 
 
</RelativeLayout> 

以上就是Android RecycleView添加head配置封裝的實(shí)例,如有疑問請(qǐng)留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!

相關(guān)文章

  • Android實(shí)現(xiàn)Path平滑的涂鴉效果實(shí)例

    Android實(shí)現(xiàn)Path平滑的涂鴉效果實(shí)例

    這篇文章主要給大家介紹了關(guān)于Android實(shí)現(xiàn)Path平滑涂鴉效果的相關(guān)資料,通過本文介紹的方法修改后會(huì)讓線條平滑很多,文中給出了詳細(xì)的示例代碼供大家參考學(xué)習(xí),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-10-10
  • Android仿京東首頁畫軸效果

    Android仿京東首頁畫軸效果

    這篇文章主要為大家詳細(xì)介紹了Android仿京東首頁畫軸效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • android 調(diào)用JNI SO動(dòng)態(tài)庫的方法

    android 調(diào)用JNI SO動(dòng)態(tài)庫的方法

    android 調(diào)用JNI 分為靜態(tài)調(diào)用與動(dòng)態(tài)調(diào)用,接下來通過本文給大家介紹android 調(diào)用JNI SO動(dòng)態(tài)庫的方法,感興趣的朋友一起看看吧
    2021-11-11
  • Android自定義 WebView瀏覽器

    Android自定義 WebView瀏覽器

    WebView是Android中一個(gè)非常實(shí)用的組件,它和Safai、Chrome一樣都是基于Webkit網(wǎng)頁渲染引擎。接下來通過本文給大家介紹android自定義webview瀏覽器,感興趣的朋友一起學(xué)習(xí)吧
    2016-05-05
  • Android?Gson基本用法學(xué)習(xí)

    Android?Gson基本用法學(xué)習(xí)

    這篇文章介紹了Android?Gson的基本用法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-12-12
  • Android 模擬信號(hào)示波器示例代碼

    Android 模擬信號(hào)示波器示例代碼

    本文主要介紹Android 模擬信號(hào)示波器的開發(fā)示例,這里提供了示例代碼和實(shí)現(xiàn)效果圖,有興趣的小伙伴可以參考下
    2016-08-08
  • Android通過AIDL在兩個(gè)APP之間Service通信

    Android通過AIDL在兩個(gè)APP之間Service通信

    這篇文章主要為大家詳細(xì)介紹了Android通過AIDL在兩個(gè)APP之間Service通信,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • android實(shí)現(xiàn)背景音樂播放功能

    android實(shí)現(xiàn)背景音樂播放功能

    這篇文章主要為大家詳細(xì)介紹了android實(shí)現(xiàn)背景音樂播放功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Android自定義控件案例匯總2(自定義開關(guān)、下拉刷新、側(cè)滑菜單)

    Android自定義控件案例匯總2(自定義開關(guān)、下拉刷新、側(cè)滑菜單)

    這篇文章主要介紹了Android自定義控件案例匯總,自定義開關(guān)、Listview實(shí)現(xiàn)下拉刷新、側(cè)滑菜單,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • TextInputLayout輸入框控件的懸浮標(biāo)簽

    TextInputLayout輸入框控件的懸浮標(biāo)簽

    這篇文章主要為大家詳細(xì)介紹了TextInputLayout輸入框控件的懸浮標(biāo)簽,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-12-12

最新評(píng)論