通常我們寫一個繼承BaseAdapter的自定義適配器的時候,主要想做的大概有兩件事:
1、在適配的組件裏(如ListView,GridView)定義自己想要的佈局(Layout)。
2、爲佈局裏的組件(如Button)添加觸發響應的事件(如Click)。
當我們寫自定義Adapter的時候需要override以下幾個方法
@Overridepublic int getCount() { return 0; } @Overridepublic Object getItem(int position) { return null; } @Overridepublic long getItemId(int position) { return 0; } @Overridepublic View getView(int position, View convertView, ViewGroup parent) { return null; }
這裏我們需要了解getView方法不是在頁面生成的時候只被調用一次,而是根據你當前頁面能顯示的List裏的條目數,被調用數次。什麼意思呢?說白了,我們生成的這個自定義的頁面(通常是放在ListView裏的)看起來好像是一個整體,實際上是由許多個convertView拼裝成的,每個convertView就相當於一個Item,然後這些Item被塞到ListView中去,理解不了,可以看下圖:
這是一個activity的layout佈局。
這是一個Item的layout佈局。
convertView裏我們就可以隨意的加些小組件,比如按鈕啊,然後爲按鈕添加一些事件什麼的。
getView裏的具體實現我就不綴述了,我想強調的是返回值,一定要return最新生成的convertView,否則功虧一簣。這裏我栽過小2次。正確的就是這樣:
@Overridepublic View getView(int position, View convertView, ViewGroup parent) { //這裏就是給獲取組件,進行一些賦值操作或者添加事件 return convertView; }
然後,這裏還有另外一個坑,就是getCount方法。默認情況下就如同上面寫的一樣,看似好像可以不用管它,直接return 0;就好,不過經過我這個試坑專員的驗證,不管它是絕對不行的。當我們用 listview去setAdapter的時候,程序先走的是你自定義Adapter的構造函數,然後就會走getCount方法,之後纔會進入getView方法,如果getCount返回0了,那麼後面的事情就不用多想了,不會調用。這個坑我記得是把我整的挺慘,希望大家別掉下去。