From 592ad3b6524ff524c999674b272a653ef062780e Mon Sep 17 00:00:00 2001
From: mac <user@users-MacBook-Pro.local>
Date: 星期二, 30 一月 2024 13:47:17 +0800
Subject: [PATCH] 2024年01月30日13:47:09

---
 app/src/main/java/com/hdl/photovoltaic/ui/message/NascentMessageFragment.java |  284 +++++++++++++++---------------
 app/src/main/java/com/hdl/photovoltaic/config/AppConfigManage.java            |    2 
 app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java |  146 ++++++++++-----
 app/src/main/res/layout/item_message.xml                                      |    9 
 app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java             |   85 +++-----
 app/src/main/java/com/hdl/photovoltaic/ui/HomeLoginActivity.java              |    2 
 6 files changed, 279 insertions(+), 249 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/config/AppConfigManage.java b/app/src/main/java/com/hdl/photovoltaic/config/AppConfigManage.java
index b980dc7..60889ae 100644
--- a/app/src/main/java/com/hdl/photovoltaic/config/AppConfigManage.java
+++ b/app/src/main/java/com/hdl/photovoltaic/config/AppConfigManage.java
@@ -9,7 +9,7 @@
 
 
     /*********鏄惁姝e紡鏈嶅姟鍣�*********/
-    private static final boolean isOnlineServer = true;
+    private static final boolean isOnlineServer = false;
     /*********姝e紡鐜*********/
     private static final String APP_KEY_ONLINE = "CSZEMDJL";
     private static final String APP_SECRET_ONLINE = "CSZEMDKBCSZEMDKR";
