亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

android ListView結合xutils3仿微信實現下拉加載更多的示例分析

發布時間:2021-07-27 09:53:40 來源:億速云 閱讀:111 作者:小新 欄目:移動開發

這篇文章主要為大家展示了“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仿微信實現下拉加載更多的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平邑县| 栾川县| 双桥区| 牡丹江市| 蛟河市| 凭祥市| 余江县| 大理市| 彭山县| 武定县| 东兴市| 蛟河市| 孝昌县| 铜陵市| 托克托县| 彭阳县| 北碚区| 台南县| 舒兰市| 大渡口区| 佛山市| 石嘴山市| 苏尼特右旗| 无为县| 清徐县| 醴陵市| 抚顺县| 佛山市| 奉新县| 嵊州市| 灵丘县| 准格尔旗| 丹凤县| 石门县| 安溪县| 恭城| 丹寨县| 含山县| 贺兰县| 临安市| 资中县|