From dc0309e64f02227d8e1468b7326c07955f804612 Mon Sep 17 00:00:00 2001
From: chenqiyang <1406175257@qq.com>
Date: 星期三, 22 六月 2022 11:22:18 +0800
Subject: [PATCH] 修改引用路径

---
 ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelSimpleMutilfunctionAddTargetsForm.cs |  402 +++++++++++++++++++-------------------------------------
 1 files changed, 138 insertions(+), 264 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelSimpleMutilfunctionAddTargetsForm.cs b/ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelSimpleMutilfunctionAddTargetsForm.cs
index 9ae205e..6de5343 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelSimpleMutilfunctionAddTargetsForm.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Device/Panel/PanelSimpleMutilfunctionAddTargetsForm.cs
@@ -14,17 +14,10 @@
         /// </summary>
         /// <param name="device"></param>
         /// <param name="deviceBindType">0:鍦烘櫙  1:寮�鍏�  2:鎻掑骇  3:鐏厜  4:閬槼 5:绌鸿皟 6:鏂伴</param>
-        public PanelSimpleMutilfunctionAddTargetsForm(string deviceMac, int deviceBindType)
+        public PanelSimpleMutilfunctionAddTargetsForm(Panel controlDev, int deviceBindType)
         {
-            curControlDev = new Panel();
-            var dev = Common.LocalDevice.Current.GetDevice(deviceMac, 62);//绠�绾﹂潰鏉块殢渚夸竴涓洖璺潵鑾峰彇璁惧
-            if (dev != null)
-            {
-                curControlDev.CurrentGateWayId = dev.CurrentGateWayId;
-            }
-            curControlDev.Type = DeviceType.OnOffSwitch;
-            curControlDev.DeviceAddr = deviceMac;
-            curBindType = deviceBindType;
+            this.curControlDev = controlDev;
+            this.curBindType = deviceBindType;
         }
         #endregion
 
@@ -129,6 +122,10 @@
         /// 聽鍒锋柊缁戝畾琛ㄩ〉闈⒙犅�
         /// </summary>
         public Action actionRefreshBindList;
+        /// <summary>
+        /// 鏄惁鑳藉埛鏂�
+        /// </summary>
+        private bool canFresh = false;
         #endregion
 
         #region UI璁捐
@@ -139,7 +136,14 @@
         {
             TitleUI();
             MidFrameLayouUI();
+            //棣栨鍒濆鍖栨暟鎹�
+            CommonPage.Loading.Start("");
             InitData();
+
+            //澶囨敞寮圭獥鎻愮ず
+            string msg = Language.StringByID(R.MyInternationalizationString.BindRemarkTip1).Replace("{0}", "\r\n");
+            var alert = new Shared.Phone.UserCenter.ShowMsgControl(ShowMsgType.Confirm, msg, Language.StringByID(R.MyInternationalizationString.Iknown));
+            alert.Show();
         }
 
         /// <summary>
@@ -211,6 +215,7 @@
             midVerticalScrolViewLayout.BeginHeaderRefreshingAction += () =>
             {
                 midVerticalScrolViewLayout.BeginHeaderRefreshing();
+                canFresh = true;
                 InitData();
             };
 
@@ -235,8 +240,8 @@
 
             btnFinifh = new Button()
             {
-                Width = Application.GetRealWidth(907),
-                Height = Application.GetRealHeight(127),
+                Width = Application.GetRealWidth(907),
+                Height = Application.GetRealHeight(127),
                 Y = Application.GetRealHeight(49 + 35),
                 Gravity = Gravity.CenterHorizontal,
                 Radius = (uint)Application.GetRealHeight(127) / 2,
@@ -255,169 +260,28 @@
         }
 
         /// <summary>
