Java ArrayAdapter用法案例詳解
拖延癥最可怕的地方就是:就算自己這邊沒有拖延,但對(duì)方也會(huì)拖延,進(jìn)而導(dǎo)致自己這邊也開始拖延起來!現(xiàn)在這個(gè)項(xiàng)目我這邊已經(jīng)是完工了,但是對(duì)方遲遲沒有搞定,導(dǎo)致整個(gè)項(xiàng)目無法提交。
這就是拖延癥的可怕:我們不僅是與自己的拖延癥作戰(zhàn),而是與所有有關(guān)人士的拖延癥作戰(zhàn),決定項(xiàng)目是否能夠提交,在于那個(gè)最慢的人。
既然決定權(quán)已經(jīng)不在我的手上,那么我也可以做做其他事情,像是現(xiàn)在這樣寫寫博客。
這次就介紹一下ListView中比較簡(jiǎn)單但又非常方便的ArrayAdapter。
ArrayAdapter是BaseAdapter的派生類,在BaseAdapter的基礎(chǔ)上,添加了一項(xiàng)重大的功能:可以直接使用泛型構(gòu)造。
我們先來看一個(gè)簡(jiǎn)單的例子:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ListView listView = (ListView) this.findViewById(R.id.list); UserAdapter adapter = new UserAdapter(this, R.layout.list_item); adapter.add(new User(10, "小智", "男")); adapter.add(new User(10, "小霞", "女")); listView.setAdapter(adapter); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } class UserAdapter extends ArrayAdapter<User> { private int mResourceId; public UserAdapter(Context context, int textViewResourceId) { super(context, textViewResourceId); this.mResourceId = textViewResourceId; } @Override public View getView(int position, View convertView, ViewGroup parent) { User user = getItem(position); LayoutInflater inflater = getLayoutInflater(); View view = inflater.inflate(mResourceId, null); TextView nameText = (TextView) view.findViewById(R.id.name); TextView ageText = (TextView) view.findViewById(R.id.age); TextView sexText = (TextView) view.findViewById(R.id.sex); nameText.setText(user.getName()); ageText.setText(user.getAge()); sexText.setText(user.getSex()); return view; } } class User { private int mAge; private String mName; private String mSex; public User(int age, String name, String sex) { this.mAge = age; this.mName = name; this.mSex = sex; } public String getName() { return this.mName; } public String getAge() { return this.mAge + ""; } public String getSex() { return this.mSex; } }
這里自定義了一個(gè)ArrayAdapter,有關(guān)于Adapter的使用在之前的SimpleAdapter中已經(jīng)涉及到了,所以這里直接就是以自定義的ArrayAdapter作為例子。
我們這里需要將學(xué)生的信息羅列出來,需要三個(gè)TextView:
<?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="match_parent" android:orientation="vertical" > <TextView android:id="@+id/name" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <TextView android:id="@+id/age" android:layout_width="wrap_content" android:layout_height="wrap_content" /> <TextView android:id="@+id/sex" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </LinearLayout>
在自定義ArrayAdapter的時(shí)候,最神奇的地方就是我們可以指定ArrayAdapter綁定的數(shù)據(jù)類型,可以是基本數(shù)據(jù)類型,也可以是自定義的對(duì)象類型,像是這次的User類型。對(duì)于自定義的ArrayAdapter的構(gòu)造方法,存在很多形式,這次是傳進(jìn)一個(gè)View的資源Id,但是我們也可以指定綁定的數(shù)據(jù)類型。
ArrayAdapter的神奇之處就是我們竟然可以像是操作Array一樣來操作ArrayAdapter!像是例子中的添加操作,而其他的適配器都是需要傳進(jìn)一個(gè)容器的。ArrayAdapter為什么可以處理對(duì)象類型的數(shù)據(jù)呢?其實(shí),ArrayAdapter是使用數(shù)組中對(duì)象的toString()方法來填充指定的TextView,所以我們可以通過重寫對(duì)象的toString()方法來自定義ListView的顯示。
@Override public View getView(int position, View convertView, ViewGroup parent) { User user = getItem(position); LayoutInflater inflater = getLayoutInflater(); View view = inflater.inflate(mResourceId, null); TextView text = (TextView) view.findViewById(R.id.info); text.setText(user.toString()); return view; } class User { private int mAge; private String mName; private String mSex; public User(int age, String name, String sex) { this.mAge = age; this.mName = name; this.mSex = sex; } @Override public String toString() { return "姓名:" + mName + " " + "年齡:" + mAge + " " + "性別:" + mSex; } }
這樣我們可以只在一行中顯示所有數(shù)據(jù)。
使用ArrayAdapter最大的疑問就是我們是否需要將一個(gè)現(xiàn)成的容器傳入ArrayAdapter中?原本ArrayAdapter本身就用一般容器的基本操作,像是添加新的元素等,但它本身并不能完成當(dāng)成容器使用,我們更多的時(shí)候是要將一個(gè)容器中的元素交給ArrayAdapter,由后者決定它的顯示形式。
class UserAdapter extends ArrayAdapter<User> { private int mResourceId; public UserAdapter(Context context, int textViewResourceId, List<User> users) { super(context, textViewResourceId, users); this.mResourceId = textViewResourceId; } @Override public View getView(int position, View convertView, ViewGroup parent) { User user = getItem(position); LayoutInflater inflater = getLayoutInflater(); View view = inflater.inflate(mResourceId, null); TextView text = (TextView) view.findViewById(R.id.info); text.setText(user.toString()); return view; } }
List<User> users = new ArrayList<User>(); users.add(new User(10, "小智", "男")); users.add(new User(10, "小霞", "女")); UserAdapter adapter = new UserAdapter(this, R.layout.list_item, users); listView.setAdapter(adapter);
如果我們將ArrayAdapter綁定的數(shù)據(jù)類型定義為Object,我們可以自由的傳入任何類型的容器而不需要任何有關(guān)類型轉(zhuǎn)換的操作!
ArrayAdapter不僅僅是可以顯示TextView,它當(dāng)讓也像是其他Adapter一樣,可以顯示任何其他非TextView的組件:
@Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ListView listView = (ListView) this.findViewById(R.id.list); List<Object> users = new ArrayList<Object>(); users.add(10); users.add(11); UserAdapter adapter = new UserAdapter(this, R.layout.list_item, R.id.info, users); listView.setAdapter(adapter); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.main, menu); return true; } class UserAdapter extends ArrayAdapter<Object> { private int mResourceId; public UserAdapter(Context context, int resourceId, int textViewResourceId, List<Object> users) { super(context, resourceId, textViewResourceId, users); this.mResourceId = resourceId; } @Override public View getView(int position, View convertView, ViewGroup parent) { Object user = getItem(position); LayoutInflater inflater = getLayoutInflater(); View view = inflater.inflate(mResourceId, null); TextView text = (TextView) view.findViewById(R.id.info); text.setText(user.toString()); return view; } }
<?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="match_parent" android:orientation="vertical" > <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="點(diǎn)擊" /> <TextView android:id="@+id/info" android:layout_width="wrap_content" android:layout_height="wrap_content" /> </LinearLayout>
如果我們的布局中需要其他組件,必須指定該布局中用于顯示ArrayAdapter中數(shù)據(jù)的TextView的Id。
如果只是方便綁定數(shù)據(jù)的話,其實(shí)是沒有必要專門獨(dú)立個(gè)ArrayAdapter出來,只要覆寫getView()就可以,正如使用容器就是為了方便大量數(shù)據(jù)的處理一樣的道理,使用ArrayAdapter也是為了處理數(shù)據(jù)較大的情況,像是超過100條或者頻繁動(dòng)態(tài)增刪數(shù)據(jù)時(shí),就可以使用ArrayAdapter,而且,為了方便我們刷新UI,ArrayAdapter也提供了setNotifyOnChange()方法,這樣可以降低UI的處理量,使得刷新UI更加快速,主要是通過停止對(duì)add,insert,remove和clear的操作來實(shí)現(xiàn)這點(diǎn)。
相關(guān)文章
Java maven三種倉(cāng)庫(kù),本地倉(cāng)庫(kù),私服,中央倉(cāng)庫(kù)的配置
今天給大家簡(jiǎn)單介紹Maven三種倉(cāng)庫(kù)的配置,文中有非常詳細(xì)的解釋,對(duì)Java初學(xué)者很有幫助喲,需要的朋友可以參考下,希望能夠給你帶來幫助2021-09-09在Spring中利用@Order注解對(duì)bean和依賴進(jìn)行排序
在Spring框架中,@Order是一個(gè)經(jīng)常被忽視但非常重要的注解,在項(xiàng)目開發(fā)中,當(dāng)我們需要維護(hù)bean的特定順序或者存在許多相同類型的bean時(shí),這個(gè)注解就發(fā)揮了作用,這篇文章講的就是如何利用@Order注解對(duì)bean和依賴進(jìn)行排序,需要的朋友可以參考下2023-11-11java構(gòu)造函數(shù)示例(構(gòu)造方法)
這篇文章主要介紹了java構(gòu)造函數(shù)示例(構(gòu)造方法),需要的朋友可以參考下2014-03-03解決IDEA導(dǎo)入javaWeb項(xiàng)目注解爆紅的問題
這篇文章主要介紹了解決IDEA導(dǎo)入javaWeb項(xiàng)目注解爆紅的問題,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10IntelliJ IDEA 2020.1 EAP4 發(fā)布,重命名/更改簽名新功能一覽
這篇文章主要介紹了IntelliJ IDEA 2020.1 EAP4 發(fā)布,重命名/更改簽名新功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-04-04