要想實現OnScrollListener接口只要重寫兩個方法就能夠!例如:java
class MyScrollListener implements OnScrollListener { @Override public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) { /** * we want to load the next chunk of data before the user reach the end of the list. * 在列表打到末尾以前,咱們要加載下一個數據塊 * firstVisibleItem 表示在當前屏幕顯示的第一個listItem在整個listView裏面的位置(下標從0開始) * visibleItemCount表示在現時屏幕能夠見到的ListItem(部分顯示的ListItem也算)總數 * totalItemCount表示ListView的ListItem總數 * listView.getLastVisiblePosition()表示在現時屏幕最後一個ListItem * (最後ListItem要徹底顯示出來纔算)在整個ListView的位置(下標從0開始) */ Log.d("load", ""+firstVisibleItem+"----"+visibleItemCount+"-----"+totalItemCount); if(firstVisibleItem + visibleItemCount < totalItemCount - 3){ Log.d("load", "if------<>"); return; } if(dataLoader.isLoading() == false){ Log.d("load", "false------>"); loadNext(); } } @Override public void onScrollStateChanged(AbsListView view, int scrollState) { Log.d("load", "onScrollStateChanged"); } }
若是adapter中的數據量很大的時候,在加載listview時會出現卡頓的現象。這是會讓用戶抓狂!最好的解決辦法就是先加載必定數量的數據,而後在最下方提示正在加載!
動態加載就是把放入adapter中的數據分好幾回加載。在用戶拖動listview時再加載必定的數據,和sina微博的客戶端相似。 例如:ide
new OnScrollListener() { boolean isLastRow = false; @Override public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) { //滾動時一直回調,直到中止滾動時才中止回調。單擊時回調一次。 //firstVisibleItem:當前能看見的第一個列表項ID(從0開始) //visibleItemCount:當前能看見的列表項個數(小半個也算) //totalItemCount:列表項共數 //判斷是否滾到最後一行 if (firstVisibleItem + visibleItemCount == totalItemCount && totalItemCount > 0) { isLastRow = true; } } @Override public void onScrollStateChanged(AbsListView view, int scrollState) { //正在滾動時回調,回調2-3次,手指沒拋則回調2次。scrollState = 2的此次不回調 //回調順序以下 //第1次:scrollState = SCROLL_STATE_TOUCH_SCROLL(1) 正在滾動 //第2次:scrollState = SCROLL_STATE_FLING(2) 手指作了拋的動做(手指離開屏幕前,用力滑了一下) //第3次:scrollState = SCROLL_STATE_IDLE(0) 中止滾動 //當屏幕中止滾動時爲0;當屏幕滾動且用戶使用的觸碰或手指還在屏幕上時爲1; //因爲用戶的操做,屏幕產生慣性滑動時爲2 //當滾到最後一行且中止滾動時,執行加載 if (isLastRow && scrollState == AbsListView.OnScrollListener.SCROLL_STATE_IDLE) { //加載元素 ...... isLastRow = false; } } }