-        /// 妤煎眰閫夋嫨鐨勪晶杈规爮
-        /// </summary>
-        void SideslipFramelayout()
-        {
-            var dialog = new Dialog
-            {
-            };
-            dialog.Show();
-
-            var flMain = new FrameLayout { BackgroundColor = 0x00000000 };
-            dialog.AddChidren(flMain);
-            flMain.MouseUpEventHandler += (sender11, e11) =>
-            {
-                dialog.Close();
-            };
-
-            var sidelipFrameLayout = new FrameLayout()
-            {
-                Width = Application.GetMinReal(449),
-                Y = Application.GetRealHeight(161),
-                X = Application.GetRealWidth(596),
-                BackgroundImagePath = "DoorLock/SideslipPic.png",
-            };
-            flMain.AddChidren(sidelipFrameLayout);
-
-            var btnSelectFloor = new Button()
-            {
-                Width = Application.GetRealWidth(200),
-                Height = Application.GetRealHeight(58),
-                X = Application.GetRealWidth(81),
-                Y = Application.GetRealHeight(81),
-                TextColor = Shared.Common.ZigbeeColor.Current.XMBlack,
-                TextSize = 14,
-                IsBold = true,
-                TextAlignment = TextAlignment.CenterLeft,
-                TextID = R.MyInternationalizationString.SelectFloor,
-            };
-            sidelipFrameLayout.AddChidren(btnSelectFloor);
-
-            var sidelipVerticalScrolViewLayout = new VerticalScrolViewLayout()
-            {
-                Y = btnSelectFloor.Bottom + Application.GetRealHeight(45),
-                Height = Application.GetRealHeight(600),
-            };
-            sidelipFrameLayout.AddChidren(sidelipVerticalScrolViewLayout);
-
-            Button oldbutton = null;
-            Button oldbuttonText = null;
-            int count = 0;
-            foreach (var floorId in dicFloorList.Keys)
-            {
-                var rowFrameLayout = new RowLayout()
-                {
-                    Height = Application.GetRealHeight(152),
-                    LineColor = Shared.Common.ZigbeeColor.Current.XMRowLine,
-                    X = Application.GetRealWidth(81),
-                };
-                sidelipVerticalScrolViewLayout.AddChidren(rowFrameLayout);
-
-                var btnAllMethod = new Button()
-                {
-                    Width = Application.GetMinReal(81),
-                    Height = Application.GetMinReal(81),
-                    UnSelectedImagePath = "Floor/Floor.png",
-                    SelectedImagePath = "Floor/FloorSelected.png",
-                    Gravity = Gravity.CenterVertical,
-                };
-                rowFrameLayout.AddChidren(btnAllMethod);
-
-                var btnMethodText = new Button()
-                {
-                    Width = Application.GetRealWidth(311),
-                    Height = Application.GetRealHeight(58),
-                    X = Application.GetRealWidth(92),
-                    Gravity = Gravity.CenterVertical,
-                    TextColor = Shared.Common.ZigbeeColor.Current.XMGray3,
-                    TextSize = 14,
-                    TextAlignment = TextAlignment.CenterLeft,
-                    Text = dicFloorList[floorId],
-                };
-                rowFrameLayout.AddChidren(btnMethodText);
-
-                if (curControlDev.currentSelectFloorId == floorId)
-                {
-                    btnAllMethod.IsSelected = true;
-                    btnAllMethod.IsBold = true;
-                    btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
-                }
-
-                string curFloorId = floorId;
-                EventHandler<MouseEventArgs> hander = (sender, e) =>
-                {
-                    if (curControlDev.currentSelectFloorId == curFloorId)
-                    {
-                        return;
-                    }
-                    curControlDev.currentSelectFloorId = curFloorId;
-
-
-
-                    if (!btnMethodText.IsSelected)
-                    {
-                        if (oldbutton != null)
-                        {
-                            oldbutton.IsSelected = false;
-                        }
-                        if (oldbuttonText != null)
-                        {
-                            oldbuttonText.TextColor = Shared.Common.ZigbeeColor.Current.XMGray3;
-                        }
-                        oldbutton = btnMethodText;
-                        oldbuttonText = btnMethodText;
-                        btnMethodText.IsSelected = true;
-                        oldbuttonText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
-                        oldbuttonText.IsBold = true;
-                    }
-
-                    int index = 0;
-                    RefreshRoomList();
-                    dialog.Close();
-                };
-                btnAllMethod.MouseUpEventHandler += hander;
-                rowFrameLayout.MouseUpEventHandler += hander;
-                btnMethodText.MouseUpEventHandler += hander;
-                count++;
-            }
-
-            if (count == 0)
-            {
-                sidelipFrameLayout.Height = 0;
-            }
-            else if (count <= 4 && count > 0)
-            {
-                sidelipFrameLayout.Height = Application.GetRealHeight(180) + count * Application.GetRealHeight(150);
-            }
-            else
-            {
-                sidelipFrameLayout.Height = Application.GetMinReal(780);
-            }
-        }
-
-        /// <summary>
         /// 闈㈡澘缁戝畾鐩爣琛ㄦ樉绀�
         /// </summary>
         /// <param name="gateway">Gateway.</param>
         /// <param name="key">Key.</param>
         void RefreshRoomList()
         {
-            Room curRoom = null;
-            if (supportRoomList.Count == 0)
-            {
-                return;
-            }
             btnHorizontalScrolViewLayout.RemoveAll();
+            Room curRoom = null;
             Button curentOldRoom = null;
             FrameLayout curentOldRoomFrameLayout = null;
             int index = 0;
-            curBindTypeList = MutilfunctionPanelMethod.GetMatchBindList(curBindType);
-            var roomTempList = MutilfunctionPanelMethod.GetSupportRoomList(curControlDev, supportRoomList, curBindTypeList, curBindType);
+            List<Room> roomTempList = new List<Room> { };
             Room slectedRoom = null;
             var roomUn = new Room();
             roomUn.Name = Language.StringByID(R.MyInternationalizationString.Undistributed);
             roomUn.Id = "UndistributedId";
+
+            if (supportRoomList.Count != 0)
+            {
+                roomTempList = MutilfunctionPanelMethod.GetSupportRoomList(curControlDev, supportRoomList, curBindTypeList, curBindType);
+            }
+
             if (curBindType == 0)
             {
                 if (undistributeScList != null && undistributeScList.Count != 0)
@@ -488,7 +352,7 @@
                     }
                 }
 
