Android之自定義實現(xiàn)BaseAdapter(通用適配器三)
在上一篇中,我們說過,在setData中如果有很多控件的話,我們還是要在該方法中寫入很多代碼,為了降低開發(fā)的方便性,本次就在此基礎(chǔ)上再一次優(yōu)化。實現(xiàn)原理是這樣的,每次在setData中都要查找控件,然后setXXX()什么的,我們可以把這寫實現(xiàn)放如到ViewHolder中去,在ViewHolder中寫入一個鏈式的方法,來幫助我們來實現(xiàn)功能(關(guān)于ViewHodler類的代碼我就不再重復(fù)寫了,代碼在此:Android之自定義實現(xiàn)BaseAdapter(通用適配器一) ),鏈式方法如下:
public ViewHolder setText(int viewId, String data){ TextView tv = getView(viewId); tv.setText(data); return this; }
通過這個方法,我們可以很好的去設(shè)置對應(yīng)的內(nèi)容,只需要傳一個需要設(shè)置控件的id,然后傳對應(yīng)的數(shù)據(jù),就可以達到設(shè)置文字的效果了,下面再看看我們的MyAdapter.java中的代碼
MyAdapter.java
/** * 上一篇中的MyAdapter */ public class MyAdapter extends MyBaseAdapter { public MyAdapter(List<Student> data) { super(data); } @Override public void setData(ViewHolder holder, Student t) { TextView tvName = holder.getView(R.id.mTv1); tvName.setText(t.getName()); TextView tvSex = holder.getView(R.id.mTv2); tvSex.setText(t.getSex()); } } /** * 優(yōu)化后的MyAdapter */ public class MyAdapter extends MyBaseAdapter { public MyAdapter(List<Student> data) { super(data); } @Override public void setData(ViewHolder holder, Student t) { holder.setText(R.id.mTv1, t.getName()).setText(R.id.mTv2, t.getSex()); } }
ok,對比一下setData中的實現(xiàn),我們這里只用一條代碼就可以代替上面的實現(xiàn)了,這樣是不是更方便呢,這樣的話,我們的擴展就更加方便了,如果說,我們不僅僅只是設(shè)置文本內(nèi)容,而是通過圖片控件設(shè)置圖片呢?很簡單,我們只需要在ViewHolder中再添加我們要實現(xiàn)的方法即可,比如設(shè)置圖片,我們可以添加如下代碼:
public ViewHolder setImageResource(int viewId,int resId){ ImageView img = getView(viewId); img.setImageResource(resId); return this; } public ViewHolder setImageBitmap(int viewId, Bitmap bm){ ImageView img = getView(viewId); img.setImageBitmap(bm); return this; }
添加這兩個方法后,需要設(shè)置圖片就很輕松了,只需在setData中傳遞對應(yīng)的參數(shù)即可
@Override public void setData(ViewHolder holder, Student t) { holder.setText(R.id.mTv1, t.getName()).setText(R.id.mTv2, t.getSex()); holder.setImageResource(R.id.img1,資源id).setImageBitmap(R.id.img2,bm); }
好了,一個通用的適配器就已經(jīng)完成了,整體框架和代碼都已經(jīng)實現(xiàn)了,我將所有的代碼都綜合一下,寫在下面,方便大家使用,分別是MainActivity.java(主界面類,負責傳參設(shè)置ListView的數(shù)據(jù))、MyAdapter.java(自定義的適配器)、MyBaseAdapter.java(通用的適配器類)、ViewHolder.java(通用的持有類對象)、以及實體類Student.java
MainActivity.java
public class MainActivity extends AppCompatActivity{ private List<Student> data; private ListView mList; MyAdapter adapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); getData(); mList = (ListView) findViewById(R.id.mList); adapter = new MyAdapter(data); mList.setAdapter(adapter); } private void getData() { data = new ArrayList<>(); Student stu = null; for (int i = 0; i < 20; i++) { stu = new Student(); stu.setName("姓名" + i); stu.setSex(i % 2 == 0 ? "男" : "女"); data.add(stu); } } }
MyAdapter.java
public class MyAdapter extends MyBaseAdapter<Student> { public MyAdapter(List<Student> data) { super(data); } @Override public void setData(ViewHolder holder, Student t) { holder.setText(R.id.mTv1, t.getName()).setText(R.id.mTv2, t.getSex()); } }
MyBaseAdapter.java
public abstract class MyBaseAdapter<T> extends BaseAdapter { protected List<T> data; public MyBaseAdapter(List<T> data){ this.data = data; } @Override public int getCount() { return data == null ? 0 : data.size(); } @Override public Object getItem(int position) { return data.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder = ViewHolder.getHolder(convertView,parent,position, R.layout.list_item); setData(holder,data.get(position)); return holder.getConvertView(); } public abstract void setData(ViewHolder holder,T t); }
ViewHolder.java
public class ViewHolder { private int position; private SparseArray<View> array; private View convertView; private Context context; private ViewHolder(ViewGroup parent, int position, int layout) { this.position = position; this.context = parent.getContext(); convertView = LayoutInflater.from(parent.getContext()).inflate(layout, null); convertView.setTag(this); array = new SparseArray<>(); } public static ViewHolder getHolder(View convertView, ViewGroup parent, int position, int layout) { if (convertView == null) { return new ViewHolder(parent, position, layout); } else { ViewHolder holder = (ViewHolder) convertView.getTag(); holder.position = position; return holder; } } public <T extends View> T getView(int viewId) { View view = array.get(viewId); if (view == null) { view = convertView.findViewById(viewId); array.put(viewId, view); } return (T) view; } public View getConvertView() { return convertView; } public ViewHolder setText(int viewId, String data) { TextView tv = getView(viewId); tv.setText(data); return this; } public ViewHolder setImageResource(int viewId, int resId) { ImageView img = getView(viewId); img.setImageResource(resId); return this; } public ViewHolder setImageBitmap(int viewId, Bitmap bm) { ImageView img = getView(viewId); img.setImageBitmap(bm); return this; } }
Student.java
public class Student { private String name; private String sex; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getSex() { return sex; } public void setSex(String sex) { this.sex = sex; } }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android實現(xiàn)微信右側(cè)頂部下拉對話框
這篇文章主要為大家詳細介紹了Android實現(xiàn)微信右側(cè)頂部下拉對話框,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12Android編程之文件讀寫操作與技巧總結(jié)【經(jīng)典收藏】
這篇文章主要介紹了Android編程之文件讀寫操作與技巧,結(jié)合實例形式總結(jié)分析了Android常見的文件與目錄的讀寫操作,及相關(guān)函數(shù)的使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下2016-06-06Android之高德地圖定位SDK集成及地圖功能實現(xiàn)
本文主要介紹了Android中高德地圖定位SDK集成及地圖功能的實現(xiàn)。具有很好的參考價值。下面跟著小編一起來看下吧2017-04-04Android開發(fā)筆記之:消息循環(huán)與Looper的詳解
本篇文章是對Android中消息循環(huán)與Looper的應(yīng)用進行了詳細的分析介紹,需要的朋友參考下2013-05-05淺析Android圓形進度條ProgressBar如何實現(xiàn)固定進度
之前遇到一個問題,發(fā)現(xiàn)Android里的圓形進度條無法固定一個進度,所以這篇文章就來和大家探索一下圓形進度條ProgressBar如何實現(xiàn)固定進度,希望對大家有所幫助2024-03-03Android用注解與反射實現(xiàn)Butterknife功能
Butterknife是一個在android上實現(xiàn)ioc(控制反轉(zhuǎn))的一個庫。ioc的核心是解耦。解耦的目的是修改耦合對象時不影響另外一個對象,降低模塊之間的關(guān)聯(lián)。在Spring中ioc更多的是依靠xml的配置。而android上的IOC框架可以不使用xml配置2022-11-11