From 081ea8d273048fd03756718ac6fb48a3c09218e9 Mon Sep 17 00:00:00 2001
From: gxc <guoxuecheng@guoxuechengdeMacBook-Pro.local>
Date: 星期二, 29 十月 2019 13:10:00 +0800
Subject: [PATCH] Merge branch 'dev-tzy' into DEV_GXC

---
 ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelFunctionSettionForm.cs |   56 +++++++++++++++++++++++++++++++++-----------------------
 1 files changed, 33 insertions(+), 23 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelFunctionSettionForm.cs b/ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelFunctionSettionForm.cs
index 422cf86..2091f65 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelFunctionSettionForm.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelFunctionSettionForm.cs
@@ -29,9 +29,9 @@
         /// </summary>
         private FrameCaptionInputControl btnDeviceName = null;
         /// <summary>
-        /// 璁惧Mac鍦板潃
+        /// 璁惧鐨勬煇涓�鍥炶矾
         /// </summary>
-        private string deviceMac = string.Empty;
+        private CommonDevice deviceObj = null;
         /// <summary>
         /// 璁惧闇�瑕佷繚瀛樼殑璁惧鍚嶅瓧
         /// </summary>
@@ -48,10 +48,10 @@
         /// <summary>
         /// 鐢婚潰鏄剧ず(搴曞眰浼氬浐瀹氳皟鐢ㄦ鏂规硶锛屽�熶互瀹屾垚鐢婚潰鍒涘缓)
         /// </summary>
-        /// <param name="i_deviceMac">璁惧Mac鍦板潃</param>
-        public void ShowForm(string i_deviceMac)
+        /// <param name="i_device">璁惧鐨勬煇涓�鍥炶矾</param>
+        public void ShowForm(CommonDevice i_device)
         {
-            this.deviceMac = i_deviceMac;
+            this.deviceObj = i_device;
 
             //璁剧疆澶撮儴淇℃伅
             base.SetTitleText(Language.StringByID(R.MyInternationalizationString.uFunctionSettingUp));
@@ -74,7 +74,7 @@
             //鍒濆鍖栨甯�
             var tableContr = new InformationEditorControl();
             this.listview = tableContr.InitControl(bodyFrameLayout, Language.StringByID(R.MyInternationalizationString.uDeviceEditor), 708, 1028);
-           
+
             //鍒濆鍖栬澶囧洖璺浘鏍�
             this.InitDeviceEpointIcon();
 
@@ -94,7 +94,7 @@
                 this.ShowProgressBar();
                 foreach (var epoint in dicDeviceSaveName.Keys)
                 {
-                    var device = Common.LocalDevice.Current.GetDevice(deviceMac, epoint);
+                    var device = Common.LocalDevice.Current.GetDevice(deviceObj.DeviceAddr, epoint);
                     if (device == null || dicDeviceSaveName[epoint] == string.Empty)
                     {
                         //涓嶈兘鍏佽绌虹櫧鍚嶅瓧
@@ -116,7 +116,7 @@
                 }
                 foreach (var epoint in dicDeviceFuncType.Keys)
                 {
-                    var device = Common.LocalDevice.Current.GetDevice(deviceMac, epoint);
+                    var device = Common.LocalDevice.Current.GetDevice(deviceObj.DeviceAddr, epoint);
                     if (device == null)
                     {
                         continue;
@@ -238,7 +238,7 @@
             {
                 menuCount = 2;
             }
-            var frame = new TopRightMenuControl(this, menuCount);
+            var frame = new TopRightMenuControl(menuCount);
             if (canTest == true)
             {
                 //瀹氫綅
@@ -354,7 +354,8 @@
         /// </summary>
         private void InitDeviceEpointIcon()
         {
-            var listDevice = Common.LocalDevice.Current.GetDevicesByMac(deviceMac);
+            bool hadDevice = false;
+            var listDevice = Common.LocalDevice.Current.GetDevicesByMac(deviceObj.DeviceAddr);
             var listSort = new List<CommonDevice>();
             foreach (var device in listDevice)
             {
@@ -363,6 +364,11 @@
                     || device.Type == DeviceType.ColorDimmableLight)
                 {
                     listSort.Add(device);
+                    if (device.DeviceEpoint == deviceObj.DeviceEpoint)
+                    {
+                        //鑳藉鍖归厤寰楀埌杩欎釜鍥炶矾
+                        hadDevice = true;
+                    }
                 }
             }
             //鎺掑簭
@@ -374,6 +380,11 @@
                 }
                 return -1;
             });
+            if (hadDevice == false)
+            {
+                //濡傛灉鍖归厤涓嶅埌杩欎釜鍥炶矾,鍒欓粯璁ょ涓�涓�
+                this.deviceObj = listSort[0];
+            }
 
             var frameBorder = new FrameLayout();
             frameBorder.Y = Application.GetRealHeight(150);
@@ -408,9 +419,8 @@
         /// </summary>
         /// <param name="frame">鎵╁ぇ鐐瑰嚮鍖哄煙鐨勫鍣�</param>
         /// <param name="device">璁惧瀵硅薄</param>
-        /// <param name="isFirst">鏄惁鏄涓�涓�</param>
         /// <returns></returns>
-        private void InitDeviceIcon(FrameLayoutControl frame, CommonDevice device, bool isFirst)
+        private void InitDeviceIcon(FrameLayoutControl frame, CommonDevice device)
         {
             //涓嶄娇鐢ㄧ偣鍑荤壒鏁�
             frame.UseClickStatu = false;
@@ -429,7 +439,7 @@
                 this.DeviceEpointSelectEvent(btnIcon, null);
             };
 
-            if (isFirst == true)
+            if (device.DeviceEpoint == deviceObj.DeviceEpoint)
             {
                 //鍒濆鍖栬彍鍗曡
                 this.DeviceEpointSelectEvent(btnIcon, null);
@@ -455,7 +465,7 @@
             frame1.Gravity = Gravity.CenterHorizontal;
             frameBack.AddChidren(frame1);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame1, listDevice[0], true);
+            this.InitDeviceIcon(frame1, listDevice[0]);
 
             //鎸夐敭2
             var frame2 = new FrameLayoutControl();
@@ -465,7 +475,7 @@
             frame2.Gravity = Gravity.CenterHorizontal;
             frameBack.AddChidren(frame2);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame2, listDevice[1], false);
+            this.InitDeviceIcon(frame2, listDevice[1]);
         }
 
         #endregion
