您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“android ListView結合xutils3仿微信實現下拉加載更多的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“android ListView結合xutils3仿微信實現下拉加載更多的示例分析”這篇文章吧。
步驟-問把大象關冰箱,總共分幾步?
1.自定義absListview.scrollListerner
核心的東西是監聽ListView的scrollListerner,這里采取拿來主義 原文連接找不到了,如果原作者看到,請聯系青樓愛小生,將您的文章鏈接更新出來 ,網上扒了一個挺不錯的,大家用的時候實現這個scrollListerner,完善自己的邏輯即可
public class MyOnScrollListener implements OnScrollListener { private int totalItemCount; //ListView最后的item項 private int lastItem; //listview第一項 private int firstItem; //用于判斷當前是否在加載 private boolean isLoading; //底部加載更多布局 private View footer; //接口回調的實例 private OnloadDataListener listener; //數據 private List<MsgBean> data; Handler handler = new Handler(); public MyOnScrollListener(View footer, List<MsgBean> data) { this.footer = footer; this.data = data; } //設置接口回調的實例 public void setOnLoadDataListener(OnloadDataListener listener) { this.listener = listener; } /** * 滑動狀態變化 * * @param view * @param scrollState 1 SCROLL_STATE_TOUCH_SCROLL是拖動 2 SCROLL_STATE_FLING是慣性滑動 0SCROLL_STATE_IDLE是停止 , 只有當在不同狀態間切換的時候才會執行 */ @Override public void onScrollStateChanged(AbsListView view, int scrollState) { //如果數據沒有加載,并且滑動狀態是停止的,并且滾到了第一個item,可在此做下拉更新或者上拉更新的判斷 if (!isLoading && firstItem == 0 && scrollState == SCROLL_STATE_IDLE) { //顯示加載更多 footer.setVisibility(View.VISIBLE); //模擬一個延遲兩秒的刷新功能 handler.postDelayed(new Runnable() { @Override public void run() { if (listener != null) { //開始加載更多數據 loadMoreData(); //回調設置ListView的數據 listener.onLoadData(data); //加載完成后操作什么 loadComplete(); } } }, 2000); } } /** * 當加載數據完成后,設置加載標志為false表示沒有加載數據了 * 并且設置底部加載更多為隱藏 */ private void loadComplete() { isLoading = false; footer.setVisibility(View.GONE); } /** * 開始加載更多新數據,這里每次只更新三條數據 */ private void loadMoreData() { isLoading = true; MsgBean msg = null; for (int i = 0; i < 3; i++) { msg = new MsgBean(); msg .setRemark("Liming"+i); msg .setMsgID(i); data.add(stu); } } /** * 監聽可見界面的情況 * * @param view ListView * @param firstVisibleItem 第一個可見的 item 的索引 * @param visibleItemCount 可以顯示的 item的條數 * @param totalItemCount 總共有多少個 item */ @Override public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) { //實現下拉加載 lastItem = firstVisibleItem + visibleItemCount; //實現上拉加載 firstItem = firstVisibleItem; //總listView的item個數 this.totalItemCount = totalItemCount; } //回調接口 public interface OnloadDataListener { void onLoadData(List<MsgBean> data); } }
2.實現此接口
public class ListPageActivity extends Activity implements MyOnScrollListener.OnloadDataListener { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_list_page); //顯示到ListView上 showListView(data); //自定義的滾動監聽事件 MyOnScrollListener onScrollListener = new MyOnScrollListener(header, data); //設置接口回調 onScrollListener.setOnLoadDataListener(this); //設置ListView的滾動監聽事件 mListView.setOnScrollListener(onScrollListener); @Override public void onLoadData(List<MsgBean> data) { //加載數據完成后,展示數據到ListView showListView(data); } }
showListView里面無疑是普通的更新adapter的工作
那么我們如何借助xutils的數據庫進行分類呢?
3.利用xutils數據庫操作進行分頁處理
首先,我們理一下思路,上面我們已經實現了上拉的回調,在此回調中把新來的數據加載到adapter即可.
下文db是Dbmanager的實例
/** * 當前屏幕顯示的消息數量 */ private int MAX_MSG_NUMBER = 20;
private List<MsgBean> getDataFromDb() { List<?> dbSize = db.selector(MsgBean.class).where(WhereBuilder.b("id", "=", 400)).findAll();//記得捕獲null指針和DbException異常 //如果數據庫比我們顯示的頁數小,則不偏移,否則,偏移到我們需要顯示的位置 if (dbSize.size() < MAX_MSG_NUMBER) { indexOffset = 0; } else { indexOffset = dbSize.size() - MAX_MSG_NUMBER; } List<MsgBean> datas = db.selector(MsgBean.class).where(WhereBuilder.b("id", "=", 400)).limit(MAX_MSG_NUMBER) .offset(indexOffset).findAll(); return datas; }
這里解釋一下
db.selector(MsgBean.class).where(WhereBuilder.b("id", "=", 400)).limit(MAX_MSG_NUMBER).offset(indexOffset).findAll();是我們實現分頁的關鍵
.limit是我們定義的分頁大小
.offset偏移量,我們數據庫的大小是不變的,如果不定義偏移量,那么我們定義的分頁大小每次只從0取到19.假設數據庫中有21條數據,那么我們需要從1取到20,而不是0到19,所以偏移1.
然后我們在loadMoreData中
MAX_MSG_NUMBER += MAX_MSG_NUMBER; getDataFromDb();
將大小自加,即完成加載更多的功能,在onLoadData(List<MsgBean> data)中加載數據即可.
后面貼上我對xutils數據庫操作的封裝,還有很多不完善之處
/** * 數據庫 xutils用法 * @author 青樓愛小生 */ public class DbUtil { private static final String TAG = DbUtil.class.getName(); private static DbUtil dbUtil; private DbManager db; private DbUtil(){ db = x.getDb(MyApplication.getInstance().daoConfig); } public static DbUtil getInstance(){ if(dbUtil == null){ synchronized (DbUtil.class) { if(dbUtil == null){ dbUtil = new DbUtil(); } } } return dbUtil; } /** * 增加數據 * @param list * @throws DbException */ public void addMsgList(List<MsgBean> list) { try { db.saveOrUpdate(list); } catch (DbException e) { e.printStackTrace(); LogHelper.e(TAG, e.getMessage()); } } /** * 增加一條數據 * @param node * @throws DbException */ public void addMsgToDb(MsgBean node) { try { db.saveOrUpdate(node); } catch (DbException e) { e.printStackTrace(); LogHelper.e(TAG, e.getMessage()); } } /** * 刪除表中所有數據 * @param cls 創建的表的映射 * @throws DbException */ public void deleteAll(Class cls) { try { db.delete(cls); } catch (DbException e) { LogHelper.e(TAG, e.getMessage()); e.printStackTrace(); } } /** * 刪除第一條數據 * @param cls */ @SuppressWarnings("unchecked") public void deleteFirst(Class cls){ try { db.delete(db.findFirst(cls)); } catch (DbException e) { // TODO Auto-generated catch block e.printStackTrace(); } } /** * 查詢表中所有數據 * @throws DbException */ @SuppressWarnings("unchecked") public List<?> findAll(Class cls) { try { return db.findAll(cls) == null ? Collections.emptyList() : db.findAll(cls); } catch (DbException e) { e.printStackTrace(); LogHelper.e(TAG, e.getMessage()); return Collections.emptyList(); } } /** * //添加查詢條件進行查詢 List<ChildInfo> all = db.selector(ChildInfo.class).where("id",">",2).and("id","<",4).findAll(); * @return 搜索指定條件的數據 */ @SuppressWarnings("unchecked") public List<?> findDataByWhere(Class cls,WhereBuilder format){ try { return db.selector(cls).where(format).findAll()== null ? Collections.emptyList() :db.selector(cls).where(format).findAll(); } catch (DbException e) { LogHelper.e(TAG, e.getMessage()); e.printStackTrace(); return Collections.emptyList(); } } /** * 添加查詢條件進行查詢 * @param cls 表映射 * @param str select語句 * @param format where語句 * @return List<DbModel> DbModel key為數據庫列名 value為值 * eg:(Selector.from(Parent.class) .where("id" ,"<", 54) .and(WhereBuilder.b("age", ">", 20).or("age", " < ", 30)) .orderBy("id") .limit(pageSize) .offset(pageSize * pageIndex)); * * * */ @SuppressWarnings("unchecked") public Selector<?> findDataBySelector(Class cls,WhereBuilder format){ try { return db.selector(cls).where(format); } catch (DbException e) { // TODO Auto-generated catch block e.printStackTrace(); } return null; } }
以上是“android ListView結合xutils3仿微信實現下拉加載更多的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。