From 3d94f1da938ec81c6e666a1d6e09088769e0e538 Mon Sep 17 00:00:00 2001
From: wjc <1243177876@qq.com>
Date: 星期二, 27 六月 2023 13:48:04 +0800
Subject: [PATCH] 2023年06月27日13:47:26

---
 app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java |  108 ++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 92 insertions(+), 16 deletions(-)

diff --git a/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java b/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java
index 55b887a..ede359c 100644
--- a/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java
+++ b/app/src/main/java/com/hdl/photovoltaic/ui/powerstation/HouseListFragment.java
@@ -1,22 +1,27 @@
 package com.hdl.photovoltaic.ui.powerstation;
 
+import android.Manifest;
 import android.content.Context;
-import android.content.Intent;
+import android.content.pm.PackageManager;
 import android.hardware.camera2.CameraManager;
 import android.os.Bundle;
 import android.util.Log;
 import android.view.View;
 
+import androidx.annotation.NonNull;
 import androidx.recyclerview.widget.LinearLayoutManager;
 import androidx.swiperefreshlayout.widget.SwipeRefreshLayout;
 
 import com.hdl.photovoltaic.R;
 import com.hdl.photovoltaic.databinding.FragmentHouseListBinding;
 import com.hdl.photovoltaic.base.CustomBaseFragment;
+import com.hdl.photovoltaic.other.HdlLogLogic;
+import com.hdl.photovoltaic.other.HdlResidenceLogic;
+import com.hdl.photovoltaic.other.HdlUniLogic;
 import com.hdl.photovoltaic.ui.adapter.HouseInfoAdapter;
-import com.hdl.photovoltaic.ui.bean.HouseInfoBean;
-import com.hdl.photovoltaic.ui.device.FastScanActivity;
-import com.hdl.photovoltaic.utils.FlashLightUtils;
+import com.hdl.photovoltaic.ui.bean.HouseIdBean;
+import com.hdl.photovoltaic.uni.HDLUniMP;
+import com.hdl.photovoltaic.utils.PermissionUtils;
 
 import java.util.ArrayList;
 import java.util.List;
@@ -26,7 +31,8 @@
     private HouseInfoAdapter houseInfoAdapter;
     private CameraManager manager;
 
-    private List<HouseInfoBean> houseInfoBeanList = null;
+    private List<HouseIdBean> houseListBeanIDList = null;
+
 
     @Override
     public Object getContentView() {
@@ -47,14 +53,26 @@
 
     }
 
-
     private void initEvent() {
+
         viewBinding.toolbarTopFragmentHouseListRl.topMoreIv.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
-                Intent intent = new Intent();
-                intent.setClass(_mActivity, FastScanActivity.class);
-                startActivity(intent);
+
+                // 鎵撳紑灏忕▼搴忛〉闈�
+//                HdlUniLogic.getInstance().openUniMP(HDLUniMP.UNI_EVENT_OPEN_HOME_CREATION, null);
+                requestPermissions(new PermissionsResultCallback() {
+                    @Override
+                    public void succeed() {
+                        // 鎵撳紑灏忕▼搴忛〉闈�
+                        HdlUniLogic.getInstance().openUniMP(HDLUniMP.UNI_EVENT_OPEN_HOME_CREATION, null);
+                    }
+
+                    @Override
+                    public void failing() {
+                    }
+                });
+
             }
         });
         //璁剧疆涓嬫媺绠ご棰滆壊
@@ -67,6 +85,19 @@
                 Log.d("HouseListFragment", "涓嬫媺鍒锋柊");
             }
         });
+        houseInfoAdapter.setNoOnclickListener(new HouseInfoAdapter.OnclickListener() {
+            @Override
+            public void onClick(int position) {
+                //鐐瑰嚮浣忓畢璇︽儏
+                HdlLogLogic.print("====鐐瑰嚮浣忓畢璇︽儏" + position);
+                if (houseListBeanIDList == null || houseListBeanIDList.size() <= 0) {
+                    return;
+                }
+                HouseIdBean houseIdBean = houseListBeanIDList.get(position);
+                String path = HDLUniMP.UNI_EVENT_OPEN_HOME_DETAILS + "?homeId=" + houseIdBean.getHomeId();
+                HdlUniLogic.getInstance().openUniMP(path, null);
+            }
+        });
     }
 
     private void initView() {
@@ -74,7 +105,7 @@
         viewBinding.toolbarTopFragmentHouseListRl.topMoreIv.setVisibility(View.VISIBLE);
         viewBinding.toolbarTopFragmentHouseListRl.topMoreIv.setImageResource(R.drawable.add);
         LinearLayoutManager linearLayout = new LinearLayoutManager(_mActivity);
-        houseInfoAdapter = new HouseInfoAdapter(this.houseInfoBeanList);
+        houseInfoAdapter = new HouseInfoAdapter(this.houseListBeanIDList);
         viewBinding.fragmentHouseSrlListRc.setLayoutManager(linearLayout);
         viewBinding.fragmentHouseSrlListRc.setAdapter(houseInfoAdapter);
 
@@ -82,15 +113,60 @@
     }
 
     private void initData() {
-        this.houseInfoBeanList = new ArrayList<>();
-        for (int i = 0; i < 11; i++) {
-            HouseInfoBean houseInfoBean = new HouseInfoBean();
-            houseInfoBean.setName("鐢电珯" + i);
-            this.houseInfoBeanList.add(houseInfoBean);
-        }
+        this.houseListBeanIDList = new ArrayList<>();
+//        for (int i = 0; i < 11; i++) {
+//            HouseListBean houseListBean = new HouseListBean();
+//            houseListBean.setHomeName("鐢电珯" + i);
+//            this.houseListBeanList.add(houseListBean);
+//        }
+        this.houseListBeanIDList.addAll(HdlResidenceLogic.getInstance().getHouseInfoBeanList());
 
 
     }
 
+    /**
+     * 鐢宠鏉冮檺
+     */
+    private void requestPermissions(PermissionsResultCallback permissionsResultCallback) {
+        mPermissionsResultCallback = permissionsResultCallback;
+        //Manifest.permission.CAMERA,
+        String[] s = new String[]{
+                Manifest.permission.ACCESS_FINE_LOCATION
+        };
+        String[] ary = PermissionUtils.checkPermission(_mActivity, s);
+        if (ary.length > 0) {
+            requestPermissions(ary, PermissionUtils.STATUS_SUCCESS);
+        } else {
+            if (mPermissionsResultCallback != null) {
+                mPermissionsResultCallback.succeed();
+            }
+        }
+    }
+
+    @Override
+    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
+        super.onRequestPermissionsResult(requestCode, permissions, grantResults);
+        if (requestCode == PermissionUtils.STATUS_SUCCESS) {
+            for (int i = 0; i < permissions.length; i++) {
+                if (grantResults[i] == PackageManager.PERMISSION_GRANTED) {
+                    if (mPermissionsResultCallback != null) {
+                        mPermissionsResultCallback.succeed();
+                    }
+                }
+
+            }
+        }
+
+    }
+
+    private PermissionsResultCallback mPermissionsResultCallback;
+
+    public interface PermissionsResultCallback {
+
+        void succeed();
+
+        void failing();
+
+    }
 
 }

--
Gitblit v1.8.0