我們今天就結合實例來演示一下使用ListView獲取數據的過程。
新建一個loadmore項目,我們來看一下結構圖和最終效果圖:
左圖中包含了三個佈局文件、一個Adapter和一個Activity,右圖是我們運行後的主界面。
其中,main.xml是主界面的佈局文件,它包含一個ListView組件,代碼如下:
然後就是list_item.xml,它是ListView中單個列表項的佈局文件,從效果圖中可以看到,這裏只使用到了一個TextView組件,list_item.xml代碼如下:
我們注意到在右圖中列表底部有一個按鈕不同於其他的列表項,這是什麼情況?事實上這個按鈕是我們在ListView底部添加的一個視圖。 ListView組件提供了兩個很實用的功能,那就是可以在頂部和底部添加自定義的視圖。我們在此處ListView的底部添加了一個視圖用來加載更多數 據,這個視圖對應着load_more.xml佈局文件,代碼如下:
接下來我們來了解一下我們的Adapter,ListViewAdapter代碼如下:
這個ListViewAdapter是我們自定義適配器,它繼承自BaseAdapter,實例化此適配器需要一個Context對象來獲取 LayoutInflater實例和一個集合對象來充當適配器的數據集;在getView方法中我們填充list_item.xml佈局文件,完成列表每 一項的數據顯示;addItem方法用來在加載數據時向數據集中添加新數據。
最後我們來看一下MainActivity:
如代碼所示,我們在onCreate方法被調用時獲取listView組件,設置其底部視圖爲loadMoreView,它包含一個按鈕,點擊時會 觸發loadMore方法調用,另外在爲listView設置完適配器時,又爲其設置了滑動事件監聽器,滑動列表時onScroll會被調用,滑動狀態改 變時onScrollStateChanged會被調用。
我們來演示一下這個加載過程:
如圖,當點擊完按鈕後,出現加載動作,加載完之後如右圖所示,新數據緊接在原數據之後。然後我們滑動到底部,加載按鈕仍可工作:
最後,我們測試一下滑動列表到底部,然後鬆開,控制檯打印如下: