From 3aa86eda8f416bec308d065689d39c847d2d9cc7 Mon Sep 17 00:00:00 2001 From: mac <user@users-MacBook-Pro.local> Date: 星期二, 30 一月 2024 19:48:26 +0800 Subject: [PATCH] 2024年01月30日19:44:13 --- app/src/main/java/com/hdl/photovoltaic/ui/message/NascentMessageFragment.java | 227 ++++++++++++++++++++++++++++---------------------------- 1 files changed, 114 insertions(+), 113 deletions(-) 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 10c2b79..3c464aa 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 @@ -1,10 +1,12 @@ package com.hdl.photovoltaic.ui.message; +import android.annotation.SuppressLint; import android.content.Intent; 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 +41,7 @@ import org.greenrobot.eventbus.ThreadMode; import java.util.ArrayList; +import java.util.Date; import java.util.List; /** @@ -50,10 +53,10 @@ 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 +88,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,24 +111,21 @@ 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()) { + if (layoutManager == null) { return; } - + int visibleItemCount = layoutManager.getChildCount(); int totalItemCount = layoutManager.getItemCount(); - int lastVisibleItemPosition = layoutManager.findLastVisibleItemPosition(); - - if (!isLoadingMore && totalItemCount <= (lastVisibleItemPosition + visibleThreshold)) { -// loadNextPage(); + int firstVisibleItemPosition = layoutManager.findFirstVisibleItemPosition(); + if (visibleItemCount > 0 && visibleItemCount + firstVisibleItemPosition == totalItemCount) { + if (!isLoadingMore) { + // 婊戝姩鍒颁簡搴曢儴锛屾墽琛岀浉搴旂殑鎿嶄綔 + HdlLogLogic.print("--->婊戝姩鍒颁簡搴曢儴"); + loadNextPageNascentMessageList(++currentPage, false); + } } } }); @@ -141,30 +142,63 @@ * 鍒锋柊鍒楄〃鏁版嵁 */ 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(); + } + //鏄剧ず鏈淇℃伅鎬绘暟閲� + getUnreadCount(); + //鏄剧ず娌℃暟鎹甎i鏍峰紡 + nullDataUpdateUi(); - + } + }); } /** * 鍒锋柊銆愬彂鐢熶腑銆戜俊鎭暟閲忔�绘暟 */ - private void refreshNascentCount() { + private void refreshNascentCount(String totalCount) { HdlThreadLogic.runMainThread(new Runnable() { @Override public void run() { TextView textView = _mActivity.findViewById(R.id.message_tab_nascent_title_tv); if (textView != null) { textView.setText(getText(R.string.message_nascent)); - if (mList.size() > 0) { - String s = getText(R.string.message_nascent) + "(" + mList.size() + ")"; + if (!TextUtils.isEmpty(totalCount) && !totalCount.equals("0")) { + String s = getText(R.string.message_nascent) + "(" + totalCount + ")"; textView.setText(s); + } + } + } + }); + } + + /** + * 鍒锋柊瑙掓爣銆愭湭璇汇�戜俊鎭暟閲忔�绘暟 + */ + private void refreshUnreadNascentCount(String unreadCount) { + HdlThreadLogic.runMainThread(new Runnable() { + @SuppressLint("SetTextI18n") + @Override + public void run() { + 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 { + textView.setVisibility(View.VISIBLE); + if (unreadCount.length() > 2) { + textView.setText("99+"); + } else { + textView.setText(unreadCount); + } } } } @@ -181,8 +215,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,74 +227,56 @@ //娑堟伅璇︽儏鍥炶皟 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(); - } - } - }); - - } - - @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(); + } + } + }); + } /** * 璇诲彇娑堟伅銆愭湭璇绘暟閲忋�� @@ -274,27 +290,15 @@ @Override public void run() { JSONObject jsonObject = JSON.parseObject(data); -// if (jsonObject.containsKey("untreatedCount")) { -// //鏈鐞嗘暟閲� -// jsonObject.getString("untreatedCount"); -// } - String unreadCount = "0"; + if (jsonObject.containsKey("untreatedCount")) { + //鏈鐞嗘暟閲� + String untreatedCount = jsonObject.getString("untreatedCount"); + refreshNascentCount(untreatedCount); + } 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); - } + String unreadCount = jsonObject.getString("unreadCount"); + refreshUnreadNascentCount(unreadCount); } } }); @@ -316,9 +320,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); } } -- Gitblit v1.8.0