-                if (index == roomTempList.Count - 1 && index > 3)
+                if (index == roomTempList.Count - 1 && index > 2)
                 {
                     var btnRoomFrameLayoutEmpty = new FrameLayout
                     {
@@ -560,6 +424,8 @@
                     var btn = (Button)frame.GetChildren(0);
                     frame.BackgroundImagePath = "Item/RoomIconBackgroundSelected.png";
                     btn.TextColor = Shared.Common.ZigbeeColor.Current.XMWhite;
+                    curentOldRoom = btn;
+                    curentOldRoomFrameLayout = frame;
                 }
                 else
                 {
@@ -673,13 +539,13 @@
                 {
                     line2.Visible = false;
                 }
-                if (Common.LocalDevice.Current.CheckDeviceIsOnline(device) == true)
-                {
-                    btnBindName.TextColor = Shared.Common.ZigbeeColor.Current.TextBlack;
-                }
-                else
-                {
-                    btnBindName.TextColor = Shared.Common.ZigbeeColor.Current.XMGray3;
+                if (Common.LocalDevice.Current.CheckDeviceIsOnline(device) == true)
+                {
+                    btnBindName.TextColor = Shared.Common.ZigbeeColor.Current.TextBlack;
+                }
+                else
+                {
+                    btnBindName.TextColor = Shared.Common.ZigbeeColor.Current.XMGray3;
                 }
                 switch (curBindType)
                 {
@@ -739,6 +605,13 @@
 
                 EventHandler<MouseEventArgs> hander = (sender, e) =>
                 {
+                    //鐩爣澶囨敞澶勭悊
+                    var localName = System.Text.Encoding.UTF8.GetBytes(Common.LocalDevice.Current.GetDeviceEpointName(device));
+                    if (localName.Length > 20)
+                    {
+                        new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.BindRemarkTip2), Direction = AMPopTipDirection.None, CloseTime = 1 }.Show(Common.CommonPage.Instance);
+                        return;
+                    }
                     btnChoose.IsSelected = !btnChoose.IsSelected;
                     if (curBindType != 6)
                     {
@@ -970,13 +843,26 @@
 
                 EventHandler<MouseEventArgs> hander = (sender, e) =>
                 {
-                    if (curSupportBindEpointList.Count == 0 || curSupportBindEpointList.Count == targetScList.Count)
+
+                    //鐩爣澶囨敞澶勭悊
+                    if (!string.IsNullOrEmpty(scene.Name))
+                    {
+                        var localName = System.Text.Encoding.UTF8.GetBytes(scene.Name);
+                        if (localName.Length > 20)
+                        {
+                            new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.BindRemarkTip2), Direction = AMPopTipDirection.None, CloseTime = 1 }.Show(Common.CommonPage.Instance);
+                            return;
+                        }
+                    }
+
+                    btnChoose.IsSelected = !btnChoose.IsSelected;
+
+                    if (curSupportBindEpointList.Count == 0)
                     {
                         new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.BindFull), Direction = AMPopTipDirection.None, CloseTime = 1 }.Show(Common.CommonPage.Instance);
                         return;
                     }
 
-                    btnChoose.IsSelected = !btnChoose.IsSelected;
                     if (!btnChoose.IsSelected)
                     {
                         targetScList.Remove(scene);
@@ -1027,17 +913,15 @@
             {
                 try
                 {
-                    Application.RunOnMainThread(() =>
-                    {
-                        CommonPage.Loading.Start("");
-                    });
-
                     //鑾峰彇妤煎眰
                     dicFloorList = HdlRoomLogic.Current.GetFloorSortList();
                     curControlDev.currentSelectFloorId = BindInfo.GetCurrentSelectFloorId();
 
-                    //鑾峰彇妤煎眰涓埧闂村垪琛�
-                    supportRoomList = BindInfo.GetFloorRoomList();
+                    //鑾峰彇鎴块棿鍒楄〃
+                    supportRoomList = BindInfo.GetSupportRoomList();
+
+                    //鑾峰彇闈㈡澘宸茬粡缁戝畾鐨勫尮閰嶇被鍨嬬殑鍒楄〃
+                    curBindTypeList = MutilfunctionPanelMethod.GetMatchBindList(curControlDev, curBindType);
 
                     if (curBindType == 0)
                     {
@@ -1053,7 +937,7 @@
                         undistributeDevList = MutilfunctionPanelMethod.GetUndistributeDeviceList(undistributeDevList, curBindTypeList, curBindType);
                     }
                     //鑾峰彇褰撳墠鏀寔鐨勭鐐圭粦瀹氳〃
-                    curSupportBindEpointList = MutilfunctionPanelMethod.GetMatchEpointList(curBindType);
+                    curSupportBindEpointList = MutilfunctionPanelMethod.GetMatchEpointList(curControlDev, curBindType);
                     if (curBindType == 3)
                     {
                         foreach (var ep in curSupportBindEpointList)
@@ -1077,14 +961,17 @@
                 {
                     Application.RunOnMainThread(() =>
                     {
-                        BindDownFrameLayout(this.midFrameLayout, curControlDev, dicFloorList, ref btnFloorText);
+                        if (!canFresh)
+                        {
+                            BindDownFrameLayout(this.midFrameLayout, curControlDev, dicFloorList, ref btnFloorText);
+                        }
                         ChooseFloorAction += (floorId, btnMethodText) =>
                         {
                             btnFloorText.Text = dicFloorList[floorId];
 
-                            //鑾峰彇妤煎眰涓埧闂村垪琛�
+                            //鑾峰彇鎴块棿鍒楄〃
                             supportRoomList.Clear();
-                            supportRoomList = BindInfo.GetFloorRoomList();
+                            supportRoomList = BindInfo.GetSupportRoomList();
                             if (curBindType == 0)
                             {
                                 // 鑾峰彇鏈湴鏈垎閰嶇殑鏀寔褰撳墠绫诲瀷鐨勭粦瀹氬満鏅垪琛�
@@ -1097,15 +984,18 @@
                             }
                             RefreshRoomList();
                         };
-
-                        btnFloorText.Text = BindInfo.GetCurrentSelectFloorIdName();
-                        //鑾峰彇妤煎眰涓埧闂村垪琛�
-                        if (supportRoomList.Count != 0)
+                        //榛樿妤煎眰鏄剧ず
+                        if (BindInfo.GetCurrentSelectFloorIdName() != null)
                         {
-                            RefreshRoomList();
+                            Application.RunOnMainThread(() =>
+                            {
+                                btnFloorText.Text = BindInfo.GetCurrentSelectFloorIdName();
+                            });
                         }
-
+                        //鑾峰彇妤煎眰涓埧闂村垪琛�
+                        RefreshRoomList();
                         CommonPage.Loading.Hide();
+                        canFresh = false;
                         midVerticalScrolViewLayout.EndHeaderRefreshing();
                     });
                 }
@@ -1153,22 +1043,20 @@
                         for (int i = 0; i < targetScList.Count; i++)
                         {
                             //缁戝畾鏂扮殑鏁版嵁
-                            var addBindeDev = new AddBindData();
-                            addBindeDev.DeviceAddr = curControlDev.DeviceAddr;
+                            var addSingleBindData = new AddSingleBindData();
+                            addSingleBindData.DeviceAddr = curControlDev.DeviceAddr;
                             for (int j = 0; j < curSupportBindEpointList.Count; j++)
                             {
                                 curSendEpointList.Add(curSupportBindEpointList[0]);
-                                addBindeDev.Epoint = curControlDev.DeviceEpoint = curSupportBindEpointList[0];
+                                addSingleBindData.Epoint = curControlDev.DeviceEpoint = curSupportBindEpointList[0];
                                 break;
                             }
                             var de = targetScList[i];
-                            var addBindInfo = new AddBindListObj();
-                            addBindInfo.BindType = 1;
-                            addBindInfo.BindCluster = 6;
-                            addBindInfo.BindScenesId = de.Id;
-                            addBindeDev.BindList.Add(addBindInfo);
+                            addSingleBindData.BindType = 1;
+                            addSingleBindData.BindClusterList.Add(6);
+                            addSingleBindData.BindScenesId = de.Id;
 
-                            var resT = AddDeviceBind(addBindeDev, targetSendCount, ref targetRecCount);
+                            var resT = AddDeviceBind(addSingleBindData, targetSendCount, ref targetRecCount);
                             if (!resT)
                             {
                                 break;
@@ -1197,8 +1085,8 @@
                         foreach (var de in targetList)
                         {
                             //缁戝畾鏂扮殑鏁版嵁
-                            var addBindeDev = new AddBindData();
-                            addBindeDev.DeviceAddr = curControlDev.DeviceAddr;
+                            var addSingleBindData = new AddSingleBindData();
+                            addSingleBindData.DeviceAddr = curControlDev.DeviceAddr;
 
                             if (curBindType == 3)
                             {
@@ -1207,7 +1095,7 @@
                                     for (int j = 0; j < curSupportDimmerEpointList.Count; j++)
                                     {
                                         curSendEpointList.Add(curSupportDimmerEpointList[0]);
-                                        addBindeDev.Epoint = curControlDev.DeviceEpoint = curSupportDimmerEpointList[0];
+                                        addSingleBindData.Epoint = curControlDev.DeviceEpoint = curSupportDimmerEpointList[0];
                                         break;
                                     }
                                 }
@@ -1217,7 +1105,7 @@
                                     for (int j = 0; j < curSupportLightEpointList.Count; j++)
                                     {
                                         curSendEpointList.Add(curSupportLightEpointList[0]);
-                                        addBindeDev.Epoint = curControlDev.DeviceEpoint = curSupportLightEpointList[0];
+                                        addSingleBindData.Epoint = curControlDev.DeviceEpoint = curSupportLightEpointList[0];
                                         break;
                                     }
                                 }
@@ -1227,68 +1115,48 @@
                                 for (int j = 0; j < curSupportBindEpointList.Count; j++)
                                 {
                                     curSendEpointList.Add(curSupportBindEpointList[0]);
-                                    addBindeDev.Epoint = curControlDev.DeviceEpoint = curSupportBindEpointList[0];
+                                    addSingleBindData.Epoint = curControlDev.DeviceEpoint = curSupportBindEpointList[0];
                                     break;
                                 }
                             }
 
-                            var addBindInfo = new AddBindListObj();
-                            addBindInfo.BindType = 0;
-                            addBindInfo.BindMacAddr = de.DeviceAddr;
-                            addBindInfo.BindEpoint = de.DeviceEpoint;
+                            addSingleBindData.BindType = 0;
+                            addSingleBindData.BindMacAddr = de.DeviceAddr;
+                            addSingleBindData.BindEpoint = de.DeviceEpoint;
                             switch (curBindType)
                             {
                                 case 0:
-                                    addBindInfo.BindCluster = 6;
-                                    break;
                                 case 1:
-                                    addBindInfo.BindCluster = 6;
-                                    break;
                                 case 2:
-                                    addBindInfo.BindCluster = 6;
+                                    addSingleBindData.BindClusterList.Add(6);
                                     break;
                                 case 3:
-                                    addBindInfo.BindCluster = 6;
-                                    break;
-                                case 4:
-                                    addBindInfo.BindCluster = 258;
-                                    break;
-                                case 5:
-                                    addBindInfo.BindCluster = 513;
-                                    break;
-                                case 6:
-                                    addBindInfo.BindCluster = 514;
-                                    break;
-                            }
-                            addBindeDev.BindList.Add(addBindInfo);
-
-                            //閮ㄥ垎鐩爣闇�瑕佷簩娆$粦瀹氱浜岀鍔熻兘
-                            var addBindInfo2 = new AddBindListObj();
-                            addBindInfo2.BindType = 0;
-                            addBindInfo2.BindMacAddr = de.DeviceAddr;
-                            addBindInfo2.BindEpoint = de.DeviceEpoint;
-                            switch (curBindType)
-                            {
-                                case 3:
+                                    addSingleBindData.BindClusterList.Add(6);
                                     var device = LocalDevice.Current.GetDevice(de.DeviceAddr, de.DeviceEpoint);
                                     if (device != null)
                                     {
                                         if (device.Type == DeviceType.DimmableLight)
                                         {
                                             //鐏厜涓鸿皟鍏夋椂闇�瑕佺粦瀹�6锛�8
-                                            addBindInfo2.BindCluster = 8;
-                                            addBindeDev.BindList.Add(addBindInfo2);
+                                            addSingleBindData.BindClusterList.Add(8);
                                         }
                                     }
                                     break;
+                                case 4:
+                                    addSingleBindData.BindClusterList.Add(258);
+                                    break;
                                 case 5:
                                     //瑕佺粦瀹氱┖璋冿細闇�瑕佺粦瀹�513锛�514
-                                    addBindInfo2.BindCluster = 514;
-                                    addBindeDev.BindList.Add(addBindInfo2);
+                                    addSingleBindData.BindClusterList.Add(513);
+                                    addSingleBindData.BindClusterList.Add(514);
+                                    break;
+                                case 6:
+                                    addSingleBindData.BindClusterList.Add(514);
                                     break;
                             }
 
-                            var resT = AddDeviceBind(addBindeDev, targetSendCount, ref targetRecCount);
+
+                            var resT = AddDeviceBind(addSingleBindData, targetSendCount, ref targetRecCount);
                             if (!resT)
                             {
                                 break;
@@ -1312,53 +1180,53 @@
         /// <summary>
         /// AddDeviceBind
         /// </summary>
-        /// <param name="addBindeDev"></param>
+        /// <param name="addSingleBindData"></param>
         /// <param name="targetSendCount"></param>
         /// <param name="targetRecCount"></param>
         /// <returns></returns>
-        private bool AddDeviceBind(AddBindData addBindeDev, int targetSendCount, ref int targetRecCount)
+        private bool AddDeviceBind(AddSingleBindData addSingleBindData, int targetSendCount, ref int targetRecCount)
         {
             var addSuccess = false;
-            var dev = HdlDeviceBindLogic.Current.AddDeviceBindAsync(addBindeDev);
-            if (dev != null && dev.addedDeviceBindResponseData != null)
+            var dev = HdlDeviceBindLogic.Current.AddDeviceSingleBindAsync(addSingleBindData);
+            if (dev != null && dev.addedDeviceSingleBindResponseData != null)
             {
                 addSuccess = true;
                 targetRecCount++;
-                if (dev.addedDeviceBindResponseData.Result == 0)
+                if (dev.addedDeviceSingleBindResponseData.Result == 0)
                 {
                     var countTotal = targetRecCount;
-
                     var bList = new List<BindListAllInfo>();
-                    foreach (var devB in dev.addedDeviceBindResponseData.BindList)
+                    foreach (var cluster in dev.addedDeviceSingleBindResponseData.BindClusterList)
                     {
                         var curD = new BindListAllInfo();
                         curD.KeyMacAddr = curControlDev.DeviceAddr;
                         curD.KeyEpoint = curControlDev.DeviceEpoint;
-                        curD.BindCluster = devB.BindCluster;
-                        curD.BindScenesId = devB.BindScenesId;
-                        curD.BindMacAddr = devB.BindMacAddr;
-                        curD.BindEpoint = devB.BindEpoint;
-                        curD.ESName = devB.ESName;
-                        curD.BindType = devB.BindType;
+                        curD.BindCluster = cluster;
+                        curD.BindScenesId = dev.addedDeviceSingleBindResponseData.BindScenesId;
+                        curD.BindMacAddr = dev.addedDeviceSingleBindResponseData.BindMacAddr;
+                        curD.BindEpoint = dev.addedDeviceSingleBindResponseData.BindEpoint;
+                        curD.ESName = dev.addedDeviceSingleBindResponseData.ESName;
+                        curD.BindType = dev.addedDeviceSingleBindResponseData.BindType;
                         bList.Add(curD);
                     }
-                    if (MutilfunctionPanelMethod.bindTargetsFromMutilfunctionPanelList.ContainsKey(curControlDev.DeviceAddr + curControlDev.DeviceEpoint))
+
+                    if (curControlDev.bindTargetsFromMutilfunctionPanelList.ContainsKey(curControlDev.DeviceAddr + curControlDev.DeviceEpoint))
                     {
-                        MutilfunctionPanelMethod.bindTargetsFromMutilfunctionPanelList[curControlDev.DeviceAddr + curControlDev.DeviceEpoint] = bList;
+                        curControlDev.bindTargetsFromMutilfunctionPanelList[curControlDev.DeviceAddr + curControlDev.DeviceEpoint] = bList;
                     }
                     else
                     {
-                        MutilfunctionPanelMethod.bindTargetsFromMutilfunctionPanelList.Add(curControlDev.DeviceAddr + curControlDev.DeviceEpoint, bList);
+                        curControlDev.bindTargetsFromMutilfunctionPanelList.Add(curControlDev.DeviceAddr + curControlDev.DeviceEpoint, bList);
                     }
 
                     if (curBindType == 3)
                     {
-                        if (addBindeDev.Epoint >= 22 && addBindeDev.Epoint <= 28)
+                        if (addSingleBindData.Epoint >= 22 && addSingleBindData.Epoint <= 28)
                         {
                             curSupportDimmerEpointList.RemoveAt(0);
 
                         }
-                        if (addBindeDev.Epoint >= 52 && addBindeDev.Epoint <= 61)
+                        if (addSingleBindData.Epoint >= 52 && addSingleBindData.Epoint <= 61)
                         {
                             curSupportLightEpointList.RemoveAt(0);
                         }
@@ -1383,7 +1251,7 @@
                         }
                     });
                 }
-                else if (dev.addedDeviceBindResponseData.Result == 1)
+                else if (dev.addedDeviceSingleBindResponseData.Result == 1)
                 {
                     Application.RunOnMainThread(() =>
                     {
@@ -1394,7 +1262,7 @@
                         new Tip()
                         {
                             MaxWidth = 150,
-                            Text = Language.StringByID(R.MyInternationalizationString.BindFailed),
+                            Text = Language.StringByID(R.MyInternationalizationString.BindFailed) + "(" + "5020_1" + ")",
                             Direction = AMPopTipDirection.Up,
                             CloseTime = 1
                         }.Show(btnFinifh);
@@ -1411,7 +1279,7 @@
                         new Tip()
                         {
                             MaxWidth = 150,
-                            Text = Language.StringByID(R.MyInternationalizationString.BindUnknownError),
+                            Text = Language.StringByID(R.MyInternationalizationString.BindUnknownError) + "(" + "5020_2" + ")",
                             Direction = AMPopTipDirection.Up,
                             CloseTime = 1
                         }.Show(btnFinifh);
@@ -1425,6 +1293,13 @@
                     btnFinifh.Enable = true;
                     btnFinifh.BackgroundColor = Shared.Common.ZigbeeColor.Current.XMBlack;
                     RefreshRoomList();
+                    new Tip()
+                    {
+                        MaxWidth = 150,
+                        Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime) + "(" + "5020" + ")",
+                        Direction = AMPopTipDirection.Up,
+                        CloseTime = 1
+                    }.Show(btnFinifh);
                     CommonPage.Loading.Hide();
                     GetEpointData();
                 });
@@ -1464,7 +1339,6 @@
                                 curD.BindScenesId = dev.BindScenesId;
                                 curD.BindMacAddr = dev.BindMacAddr;
                                 curD.BindEpoint = dev.BindEpoint;
-                                curD.ESName = dev.ESName;
                                 curD.BindType = dev.BindType;
                                 bList.Add(curD);
 
@@ -1492,17 +1366,17 @@
                             }
 
                             //鏇存柊bindTargetsFromMutilfunctionPanelList
-                            if (MutilfunctionPanelMethod.bindTargetsFromMutilfunctionPanelList.ContainsKey(curControlDev.DeviceAddr + curControlDev.DeviceEpoint))
+                            if (curControlDev.bindTargetsFromMutilfunctionPanelList.ContainsKey(curControlDev.DeviceAddr + curControlDev.DeviceEpoint))
                             {
-                                MutilfunctionPanelMethod.bindTargetsFromMutilfunctionPanelList[curControlDev.DeviceAddr + curControlDev.DeviceEpoint] = bList;
+                                curControlDev.bindTargetsFromMutilfunctionPanelList[curControlDev.DeviceAddr + curControlDev.DeviceEpoint] = bList;
                             }
                             else
                             {
-                                MutilfunctionPanelMethod.bindTargetsFromMutilfunctionPanelList.Add(curControlDev.DeviceAddr + curControlDev.DeviceEpoint, bList);
+                                curControlDev.bindTargetsFromMutilfunctionPanelList.Add(curControlDev.DeviceAddr + curControlDev.DeviceEpoint, bList);
                             }
 
                             //鏇存柊褰撳墠鏀寔鐨勭鐐圭粦瀹氳〃
-                            curSupportBindEpointList = MutilfunctionPanelMethod.GetMatchEpointList(curBindType);
+                            curSupportBindEpointList = MutilfunctionPanelMethod.GetMatchEpointList(curControlDev, curBindType);
                             if (curBindType == 3)
                             {
                                 foreach (var ep in curSupportBindEpointList)

--
Gitblit v1.8.0