From b9cc7390e8e8ce64c41c26fb369c98ce669d660c Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期三, 07 五月 2025 15:02:30 +0800 Subject: [PATCH] Merge branch '1.2.0' --- app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java | 173 ++++++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 152 insertions(+), 21 deletions(-) diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java b/app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java index 7ab4658..af6c830 100644 --- a/app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java +++ b/app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java @@ -5,6 +5,11 @@ import android.content.DialogInterface; import android.content.Intent; import android.os.Bundle; +import android.os.Handler; +import android.os.Looper; +import android.os.SystemClock; +import android.text.TextUtils; +import android.util.Log; import android.view.View; import androidx.recyclerview.widget.LinearLayoutManager; @@ -12,6 +17,7 @@ import com.google.gson.JsonObject; import com.hdl.linkpm.sdk.core.exception.HDLException; +import com.hdl.linkpm.sdk.user.HDLLinkPMUser; import com.hdl.photovoltaic.R; import com.hdl.photovoltaic.base.CustomBaseActivity; import com.hdl.photovoltaic.config.ConstantManage; @@ -21,6 +27,7 @@ import com.hdl.photovoltaic.internet.HttpClient; import com.hdl.photovoltaic.listener.CloudCallBeak; import com.hdl.photovoltaic.other.HdlCommonLogic; +import com.hdl.photovoltaic.other.HdlLogLogic; import com.hdl.photovoltaic.other.HdlResidenceLogic; import com.hdl.photovoltaic.other.HdlThreadLogic; import com.hdl.photovoltaic.other.HdlUniLogic; @@ -32,18 +39,23 @@ import com.hdl.photovoltaic.utils.PermissionUtils; import com.hdl.photovoltaic.widget.ConfirmationCancelDialog; import com.hdl.photovoltaic.widget.PermissionExplanationDialog; +import com.hdl.photovoltaic.widget.refreshlayout.BGARefreshLayout; +import com.hdl.photovoltaic.widget.refreshlayout.HDLRefreshViewHolder; import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus; import org.greenrobot.eventbus.Subscribe; import org.greenrobot.eventbus.ThreadMode; import java.util.ArrayList; +import java.util.Collections; import java.util.List; /** * C绔數绔欏垪琛ㄧ紪杈� */ public class PowerStationsListEdit extends CustomBaseActivity { + private Handler handler; + private Runnable delayedRunnable; private ActivityPowerStationsListBinding viewBinding;//鏄惁鍦ㄧ紪杈戠姸鎬� private HouseListAdapter houseListAdapter; @@ -67,6 +79,8 @@ initView(); //鍒濆鍖栫晫闈㈢洃鍚櫒 initEvent(); + //鍚庡彴璇诲彇浣忓畢鍒楄〃 +// downReadData(false); } private void initData() { @@ -93,16 +107,6 @@ } }); - //璁剧疆涓嬫媺绠ご棰滆壊 - viewBinding.fragmentHouseSrl.setColorSchemeResources(R.color.text_FF245EC3); - //鍒楄〃涓嬫媺鎸夐挳 - viewBinding.fragmentHouseSrl.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { - @Override - public void onRefresh() { - HdlResidenceLogic.getInstance().clearHouseList(); - downReadData(true); - } - }); if (houseListAdapter != null) { houseListAdapter.setOnItemClickListener(new HouseListAdapter.OnItemClickListener() { @Override @@ -158,6 +162,52 @@ viewBinding.fragmentHouseSrlListRc.setAdapter(houseListAdapter); houseListAdapter.setList(this.houseListBeanIDList); this.nullDataUpdateUi(houseListBeanIDList); + pullToRefresh(); + } + + /** + * 涓嬫媺鍒锋柊鐨勯�昏緫 + */ + protected void pullToRefresh() { + viewBinding.fragmentHouseSrl.setDelegate(new BGARefreshLayout.BGARefreshLayoutDelegate() { + @Override + public void onBGARefreshLayoutBeginRefreshing(BGARefreshLayout refreshLayout) { + handler = new Handler(Looper.getMainLooper()); + + delayedRunnable = new Runnable() { + @Override + public void run() { + viewBinding.fragmentHouseSrl.endRefreshing(); + downReadData(false); + } + }; + // 寤惰繜 5 绉掓墽琛� + handler.postDelayed(delayedRunnable, 1000); + } + + + @Override + public boolean onBGARefreshLayoutBeginLoadingMore(BGARefreshLayout refreshLayout) { + + handler = new Handler(Looper.getMainLooper()); + delayedRunnable = new Runnable() { + @Override + public void run() { + viewBinding.fragmentHouseSrl.endLoadingMore(); + + } + }; + // 寤惰繜 5 绉掓墽琛� + handler.postDelayed(delayedRunnable, 10); + + return true; + } + }); + HDLRefreshViewHolder hdlRefreshViewHolder = new HDLRefreshViewHolder(_mActivity, true); + hdlRefreshViewHolder.setPullDownImageResource(R.mipmap.loading_44); + hdlRefreshViewHolder.setChangeToReleaseRefreshAnimResId(R.drawable.loading_refresh); + hdlRefreshViewHolder.setRefreshingAnimResId(R.drawable.loading_refresh_end); + viewBinding.fragmentHouseSrl.setRefreshViewHolder(hdlRefreshViewHolder); } /** @@ -166,6 +216,9 @@ * @param isRefreshing 琛ㄧず鏄笅鎷夊埛鏂扮殑 */ private void downReadData(boolean isRefreshing) { + if (isRefreshing) { + showLoading(); + } //鑾峰彇浣忓畢(鐢电珯)ID鍒楄〃 HdlResidenceLogic.getInstance().getResidenceIdList("", "", new CloudCallBeak<List<HouseIdBean>>() { @Override @@ -175,18 +228,24 @@ public void run() { if (isRefreshing) { //鍏抽棴涓嬫媺鍒锋柊鐨勫湀鍦� - viewBinding.fragmentHouseSrl.setRefreshing(false); + hideLoading(); } - if (list != null && list.size() > 0) { - //鏇存柊缂撳瓨 - HdlResidenceLogic.getInstance().setHouseIdList(list); - if (houseListAdapter != null) { - initData(); - setSelectState(); - //鏇存柊UI - houseListAdapter.setList(houseListBeanIDList); - } + if (list != null && !list.isEmpty()) { + if (!comparableList(houseListBeanIDList, list)) { + //鏇存柊缂撳瓨 + HdlResidenceLogic.getInstance().setHouseIdList(list, true); + if (houseListAdapter != null) { + //閲嶆柊鑾峰彇鍒楄〃鏁版嵁 + initData(); + refreshDetails(); + //鏇存柊鐢电珯閫変腑鐘舵�� + setSelectState(); + //鏇存柊鍒楄〃鏁版嵁 + houseListAdapter.setList(houseListBeanIDList); + } + + } } nullDataUpdateUi(list); } @@ -201,7 +260,7 @@ public void run() { if (isRefreshing) { //鍏抽棴涓嬫媺鍒锋柊鐨勫湀鍦� - viewBinding.fragmentHouseSrl.setRefreshing(false); + hideLoading(); } HdlThreadLogic.toast(_mActivity, e.getMsg() + "(" + e.getCode() + ")"); @@ -333,4 +392,76 @@ } } + + /** + * 姣旇緝浣忓畢鍒楄〃鏁版嵁鏄惁閮戒竴鏍� + * + * @param oldList 鏃у垪琛� + * @param newList 鏂板垪琛� + * @return 鐩稿悓杩斿洖true锛屽惁鍒欒繑鍥瀎alse + */ + boolean comparableList(List<HouseIdBean> oldList, List<HouseIdBean> newList) { + if (oldList == null || newList == null) return false; + if (oldList.size() != newList.size()) return false; + List<String> oidStrList = new ArrayList<>(); + for (int i = 0; i < oldList.size(); i++) { + oidStrList.add(oldList.get(i).getHomeId()); + } + + List<String> newStrList = new ArrayList<>(); + for (int i = 0; i < newList.size(); i++) { + newStrList.add(newList.get(i).getHomeId()); + } + Collections.sort(oidStrList); + Collections.sort(newStrList); + return oidStrList.equals(newStrList); + } + + /** + * 閫氱煡uni鏇存柊鏁版嵁 + * 锛堝湪骞冲彴涓婂垹闄绔綋鍓嶄綇瀹呭悗,鑾峰彇鍒楄〃瀹炴敹瑕侀�氱煡uni閭h竟鏇存柊鐣岄潰鍗$墖锛� + */ + private void refreshDetails() { + try { + List<HouseIdBean> localHouseIdList = HdlResidenceLogic.getInstance().getHouseIdList(); + if (localHouseIdList.isEmpty()) { + JsonObject jsonObject = new JsonObject(); + jsonObject.addProperty("homeId", ""); + HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); + uniCallBackBaseBean.setType(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_REFRESH_DETAILS); + uniCallBackBaseBean.setData(jsonObject); + HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, uniCallBackBaseBean); + } else { + int select_home = -1; + for (int i = 0; i < localHouseIdList.size(); i++) { + if (localHouseIdList.get(i).getHomeId().equals(UserConfigManage.getInstance().getHomeId())) { + select_home = i; + break; + } + } + if (select_home == -1) { + //鎵句笉鍒伴粯璁ょ涓�涓� + HouseIdBean houseIdBean = localHouseIdList.get(0); + HdlResidenceLogic.getInstance().switchHouse(houseIdBean, true); + JsonObject jsonObject = new JsonObject(); + jsonObject.addProperty("homeId", houseIdBean.getHomeId()); + jsonObject.addProperty("homeName", houseIdBean.getHomeName()); + jsonObject.addProperty("powerStationStatus", houseIdBean.getPowerStationStatus() + ""); + HDLUniMP.UniCallBackBaseBean uniCallBackBaseBean = new HDLUniMP.UniCallBackBaseBean(); + uniCallBackBaseBean.setType(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_REFRESH_DETAILS); + uniCallBackBaseBean.setData(jsonObject); + HdlUniLogic.getInstance().sendUni(HDLUniMP.UNI_EVENT_NOTIFICATION_DEVICE_MODEL, uniCallBackBaseBean); + } + } + } catch (Exception e) { + } + } + + @Override + protected void onDestroy() { + if (handler != null && delayedRunnable != null) { + handler.removeCallbacks(delayedRunnable); + } + super.onDestroy(); + } } \ No newline at end of file -- Gitblit v1.8.0