国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

android ListView結合xutils3仿微信實現下拉加載更多

2019-12-12 01:39:27
字體:
來源:轉載
供稿:網友

前言:最近涉及到和QQ打交道,定義所有的好友一共只能有300條消息,如果一次性從數據庫讀取300條或者更多,界面會有細微的卡頓.所以考慮了下分頁,第一次進來只顯示20條(仿微信),當用戶滑到第一條后,如果數據庫有消息,則再加載20條.

步驟-問把大象關冰箱,總共分幾步?

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; }  }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 河南省| 西乌| 乌拉特后旗| 桂平市| 日土县| 通化县| 疏附县| 汤原县| 秦皇岛市| 两当县| 九龙县| 定日县| 海阳市| 延寿县| 方山县| 孙吴县| 贵定县| 衡南县| 宁阳县| 南丰县| 霍州市| 绥江县| 冀州市| 巴林右旗| 三亚市| 阿巴嘎旗| 涟水县| 高平市| 金塔县| 大石桥市| 沈丘县| 德江县| 绥阳县| 宁阳县| 徐州市| 子长县| 甘南县| 扎鲁特旗| 乐平市| 孟津县| 灵川县|