@@ -487,7 +497,7 @@
             frame1.Gravity = Gravity.CenterHorizontal;
             frameBack.AddChidren(frame1);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame1, listDevice[0], true);
+            this.InitDeviceIcon(frame1, listDevice[0]);
 
             //鎸夐敭2
             var frame2 = new FrameLayoutControl();
@@ -497,7 +507,7 @@
             frame2.Y = Application.GetMinRealAverage(245);
             frameBack.AddChidren(frame2);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame2, listDevice[1], false);
+            this.InitDeviceIcon(frame2, listDevice[1]);
 
             //鎸夐敭3
             var frame3 = new FrameLayoutControl();
@@ -507,7 +517,7 @@
             frame3.Y = Application.GetMinRealAverage(245);
             frameBack.AddChidren(frame3);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame3, listDevice[2], false);
+            this.InitDeviceIcon(frame3, listDevice[2]);
         }
 
         #endregion
@@ -529,7 +539,7 @@
             frame1.Y = Application.GetMinRealAverage(63);
             frameBack.AddChidren(frame1);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame1, listDevice[0], true);
+            this.InitDeviceIcon(frame1, listDevice[0]);
 
             //鎸夐敭2
             var frame2 = new FrameLayoutControl();
@@ -539,7 +549,7 @@
             frame2.Y = Application.GetMinRealAverage(63);
             frameBack.AddChidren(frame2);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame2, listDevice[1], false);
+            this.InitDeviceIcon(frame2, listDevice[1]);
 
             //鎸夐敭3
             var frame3 = new FrameLayoutControl();
@@ -549,7 +559,7 @@
             frame3.Y = Application.GetMinRealAverage(245);
             frameBack.AddChidren(frame3);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame3, listDevice[2], false);
+            this.InitDeviceIcon(frame3, listDevice[2]);
 
             //鎸夐敭4
             var frame4 = new FrameLayoutControl();
@@ -559,7 +569,7 @@
             frame4.Y = Application.GetMinRealAverage(245);
             frameBack.AddChidren(frame4);
             //鍒濆鍖栬澶囧浘鏍�
-            this.InitDeviceIcon(frame4, listDevice[3], false);
+            this.InitDeviceIcon(frame4, listDevice[3]);
         }
 
         #endregion
@@ -594,7 +604,7 @@
             nowContr.TextColor = UserCenterColor.Current.TextColor1;
 
             nowSelectControl = nowContr;
-            nowSelectDevice = Common.LocalDevice.Current.GetDevice(deviceMac, Convert.ToInt32(nowContr.Name.Replace("btn", string.Empty)));
+            nowSelectDevice = Common.LocalDevice.Current.GetDevice(deviceObj.DeviceAddr, Convert.ToInt32(nowContr.Name.Replace("btn", string.Empty)));
 
             //閲嶆柊鍒濆鍖栬彍鍗曡
             this.InitMenuRow();

--
Gitblit v1.8.0