diff --git a/app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java b/app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java
index 43e9624..b8fa1bb 100644
--- a/app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java
+++ b/app/src/main/java/com/hdl/photovoltaic/other/HdlMessageLogic.java
@@ -23,7 +23,8 @@
 public class HdlMessageLogic {
     private static volatile HdlMessageLogic sHdlMessageLogic;
 
-    private int pageSize = 50;//椤垫暟
+    private final int pageSize = 50;//椤垫暟
+    private List<MessageBean> mListMessage = new ArrayList<>();
 
     /**
      * 鑾峰彇褰撳墠瀵硅薄
@@ -41,6 +42,7 @@
         }
         return sHdlMessageLogic;
     }
+
 
     /**
      * 鑾峰彇鍙戠敓涓紦瀛樺垪琛�
@@ -242,8 +244,29 @@
     }
 
 
-    private List<MessageBean> mListMessage = new ArrayList<>();
+    /**
+     * 鑾峰彇鏈鐞嗙紦瀛樻秷鎭暟閲�
+     */
+    public String getMessageUntreatedMemoryCount() {
+        if (this.mListMessage == null || this.mListMessage.size() == 0) {
+            return "0";
+        }
+        List<MessageBean> newList = new ArrayList<>();
+        for (int i = 0; i < mListMessage.size(); i++) {
+            MessageBean messageBean = mListMessage.get(i);
+            if (messageBean == null) {
+                continue;
+            }
+            if (!messageBean.getStatus().equals(MessageStateType.untreated)) {
+                continue;
+            }
+            if (!messageBean.isRead()) {
+                newList.add(messageBean);
+            }
 
+        }
+        return newList.size() + "";
+    }
 
     /**
      * 鑾峰彇鏈鐞嗘秷鎭暟閲�
@@ -314,7 +337,7 @@
             json.addProperty("status", messageStateType);
         }
         json.addProperty("pageNo", 1);//椤电爜
-        json.addProperty("pageSize", 50);//椤垫暟
+        json.addProperty("pageSize", pageSize);//椤垫暟
 
         List<MessageBean> list = new ArrayList<>();
         HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
@@ -384,74 +407,36 @@
     }
 
     /**
-     * 鑾峰彇娑堟伅鍒楄〃
+     * 鑾峰彇鎸囧畾椤电殑鑾峰彇娑堟伅鍒楄〃
      *
+     * @param pageNo           椤电爜
      * @param messageStateType all:鍏ㄩ儴,UNTREATED:鏈鐞�,PROCESSED:宸插鐞�;
      * @param cloudCallBeak    -
      */
-    private void getMessageList(int pageNo, String messageStateType, CloudCallBeak<List<MessageBean>> cloudCallBeak) {
+    public void getPageNoMessageList(int pageNo, String messageStateType, CloudCallBeak<MessageListClass> cloudCallBeak) {
         String requestUrl = HttpApi.POST_Message_List;
         JsonObject json = new JsonObject();
 
         if (!MessageStateType.all.equals(messageStateType)) {
             json.addProperty("status", messageStateType);
         }
-        json.addProperty("pageNo", 1);//椤电爜
-        json.addProperty("pageSize", 50);//椤垫暟
+        json.addProperty("pageNo", pageNo);//椤电爜
+        json.addProperty("pageSize", pageSize);//椤垫暟
 
-        List<MessageBean> list = new ArrayList<>();
         HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
             @Override
             public void onSuccess(String jsonStr) {
                 if (TextUtils.isEmpty(jsonStr)) {
                     if (cloudCallBeak != null) {
-                        cloudCallBeak.onSuccess(new ArrayList<>());
+                        cloudCallBeak.onSuccess(new MessageListClass());
                     }
                     return;
                 }
                 Gson gson = new Gson();
                 MessageListClass oldMessageListClass = gson.fromJson(jsonStr, MessageListClass.class);
-                list.addAll(oldMessageListClass.getList());
                 setListMessage(oldMessageListClass.getList());
-                //鎬诲叡鏈夊灏戦〉
-                long totalPage = oldMessageListClass.totalPage;
-                if (totalPage < 2) {
-                    if (cloudCallBeak != null) {
-                        cloudCallBeak.onSuccess(list);
-                    }
-                    return;
-                }
-                //璁板綍璇锋眰鏉℃暟
-                AtomicInteger atomicInteger = new AtomicInteger(0);
-                //浠庣浜岄〉鑾峰彇鏁版嵁
-                for (int i = 2; i <= totalPage; i++) {
-                    json.addProperty("pageNo", i);//鏇存柊椤电爜
-                    HttpClient.getInstance().requestHttp(requestUrl, json.toString(), new CloudCallBeak<String>() {
-                        @Override
-                        public void onSuccess(String jsonStr) {
-                            atomicInteger.set(atomicInteger.get() + 1);
-                            MessageListClass newMessageListClass = gson.fromJson(jsonStr, MessageListClass.class);
-                            list.addAll(newMessageListClass.getList());
-                            setListMessage(newMessageListClass.getList());
-                            if (atomicInteger.get() == totalPage - 1) {
-                                //鏈�鍚庝竴鏉¢��鍑�
-                                if (cloudCallBeak != null) {
-                                    cloudCallBeak.onSuccess(list);
-                                }
-                            }
-                        }
-
-                        @Override
-                        public void onFailure(HDLException e) {
-                            atomicInteger.set(atomicInteger.get() + 1);
-                            if (atomicInteger.get() == totalPage - 1) {
-                                //鏈�鍚庝竴鏉¢��鍑�
-                                if (cloudCallBeak != null) {
-                                    cloudCallBeak.onSuccess(list);
-                                }
-                            }
-                        }
-                    });
+                if (cloudCallBeak != null) {
+                    cloudCallBeak.onSuccess(oldMessageListClass);
                 }
             }
 
@@ -533,7 +518,7 @@
     }
 
 
-    static class MessageListClass {
+    public static class MessageListClass {
 
         //鎬绘潯鏁�
         private long totalCount;
diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/HomeLoginActivity.java b/app/src/main/java/com/hdl/photovoltaic/ui/HomeLoginActivity.java
index 8718cff..6bff9c1 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/HomeLoginActivity.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/HomeLoginActivity.java
@@ -114,7 +114,7 @@
         }
 
         String acc = "13375012441";
-        String pws = "a123456";
+        String pws = "123456";
         //娴嬭瘯鐢�
         viewBinding.homeLoginAccountEt.setText(acc);
         viewBinding.homeLoginPasswordEt.setText(pws);
diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/message/NascentMessageFragment.java b/app/src/main/java/com/hdl/photovoltaic/ui/message/NascentMessageFragment.java
index e672fd4..016b4c4 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/message/NascentMessageFragment.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/message/NascentMessageFragment.java
@@ -5,6 +5,7 @@
 import android.os.Bundle;
 import android.os.Handler;
 import android.text.TextUtils;
+import android.util.Log;
 import android.view.MotionEvent;
 import android.view.View;
 import android.widget.TextView;
@@ -39,6 +40,7 @@
 import org.greenrobot.eventbus.ThreadMode;
 
 import java.util.ArrayList;
+import java.util.Date;
 import java.util.List;
 
 /**
@@ -50,10 +52,9 @@
     private MessageAdapter messageNascentAdapter;
 
     private final List<MessageBean> mList = new ArrayList<>();
+    private int currentPage = 0; // 褰撳墠椤电爜
+    private int total = 0; // 鏈�鍚庨〉鐮�
 
-    // 娣诲姞涓婃媺鍔犺浇鏇村鐨勯�昏緫
-    private int visibleThreshold = 5; // 褰撳墠鏄剧ず鐨勬渶鍚庝竴椤逛笌鎬诲叡鏈夊灏戞潯鏁版嵁涔嬮棿鐨勫樊鍊�
-    private int currentPage = 1; // 褰撳墠椤电爜
     private boolean isLoadingMore = false; // 鏍囪姝e湪鍔犺浇鏇村鏁版嵁
 
     LinearLayoutManager layoutManager;
@@ -85,9 +86,10 @@
         viewBinding.messageNascentSrl.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
             @Override
             public void onRefresh() {
-                mList.clear();//琛ㄧず寮哄埗閲嶆柊璇锋眰娑堟伅鍒楄〃
-                updateListData();//娓呯┖涔嬪墠缂撳瓨,鍥犱负閬囧埌涓�涓棶棰樼寷鎷夌殑鏃跺�欐姤閿�;
-                getNascentMessageList(false);
+                viewBinding.messageNascentSrl.setRefreshing(false);
+//                mList.clear();//琛ㄧず寮哄埗閲嶆柊璇锋眰娑堟伅鍒楄〃
+//                updateListData();//娓呯┖涔嬪墠缂撳瓨,鍥犱负閬囧埌涓�涓棶棰樼寷鎷夌殑鏃跺�欐姤閿�;
+//                getNascentMessageList(false);
             }
         });
         messageNascentAdapter.setNoOnclickListener(new MessageAdapter.OnclickListener() {
@@ -107,25 +109,22 @@
         viewBinding.messageNascentRecyclerview.addOnScrollListener(new RecyclerView.OnScrollListener() {
             @Override
             public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) {
-                super.onScrolled(recyclerView, dx, dy);
+//                super.onScrolled(recyclerView, dx, dy);
 
-//                if (dy <= 0) {
-//                    //绛変簬0鏄《閮�
-//                    return;
-//                }
-//                LinearLayoutManager layoutManager = (LinearLayoutManager) recyclerView.getLayoutManager();
-//                assert layoutManager != null;
-//                // 鍙湁鍨傜洿甯冨眬鎵嶄細瑙﹀彂涓婃媺浜嬩欢
-//                if (!layoutManager.canScrollVertically()) {
-//                    return;
-//                }
-//
-//                int totalItemCount = layoutManager.getItemCount();
-//                int lastVisibleItemPosition = layoutManager.findLastVisibleItemPosition();
-//
-//                if (!isLoadingMore && totalItemCount <= (lastVisibleItemPosition + visibleThreshold)) {
-////                    loadNextPage();
-//                }
+                LinearLayoutManager layoutManager = (LinearLayoutManager) recyclerView.getLayoutManager();
+                if (layoutManager == null) {
+                    return;
+                }
+                int visibleItemCount = layoutManager.getChildCount();
+                int totalItemCount = layoutManager.getItemCount();
+                int firstVisibleItemPosition = layoutManager.findFirstVisibleItemPosition();
+                if (visibleItemCount > 0 && visibleItemCount + firstVisibleItemPosition == totalItemCount) {
+                    if (!isLoadingMore) {
+                        // 婊戝姩鍒颁簡搴曢儴锛屾墽琛岀浉搴旂殑鎿嶄綔
+                        HdlLogLogic.print("--->婊戝姩鍒颁簡搴曢儴");
+                        loadNextPageNascentMessageList(++currentPage, false);
+                    }
+                }
             }
         });
     }
@@ -141,15 +140,24 @@
      * 鍒锋柊鍒楄〃鏁版嵁
      */
     private void updateListData() {
-        if (this.messageNascentAdapter != null) {
-            this.messageNascentAdapter.setList(mList);
-            this.messageNascentAdapter.notifyDataSetChanged();
-        }
-        //鍒锋柊銆愬彂鐢熶腑銆戜俊鎭暟閲忔�绘暟
-        this.refreshNascentCount();
-        this.nullDataUpdateUi();
-
-
+        HdlThreadLogic.runMainThread(new Runnable() {
+            @Override
+            public void run() {
+                //鏇存柊缂撳瓨鏁版嵁
+                initData();
+                //鍒锋柊鍒楄〃
+                if (messageNascentAdapter != null) {
+                    messageNascentAdapter.setList(mList);
+                    messageNascentAdapter.notifyDataSetChanged();
+                }
+                //鏄剧ず鍙戠敓涓秷鎭�绘暟閲�
+                refreshNascentCount();
+                //鏄剧ず娌℃暟鎹甎i鏍峰紡
+                nullDataUpdateUi();
+                //鏄剧ず鏈淇℃伅鎬绘暟閲�
+                getUnreadCount();
+            }
+        });
     }
 
     /**
@@ -181,8 +189,8 @@
         if (eventBus.getTopic().equals(ConstantManage.message_function_tab_switch)) {
             if (eventBus.getType().equals(MessageFunctionTabSwitch.nascent.toString())) {
                 initData();
-                getNascentMessageList(true);
-                getUnreadCount();
+                loadNextPageNascentMessageList(1, true);
+//                getUnreadCount();
                 // 鍙栨秷绮樻�т簨浠�
                 EventBus.getDefault().removeStickyEvent(eventBus);
 
@@ -193,126 +201,121 @@
                 //娑堟伅璇︽儏鍥炶皟
                 initData();
                 updateListData();
-                getUnreadCount();
+//                getUnreadCount();
             }
         }
     }
 
     /**
-     * 鑾峰彇鍙戠敓涓殑娑堟伅鍒楄〃
+     * 鍔犺浇涓�椤垫暟鎹�
      *
+     * @param pageNo        椤垫暟
      * @param isShowLoading 鏄惁鍚姩鍔犺浇妗� true鍚姩
      */
-    private void getNascentMessageList(boolean isShowLoading) {
-        if (mList.size() == 0) {
-            if (isShowLoading) {
-                showLoading();
-            }
-            HdlMessageLogic.getInstance().getNascentMessageList(new CloudCallBeak<List<MessageBean>>() {
-                @Override
-                public void onSuccess(List<MessageBean> list) {
-                    HdlThreadLogic.runMainThread(new Runnable() {
-                        @Override
-                        public void run() {
-                            if (isShowLoading) {
-                                hideLoading();
-                            }
-                            if (!isShowLoading) {
-                                viewBinding.messageNascentSrl.setRefreshing(false);
-                            }
-
-                            if (list != null && list.size() != 0) {
-                                mList.addAll(list);
-                                updateListData();
-                            } else {
-                                nullDataUpdateUi();
-                            }
-                        }
-                    });
-
-                }
-
-                @Override
-                public void onFailure(HDLException e) {
-                    if (isShowLoading) {
-                        hideLoading();
-                    }
-                    if (!isShowLoading) {
-                        viewBinding.messageNascentSrl.setRefreshing(false);
-                    }
-                }
-            });
+    private void loadNextPageNascentMessageList(int pageNo, boolean isShowLoading) {
+        if (pageNo == 1 && mList.size() > 0) {
+            //缂撳瓨鏁版嵁娌℃湁鎵嶅彲浠ヨ鍙栫涓�椤�
+            return;
         }
-    }
+        if (currentPage > total) {
+            //褰撳墠椤典笉鑳藉ぇ浜庢�婚〉鏁�
+            return;
+        }
+        isLoadingMore = true;//鏍囪璇诲彇鐘舵��
+        if (isShowLoading) {
+            showLoading();
+        }
+        HdlMessageLogic.getInstance().getPageNoMessageList(pageNo, MessageStateType.untreated, new CloudCallBeak<HdlMessageLogic.MessageListClass>() {
+            @Override
+            public void onSuccess(HdlMessageLogic.MessageListClass messageListClass) {
+                if (messageListClass != null) {
+                    total = (int) messageListClass.getTotalPage();
+                    currentPage = (int) messageListClass.getPageNo();
+                    updateListData();
+                }
+                isLoadingMore = false;
+                if (isShowLoading) {
+                    hideLoading();
+                }
+            }
 
-//    private void loadNextPage() {
-//        isLoadingMore = true;
-//
-//        // 妯℃嫙缃戠粶璇锋眰鑾峰彇鏂扮殑鏁版嵁
-//        Handler handler = new Handler();
-//        handler.postDelayed(() -> {
-//            List<MessageBean> newData = fetchNewDataFromServer(currentPage++);
-//            messageNascentAdapter.setList(newData);
-//            isLoadingMore = false;
-//        }, 2000);
-//    }
-//
-//    private List<MessageBean> fetchNewDataFromServer(int pageNumber) {
-//        // TODO: 浠庢湇鍔″櫒鑾峰彇鏂扮殑鏁版嵁骞惰繑鍥�
-//        pageNumber++;
-//        List<MessageBean> newData = HdlMessageLogic.getInstance().getAllMessageList();
-//        return newData;
-//    }
+            @Override
+            public void onFailure(HDLException e) {
+                if (currentPage > 1) {
+                    --currentPage;
+                }
+                isLoadingMore = false;
+                if (isShowLoading) {
+                    hideLoading();
+                }
+            }
+        });
+    }
 
     /**
      * 璇诲彇娑堟伅銆愭湭璇绘暟閲忋��
      */
     private void getUnreadCount() {
-        HdlMessageLogic.getInstance().getMessageUntreatedCount(new CloudCallBeak<String>() {
-            @Override
-            public void onSuccess(String data) {
-
-                HdlThreadLogic.runMainThread(new Runnable() {
-                    @Override
-                    public void run() {
-                        JSONObject jsonObject = JSON.parseObject(data);
-//                        if (jsonObject.containsKey("untreatedCount")) {
-//                            //鏈鐞嗘暟閲�
-//                            jsonObject.getString("untreatedCount");
-//                        }
-                        String unreadCount = "0";
-                        if (jsonObject.containsKey("unreadCount")) {
-                            //鏈鏁伴噺
-                            unreadCount = jsonObject.getString("unreadCount");
-                        }
-                        TextView textView = _mActivity.findViewById(R.id.my_message_bottom_il2).findViewById(R.id.red_count_tv);
-                        if (textView != null) {
-                            if (TextUtils.isEmpty(unreadCount) || unreadCount.equals("0")) {
-                                textView.setVisibility(View.GONE);
-                            } else {
-                                if (unreadCount.length() > 2) {
-                                    //澶т簬3浣嶆暟,榛樿99+
-                                    unreadCount = "99+";
-                                }
-                                textView.setVisibility(View.VISIBLE);
-                                textView.setText(unreadCount);
-                            }
-
-
-                        }
-                    }
-                });
-
-            }
-
-            @Override
-            public void onFailure(HDLException e) {
-                TextView textView = _mActivity.findViewById(R.id.my_message_bottom_il2).findViewById(R.id.red_count_tv);
-                if (textView != null) {
-                    textView.setVisibility(View.GONE);
+        String untreatedMemoryCount = HdlMessageLogic.getInstance().getMessageUntreatedMemoryCount();
+        TextView textView = _mActivity.findViewById(R.id.my_message_bottom_il2).findViewById(R.id.red_count_tv);
+        if (textView != null) {
+            if (TextUtils.isEmpty(untreatedMemoryCount) || untreatedMemoryCount.equals("0")) {
+                textView.setVisibility(View.GONE);
+            } else {
+                if (untreatedMemoryCount.length() > 2) {
+                    //澶т簬3浣嶆暟,榛樿99+
+                    untreatedMemoryCount = "99+";
                 }
+                textView.setVisibility(View.VISIBLE);
+                textView.setText(untreatedMemoryCount);
             }
-        });
+        }
+//
+//        HdlMessageLogic.getInstance().getMessageUntreatedCount(new CloudCallBeak<String>() {
+//            @Override
+//            public void onSuccess(String data) {
+//
+//                HdlThreadLogic.runMainThread(new Runnable() {
+//                    @Override
+//                    public void run() {
+//                        JSONObject jsonObject = JSON.parseObject(data);
+////                        if (jsonObject.containsKey("untreatedCount")) {
+////                            //鏈鐞嗘暟閲�
+////                            jsonObject.getString("untreatedCount");
+////                        }
+//                        String unreadCount = "0";
+//                        if (jsonObject.containsKey("unreadCount")) {
+//                            //鏈鏁伴噺
+//                            unreadCount = jsonObject.getString("unreadCount");
+//                        }
+//                        TextView textView = _mActivity.findViewById(R.id.my_message_bottom_il2).findViewById(R.id.red_count_tv);
+//                        if (textView != null) {
+//                            if (TextUtils.isEmpty(unreadCount) || unreadCount.equals("0")) {
+//                                textView.setVisibility(View.GONE);
+//                            } else {
+//                                if (unreadCount.length() > 2) {
+//                                    //澶т簬3浣嶆暟,榛樿99+
+//                                    unreadCount = "99+";
+//                                }
+//                                textView.setVisibility(View.VISIBLE);
+//                                textView.setText(unreadCount);
+//                            }
+//
+//
+//                        }
+//                    }
+//                });
+//
+//            }
+//
+//            @Override
+//            public void onFailure(HDLException e) {
+//                TextView textView = _mActivity.findViewById(R.id.my_message_bottom_il2).findViewById(R.id.red_count_tv);
+//                if (textView != null) {
+//                    textView.setVisibility(View.GONE);
+//                }
+//            }
+//        });
     }
 
 
@@ -320,9 +323,6 @@
      * 娌℃湁鐢电珯鍒楄〃鐨勬牱寮�
      */
     private void nullDataUpdateUi() {
-        HdlCommonLogic.getInstance().nullDataUpdateUi(_mActivity,
-                viewBinding.nullDataIc.getRoot(),
-                viewBinding.nullDataIc.nullDataGifAnimationIv,
-                viewBinding.nullDataIc.nullDataTv, getString(R.string.message_alarm_data_null), mList.size() > 0);
+        HdlCommonLogic.getInstance().nullDataUpdateUi(_mActivity, viewBinding.nullDataIc.getRoot(), viewBinding.nullDataIc.nullDataGifAnimationIv, viewBinding.nullDataIc.nullDataTv, getString(R.string.message_alarm_data_null), mList.size() > 0);
     }
 }
diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java b/app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java
index ec05cd8..2a101f7 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/message/RecoverMessageFragment.java
@@ -4,7 +4,9 @@
 import android.os.Bundle;
 import android.widget.TextView;
 
+import androidx.annotation.NonNull;
 import androidx.recyclerview.widget.LinearLayoutManager;
+import androidx.recyclerview.widget.RecyclerView;
 import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
 
 import com.google.gson.Gson;
@@ -40,6 +42,10 @@
     FragmentRecoverMessageBinding viewBinding;
 
     private MessageAdapter messageRecoverAdapter;
+    private int currentPage = 0; // 褰撳墠椤电爜
+    private int total = 0; // 鏈�鍚庨〉鐮�
+
+    private boolean isLoadingMore = false; // 鏍囪姝e湪鍔犺浇鏇村鏁版嵁
 
     private final List<MessageBean> mList = new ArrayList<>();
 
@@ -71,9 +77,10 @@
         viewBinding.messageRecoverSrl.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
             @Override
             public void onRefresh() {
-                mList.clear();//琛ㄧず寮哄埗閲嶆柊璇锋眰娑堟伅鍒楄〃
-                updateListData();//娓呯┖涔嬪墠缂撳瓨,鍥犱负閬囧埌涓�涓棶棰樼寷鎷夌殑鏃跺�欐姤閿�;
-                getRecoverMessageList(false);
+                viewBinding.messageRecoverSrl.setRefreshing(false);
+//                mList.clear();//琛ㄧず寮哄埗閲嶆柊璇锋眰娑堟伅鍒楄〃
+//                updateListData();//娓呯┖涔嬪墠缂撳瓨,鍥犱负閬囧埌涓�涓棶棰樼寷鎷夌殑鏃跺�欐姤閿�;
+//                getRecoverMessageList(false);
             }
         });
         messageRecoverAdapter.setNoOnclickListener(new MessageAdapter.OnclickListener() {
@@ -88,7 +95,30 @@
                 startActivity(intent);
             }
         });
+
+        viewBinding.messageRecoverRecyclerview.addOnScrollListener(new RecyclerView.OnScrollListener() {
+            @Override
+            public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) {
+//                super.onScrolled(recyclerView, dx, dy);
+
+                LinearLayoutManager layoutManager = (LinearLayoutManager) recyclerView.getLayoutManager();
+                if (layoutManager == null) {
+                    return;
+                }
+                int visibleItemCount = layoutManager.getChildCount();
+                int totalItemCount = layoutManager.getItemCount();
+                int firstVisibleItemPosition = layoutManager.findFirstVisibleItemPosition();
+                if (visibleItemCount > 0 && visibleItemCount + firstVisibleItemPosition == totalItemCount) {
+                    if (!isLoadingMore) {
+                        // 婊戝姩鍒颁簡搴曢儴锛屾墽琛岀浉搴旂殑鎿嶄綔
+                        HdlLogLogic.print("--->婊戝姩鍒颁簡搴曢儴");
+                        loadNextPageRecoverMessageList(++currentPage, false);
+                    }
+                }
+            }
+        });
     }
+
 
     private void initView() {
         viewBinding.messageRecoverRecyclerview.setLayoutManager(new LinearLayoutManager(_mActivity));
@@ -101,14 +131,25 @@
      * 鍒锋柊鍒楄〃鏁版嵁
      */
     private void updateListData() {
-        if (this.messageRecoverAdapter != null) {
-            this.messageRecoverAdapter.setList(mList);
-            this.messageRecoverAdapter.notifyDataSetChanged();
-        }
 
-        //鍒锋柊銆愬凡鎭㈠銆戜俊鎭暟閲忔�绘暟
-        this.refreshRecoverCount();
-        this.nullDataUpdateUi();
+        HdlThreadLogic.runMainThread(new Runnable() {
+            @Override
+            public void run() {
+                //鏇存柊缂撳瓨鏁版嵁
+                initData();
+                //鍒锋柊鍒楄〃
+                if (messageRecoverAdapter != null) {
+                    messageRecoverAdapter.setList(mList);
+                    messageRecoverAdapter.notifyDataSetChanged();
+                }
+
+                //鍒锋柊銆愬凡鎭㈠銆戜俊鎭暟閲忔�绘暟
+                refreshRecoverCount();
+                //鏄剧ず娌℃暟鎹甎i鏍峰紡
+                nullDataUpdateUi();
+            }
+        });
+
     }
 
 
@@ -122,7 +163,7 @@
         if (eventBus.getTopic().equals(ConstantManage.message_function_tab_switch)) {
             if (eventBus.getType().equals(MessageFunctionTabSwitch.recover.toString())) {
                 initData();
-                getRecoverMessageList(true);
+                loadNextPageRecoverMessageList(1, true);
                 // 鍙栨秷绮樻�т簨浠�
                 EventBus.getDefault().removeStickyEvent(eventBus);
             }
@@ -136,54 +177,53 @@
         }
     }
 
-
     /**
-     * 鑾峰彇鎭㈠涓殑娑堟伅鍒楄〃
+     * 鍔犺浇涓�椤垫暟鎹�
      *
-     * @param isShowLoading 鏄惁鍚姩 true鍚姩
+     * @param pageNo        椤垫暟
+     * @param isShowLoading 鏄惁鍚姩鍔犺浇妗� true鍚姩
      */
-    private void getRecoverMessageList(boolean isShowLoading) {
-
-        if (mList.size() == 0) {
-            if (isShowLoading) {
-                showLoading();
-            }
-            HdlMessageLogic.getInstance().getRecoverMessageList(new CloudCallBeak<List<MessageBean>>() {
-                @Override
-                public void onSuccess(List<MessageBean> list) {
-                    HdlThreadLogic.runMainThread(new Runnable() {
-                        @Override
-                        public void run() {
-                            if (isShowLoading) {
-                                hideLoading();
-                            }
-                            if (!isShowLoading) {
-                                viewBinding.messageRecoverSrl.setRefreshing(false);
-                            }
-
-                            if (list != null && list.size() != 0) {
-                                mList.addAll(list);
-                                updateListData();
-                            } else {
-                                nullDataUpdateUi();
-                            }
-                        }
-                    });
-                }
-
-                @Override
-                public void onFailure(HDLException e) {
-                    if (isShowLoading) {
-                        hideLoading();
-                    }
-                    if (!isShowLoading) {
-                        viewBinding.messageRecoverSrl.setRefreshing(false);
-                    }
-                }
-            });
+    private void loadNextPageRecoverMessageList(int pageNo, boolean isShowLoading) {
+        if (pageNo == 1 && mList.size() > 0) {
+            //缂撳瓨鏁版嵁娌℃湁鎵嶅彲浠ヨ鍙栫涓�椤�
+            return;
         }
+        if (currentPage > total) {
+            //褰撳墠椤典笉鑳藉ぇ浜庢�婚〉鏁�
+            return;
+        }
+        isLoadingMore = true;//鏍囪璇诲彇鐘舵��
+        if (isShowLoading) {
+            showLoading();
+        }
+        HdlMessageLogic.getInstance().getPageNoMessageList(pageNo, MessageStateType.processed, new CloudCallBeak<HdlMessageLogic.MessageListClass>() {
+            @Override
+            public void onSuccess(HdlMessageLogic.MessageListClass messageListClass) {
+                if (messageListClass != null) {
+                    total = (int) messageListClass.getTotalPage();
+                    currentPage = (int) messageListClass.getPageNo();
+                    updateListData();
+                }
+                isLoadingMore = false;
+                if (isShowLoading) {
+                    hideLoading();
+                }
+            }
+
+            @Override
+            public void onFailure(HDLException e) {
+                if (currentPage > 1) {
+                    --currentPage;
+                }
+                isLoadingMore = false;
+                if (isShowLoading) {
+                    hideLoading();
+                }
+            }
+        });
     }
 
+
     /**
      * 鍒锋柊銆愬凡鎭㈠銆戜俊鎭暟閲忔�绘暟
      */
diff --git a/app/src/main/res/layout/item_message.xml b/app/src/main/res/layout/item_message.xml
index c090068..da1f0a5 100644
--- a/app/src/main/res/layout/item_message.xml
+++ b/app/src/main/res/layout/item_message.xml
@@ -24,12 +24,17 @@
 
         <TextView
             android:id="@+id/item_content_tv"
-            android:layout_width="wrap_content"
+            android:layout_width="0dp"
             android:layout_height="@dimen/dp_23"
             android:layout_marginStart="20dp"
             android:layout_marginTop="16dp"
+            android:layout_marginEnd="@dimen/dp_5"
+            android:gravity="center_vertical"
             android:textColor="@color/text_90000000"
             android:textSize="@dimen/text_16"
+            android:ellipsize="end"
+            android:singleLine="true"
+            app:layout_constraintEnd_toStartOf="@+id/item_estate_tv"
             app:layout_constraintStart_toStartOf="parent"
             app:layout_constraintTop_toTopOf="parent" />
 
@@ -62,7 +67,7 @@
             android:gravity="center"
             android:paddingStart="@dimen/dp_12"
             android:paddingEnd="@dimen/dp_12"
-            android:text="@string/my_power_station_connecting"
+            android:text="@string/message_alarm"
             android:textColor="@color/text_FFFFFFFF"
             android:textSize="@dimen/text_12"
             app:layout_constraintEnd_toEndOf="parent"

--
Gitblit v1.8.0