您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)Android應用中怎么對RecyclerView Adapter進行封裝,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
1、通常我們封裝的時候,可以簡化到這一步:
BaseRecyclerViewAdapter adapter = new BaseRecyclerViewAdapter() { private static final int TYPE_FIR = 1; private static final int TYPE_SEC = 2; private static final int TYPE_THR = 3; @Override public int getLayoutId(int viewType) { if (viewType == TYPE_FIR) { return R.layout.test_activity_recyclerview_item; } else if (viewType == TYPE_SEC){ return R.layout.test_activity_recyclerview_item_two; } else { return R.layout.test_activity_recyclerview_item_three; } } @Override public int getItemViewType(int position) { if (position % 3 == 1) { return TYPE_FIR; } else if (position % 3 == 2) { return TYPE_SEC; } else { return TYPE_THR; } } @Override public void onBindRecyclerViewHolder(BaseViewHolder holder, int position) { if (getItemVIewType(position) == TYPE_FIR) { // TODO 數(shù)據(jù)處理及綁定 } else if (getItemVIewType(position) == TYPE_SEC) { // TODO 數(shù)據(jù)處理及綁定 } else { // TODO 數(shù)據(jù)處理及綁定 } } };
2、從上面代碼我們可以看到,當處理多布局類型的時候,我們需要解決的是:
3、當我們迭代更新的時候,我們只能通過修改adapter,這樣耦合性稍微有點強。
不過呢,簡化到這一步的時候,其實在項目中是可以使用的
解決
1、上面的問題,我們知道,如果需要迭代更新,我們只能通過修改viewType、layout、onBind等具體數(shù)據(jù)來實現(xiàn)。既然這樣,我們可以將這些具體數(shù)據(jù)抽取封裝起來,adapter不直接處理數(shù)據(jù),而是交給這個封裝類,邏輯交給封裝類來處理,這樣adapter只需要負責維護這個封裝類即可。
2、這個封裝類,我們暫且稱作Item
interface Item { @LayoutRes int getLayoutResource(); int getItemViewType(); BaseViewHolder onCreateViewHolder(ViewGroup parent, int viewType); void onBindViewHolder(BaseViewHolder holder, int position); }
adpater中,需要動態(tài)調(diào)整的就是
所以就將這些方法抽取封裝起來,然后adapter維護Item列表即可
3、上面這個接口Item
第一:沒有數(shù)據(jù),我們需要自己在實現(xiàn)類中提供數(shù)據(jù)設(shè)置獲取方法;
第二:我們需要同時實現(xiàn)四個方法
既然這樣,我們可以通過一個基類BaseItem,來簡化操作
4、在Item接口中,只有onCreateViewHolder()方法,是不需要每次都實現(xiàn)的,因為它是固定不變的的,BaseItem就可以這樣寫:
public abstract class BaseItem<T> implements Item { public T mData; public void setData(T t) { this.mData = t; } @Override public BaseViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { int resourceId = getLayoutResource(); View itemView = LayoutInflater.from(parent.getContext()).inflate(resourceId, parent, false); return new BaseViewHolder(itemView); } }
5、現(xiàn)在,我們只需要實現(xiàn)三個方法就可以了。我們再看getItemViewType,這個返回的是當前布局類型,int類型,唯一且不能重復 。Android中的Layout維護著一個int型的唯一標識ID,我們是不是可以拿這個標識ID,作為viewType?這樣就可以進一步簡化實現(xiàn)類,現(xiàn)在我們只需實現(xiàn)兩個方法即可。
public abstract class BaseItem<T> implements Item { public T mData; public void setData(T t) { this.mData = t; } @Override public int getItemViewType() { return getLayoutResource(); } @Override public BaseViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { int resourceId = getLayoutResource(); View itemView = LayoutInflater.from(parent.getContext()).inflate(resourceId, parent, false); return new BaseViewHolder(itemView); } }
6、接下來,我們要構(gòu)造Adapter,使之不再維護具體數(shù)據(jù),而是BaseItem列表
public class BaseAdapter extends RecyclerView.Adapter<BaseViewHolder> { private List<BaseItem> mData; public BaseRecyclerViewAdapter(List<BaseItem> data) { mData = new ArrayList<>(); if (data != null) { mData.addAll(data); } } @Override public BaseViewHolder onCreateViewHolder(ViewGroup parent, final int viewType) { for (BaseItem item : mData) { if (viewType == item.getItemViewType()) { return item.onCreateViewHolder(parent, viewType);; } } } @Override public void onBindViewHolder(BaseViewHolder holder, int position) { mData.get(dataPosition).onBindViewHolder(holder, position); } @Override public int getItemCount() { return mData.size(); } @Override public int getItemViewType(int position) { return mData.get(position).getItemViewType(); } }
結(jié)語
以上簡單介紹了一下封裝思路,至于像頭布局、腳布局、空布局、加載更多布局等等,其實都是Adapter中的一種vietType布局,具體實現(xiàn)代碼,GitHub:BaseAdapter
下圖是一adapter中數(shù)據(jù)構(gòu)造:
以上就是Android應用中怎么對RecyclerView Adapter進行封裝,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。