From 20119c1e9849ab28add56b977ffbca87e13e1072 Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期五, 14 二月 2025 10:47:09 +0800 Subject: [PATCH] 2025年02月14日10:46:45 --- app/src/main/java/com/hdl/photovoltaic/ui/newC/PowerStationsListEdit.java | 143 ++++++++++++++++++++++------------------------- 1 files changed, 67 insertions(+), 76 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 cff9650..b48aa9d 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 @@ -1,6 +1,9 @@ package com.hdl.photovoltaic.ui.newC; +import android.Manifest; +import android.content.DialogInterface; +import android.content.Intent; import android.os.Bundle; import android.view.View; @@ -11,6 +14,7 @@ import com.hdl.linkpm.sdk.core.exception.HDLException; import com.hdl.photovoltaic.R; import com.hdl.photovoltaic.base.CustomBaseActivity; +import com.hdl.photovoltaic.config.ConstantManage; import com.hdl.photovoltaic.config.UserConfigManage; import com.hdl.photovoltaic.databinding.ActivityPowerStationsListBinding; import com.hdl.photovoltaic.enums.ShowErrorMode; @@ -21,10 +25,13 @@ import com.hdl.photovoltaic.other.HdlThreadLogic; import com.hdl.photovoltaic.other.HdlUniLogic; import com.hdl.photovoltaic.ui.bean.HouseIdBean; -import com.hdl.photovoltaic.ui.device.FastScanActivity; +import com.hdl.photovoltaic.ui.device.ScanActivity; import com.hdl.photovoltaic.ui.newC.adapter.HouseListAdapter; import com.hdl.photovoltaic.uni.HDLUniMP; +import com.hdl.photovoltaic.utils.LocalManageUtil; +import com.hdl.photovoltaic.utils.PermissionUtils; import com.hdl.photovoltaic.widget.ConfirmationCancelDialog; +import com.hdl.photovoltaic.widget.PermissionExplanationDialog; import com.hdl.sdk.link.core.bean.eventbus.BaseEventBus; import org.greenrobot.eventbus.Subscribe; @@ -37,12 +44,11 @@ * C绔數绔欏垪琛ㄧ紪杈� */ public class PowerStationsListEdit extends CustomBaseActivity { - private ActivityPowerStationsListBinding viewBinding; + private ActivityPowerStationsListBinding viewBinding;//鏄惁鍦ㄧ紪杈戠姸鎬� private HouseListAdapter houseListAdapter; private List<HouseIdBean> houseListBeanIDList; - private boolean is_edit = false; @Override public Object getContentView() { @@ -53,8 +59,8 @@ @Override public void onBindView(Bundle savedInstanceState) { - setNotificationBarBackgroundColor(CustomColor.white); - setStatusBarTextColor(); + setStatusBarTranslucent(); + getWindow().setNavigationBarColor(getColor(R.color.text_FF000000)); //鍒濆鍖栨暟鎹� initData(); //鍒濆鍖� @@ -66,37 +72,24 @@ private void initData() { this.houseListBeanIDList = new ArrayList<>(); this.houseListBeanIDList.addAll(HdlResidenceLogic.getInstance().getHouseIdList()); - setAllItemEdit(false); + setSelectState(); } private void initEvent() { //杩斿洖鎸夐挳 - viewBinding.toolbarTopFragmentHouseListRl.topBackLl.setOnClickListener(new View.OnClickListener() { + viewBinding.toolbarTopRl.topBackLl.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { - if (!is_edit) { - finish(); - return; - } - is_edit = false; - viewBinding.toolbarTopFragmentHouseListRl.topMoreBtn.setVisibility(View.VISIBLE); - initData();//鍒濆鍖栫紦瀛樻暟鎹� - setAllItemEdit(false); - houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃 + finish(); } }); //缂栬緫鎸夐挳 - viewBinding.toolbarTopFragmentHouseListRl.topMoreBtn.setOnClickListener(new View.OnClickListener() { + viewBinding.toolbarTopRl.topMoreBtn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { - if (is_edit) { - return; - } - is_edit = true; - viewBinding.toolbarTopFragmentHouseListRl.topMoreBtn.setVisibility(View.GONE); - initData();//鍒濆鍖栫紦瀛樻暟鎹� - setAllItemEdit(true); - houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃 + Intent intent = new Intent(); + intent.setClass(_mActivity, PowerStationsMoveActivity.class); + startActivity(intent); } }); @@ -110,37 +103,6 @@ } }); if (houseListAdapter != null) { - //鐢电珯绉诲姩浣嶇疆鎸夐挳 - houseListAdapter.setMoveOnclickListener(new HouseListAdapter.OnMoveClickListener() { - @Override - public void onMoveClick(int position, HouseIdBean houseIdBean) { - if (position == 0) { - HdlThreadLogic.toast(_mActivity, getString(R.string.already_the_first_one)); - return; - } - String frontHomeId = ""; - if (position > 1) { - frontHomeId = houseListBeanIDList.get(position - 2).getHomeId(); - } - HdlResidenceLogic.getInstance().moveResidence(houseIdBean.getHomeId(), frontHomeId, new CloudCallBeak<Boolean>() { - @Override - public void onSuccess(Boolean obj) { - //绉诲姩鐢电珯浣嶇疆 - HdlResidenceLogic.getInstance().moveHouseId(houseIdBean.getHomeId()); - initData();//鍒濆鍖栫紦瀛樻暟鎹� - setAllItemEdit(is_edit); - houseListAdapter.setList(houseListBeanIDList);//閲嶆柊鍒锋柊鍒楄〃 - nullDataUpdateUi(houseListBeanIDList);//妫�娴嬫暟鎹槸鍚︿负绌� - } - - @Override - public void onFailure(HDLException e) { - HdlThreadLogic.toast(_mActivity, e); - } - }); - - } - }); houseListAdapter.setOnItemClickListener(new HouseListAdapter.OnItemClickListener() { @Override public void onItemClick(int position, HouseIdBean houseBean) { @@ -157,15 +119,27 @@ houseSelectionDialog(houseBean); } }); - } viewBinding.addPowerStationTv.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { -// String path = HDLUniMP.UNI_EVENT_OPEN_DEVICESCAN + "?scanType=addPowerStation"; -// HdlUniLogic.getInstance().openUniMP(path, null); - startActivity(FastScanActivity.class); + + // 鏈巿鏉� 濡傛灉搴旂敤绋嬪簭娌℃湁鎵�闇�鐨勬潈闄愶紝鍒欐樉绀鸿В閲婅鏄� + PermissionExplanationDialog.getInstance().showPortConflictPdDialog(_mActivity, getString(R.string.camera_storage_instructions), getString(R.string.camera_storage_purpose)); + PermissionUtils.requestPermissionsResultCallback(_mActivity, Manifest.permission.CAMERA, new PermissionUtils.PermissionState() { + @Override + public void Success(int value) { + PermissionExplanationDialog.getInstance().dismiss(); + if (value == PermissionUtils.STATUS_REFUSE_PERMANENT | value == PermissionUtils.STATUS_REFUSE) { +// HdlThreadLogic.toast(_mActivity, R.string.permission_open); + return; + } + + + startActivity(ScanActivity.class); + } + }, true); } }); @@ -173,12 +147,10 @@ } private void initView() { - viewBinding.toolbarTopFragmentHouseListRl.getRoot().setBackgroundColor(getColor(R.color.text_FFFFFFFF)); - viewBinding.toolbarTopFragmentHouseListRl.topBackLl.setVisibility(View.VISIBLE); - viewBinding.toolbarTopFragmentHouseListRl.topLeftIv.setImageResource(R.drawable.back_c); - viewBinding.toolbarTopFragmentHouseListRl.topTitleTv.setText(R.string.power_station_selection); - viewBinding.toolbarTopFragmentHouseListRl.topMoreBtn.setVisibility(View.VISIBLE); - viewBinding.toolbarTopFragmentHouseListRl.topMoreIv.setImageResource(R.drawable.editor_house); + viewBinding.toolbarTopRl.topBackLl.setVisibility(View.VISIBLE); + viewBinding.toolbarTopRl.topTitleTv.setText(R.string.power_station_selection); + viewBinding.toolbarTopRl.topMoreBtn.setVisibility(View.VISIBLE); + viewBinding.toolbarTopRl.topMoreIv.setImageResource(R.drawable.editor_house); LinearLayoutManager linearLayout = new LinearLayoutManager(_mActivity); houseListAdapter = new HouseListAdapter(_mActivity); viewBinding.fragmentHouseSrlListRc.setLayoutManager(linearLayout); @@ -209,7 +181,7 @@ HdlResidenceLogic.getInstance().setHouseIdList(list); if (houseListAdapter != null) { initData(); - setAllItemEdit(is_edit); + setSelectState(); //鏇存柊UI houseListAdapter.setList(houseListBeanIDList); } @@ -238,16 +210,12 @@ } /** - * 璁剧疆鍏ㄩ儴缂撳瓨鏁版嵁缂栬緫鐘舵�� - * - * @param edit true琛ㄧず鍦ㄧ紪杈戠姸鎬� + * 璁剧疆褰撳墠鐢电珯閫変腑鐘舵�� */ - private void setAllItemEdit(boolean edit) { + private void setSelectState() { for (int i = 0; i < houseListBeanIDList.size(); i++) { - houseListBeanIDList.get(i).setMove(edit); - houseListBeanIDList.get(i).setDelIcon(false); if (UserConfigManage.getInstance().getHomeId().equals(houseListBeanIDList.get(i).getHomeId())) { - this.houseListBeanIDList.get(i).setState_select(!edit); + this.houseListBeanIDList.get(i).setState_select(true); } } } @@ -270,10 +238,11 @@ dialog.setTitle(getString(R.string.loading_title_tip)); dialog.setContent(getString(R.string.switch_power_station).replace("%s", "\"" + houseIdBean.getHomeName() + "\"")); dialog.show(); + dialog.isHideTitle(true); dialog.setYesOnclickListener(new ConfirmationCancelDialog.onYesOnclickListener() { @Override public void Confirm() { - HdlResidenceLogic.getInstance().switchHouse(houseIdBean); + HdlResidenceLogic.getInstance().switchHouse(houseIdBean, true); dialog.dismiss(); JsonObject jsonObject = new JsonObject(); jsonObject.addProperty("homeId", houseIdBean.getHomeId()); @@ -308,6 +277,21 @@ dialog.dismiss(); } }); + + dialog.setOnDismissListener(new DialogInterface.OnDismissListener() { + @Override + public void onDismiss(DialogInterface dialog) { + //鍙栨秷涔嬪悗杩樺師涔嬪墠鐘舵�� + for (int i = 0; i < houseListBeanIDList.size(); i++) { + HouseIdBean houseIdBean = houseListBeanIDList.get(i); + houseIdBean.setState_select(false); + if (UserConfigManage.getInstance().getHomeId().equals(houseIdBean.getHomeId())) { + houseIdBean.setState_select(true); + } + } + houseListAdapter.notifyDataSetChanged(); + } + }); } @@ -331,11 +315,18 @@ @Override public void onFailure(HDLException e) { - + HdlThreadLogic.toast(_mActivity, e); } }); } + } else if (ConstantManage.REFRESH_HOME_LIST.equals(eventBus.getTopic())) { + if (houseListAdapter != null) { + initData(); + setSelectState(); + //鏇存柊UI + houseListAdapter.setList(houseListBeanIDList); + } } } -- Gitblit v1.8.0