From 66a9965c44ecc32a6696abca876ab9d1cd091584 Mon Sep 17 00:00:00 2001
From: gxc <guoxuecheng@guoxuechengdeMacBook-Pro.local>
Date: 星期五, 28 二月 2020 15:25:13 +0800
Subject: [PATCH] 2020.2.28

---
 ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindTargetsPage.cs | 1462 +++++++++++++++++++++++++++++++--------------------------
 1 files changed, 796 insertions(+), 666 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindTargetsPage.cs b/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindTargetsPage.cs
index 11acf4a..3ea1cc6 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindTargetsPage.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Device/Bind/BindTargetsPage.cs
@@ -1,4 +1,5 @@
 锘縰sing System;
+using System.Collections;
 using System.Collections.Generic;
 using Shared.Common;
 using ZigBee.Device;
@@ -32,19 +33,172 @@
         }
 
         #region 鈼� 鍙橀噺鐢虫槑__________________________
-        ZigBee.Device.Panel currentKey;
-        VerticalScrolViewLayout midVerticalScrolViewLayout;//鏄剧ず琚粦瀹氳澶囨垨鍦烘櫙鐨剉iew
-        VerticalScrolViewLayout topMidVerticalScrolViewLayout;//鏄剧ず褰撳墠妯″紡view
-        int currentClusterID = 0;//褰撳墠绨嘔D
+        ZigBee.Device.Panel currentKey;//褰撳墠鎸夐敭瀵硅薄
+        VerticalFrameRefreshControl midVerticalRefreshLayout;//鏄剧ず琚粦瀹氳澶囨垨鍦烘櫙鐨剉iew
+        int currentClusterID = 0;//鎸夐敭褰撳墠绨嘔D
+        Button entryStatusPic;
+        Button btnPicTip;
         Action<List<BindListResponseObj>> action;//鎸夐敭缁戝畾琛ㄩ�氱煡
-        public static System.Collections.Generic.List<CommonDevice> localDeviceList = new System.Collections.Generic.List<CommonDevice>();//鏈湴璁惧鍒楄〃
-        public static System.Collections.Generic.List<SceneUI> scList = new System.Collections.Generic.List<SceneUI> { };//鏈湴鍦烘櫙鍒楄〃
-        Action<List<BindListResponseObj>> devicBindAction;
+        Action<List<BindListResponseObj>> devicBindAction;//璁惧琚粦瀹氶�氱煡
+        private System.Collections.Generic.List<CommonDevice> localDeviceList = new System.Collections.Generic.List<CommonDevice>();//鏈湴璁惧鍒楄〃
+        private System.Collections.Generic.List<SceneUI> scList = new System.Collections.Generic.List<SceneUI> { };//鏈湴鍦烘櫙鍒楄〃       
+        FrameLayout blankFrameLayout;//绌烘暟鎹樉绀哄竷灞�
+        List<int> typeModeList;//鍔ㄦ�佽幏鍙栨寜閿敮鎸佺殑妯″紡澶х被鍨�
+        public List<ScenesListInfo> gwScenesList = new List<ScenesListInfo>();//缃戝叧涓殑鍦烘櫙鍒楄〃
+        bool IsRead = false;
+
         #endregion
 
+        //鍒濆鍖栨寜閿暟鎹�
+        void InitListInfo()
+        {
+            System.Threading.Tasks.Task.Run(async () =>
+            {
+                try
+                {
+                    localDeviceList.Clear();
+                    scList.Clear();
+                    //鑾峰彇鏈湴璁惧鍒楄〃
+                    foreach (var dev in Shared.Common.LocalDevice.Current.listAllDevice)
+                    {
+                        localDeviceList.Add(dev);
+                    }
+                    //鑾峰彇鏈湴鍦烘櫙鍒楄〃
+                    scList = Shared.Common.Room.AllRoomSceneUIList;
+                    //鑾峰彇缃戝叧鍦烘櫙琛�
+                    var gwSceneObj = await currentKey.GetSceneInfoAsync();
+                    if (gwSceneObj != null && gwSceneObj.getSceneInfo != null)
+                    {
+                        gwScenesList = gwSceneObj.getSceneInfo.ScenesList;
+                    }
+                    //鍔ㄦ�佽幏鍙栨寜閿敮鎸佺殑澶х被
+                    typeModeList = await GetTypeMode();
+                    #region 璇诲彇闈㈡澘褰撳墠妯″紡
+                    //璇诲彇鎸夐敭褰撳墠妯″紡
+                    var tempDeata = await currentKey.ReadPanelConfigureInfoAsync();
+                    if (tempDeata != null && tempDeata.deviceStatusReportData != null)
+                    {
+                        foreach (var attr in tempDeata.deviceStatusReportData.AttriBute)
+                        {
+                            currentKey.panelMode = attr.AttriButeData;
+                            if (currentKey.panelMode == 1)
+                            {
+                                currentClusterID = 6;
+                            }
+                            else if (currentKey.panelMode == 100 || currentKey.panelMode == 101 || currentKey.panelMode == 102)
+                            {
+                                currentClusterID = 6;
+                            }
+                            else if (currentKey.panelMode == 200 || currentKey.panelMode == 201 || currentKey.panelMode == 203 || currentKey.panelMode == 204 || currentKey.panelMode == 205)
+                            {
+                                currentClusterID = 8;
+                            }
+                            else if (currentKey.panelMode == 300 || currentKey.panelMode == 301 || currentKey.panelMode == 302 || currentKey.panelMode == 303 || currentKey.panelMode == 304)
+                            {
+                                currentClusterID = 258;
+                            }
+
+                            //璇诲彇鎸夐敭褰撳墠缁戝畾鐩爣
+                            GetDeviceBindResponseAllData getBindList = null;
+                            if (IsRead)
+                            {
+                                getBindList = await currentKey.GetDeviceBindAsync();
+                                var bindDeviceListTemp = new System.Collections.Generic.List<BindListResponseObj> { };
+                                var bindSceneListTemp = new System.Collections.Generic.List<BindListResponseObj> { };
+                                if (getBindList != null && getBindList.getAllBindResponseData != null)
+                                {
+                                    currentKey.bindList.Clear();
+                                    foreach (var b in getBindList.getAllBindResponseData.BindList)
+                                    {
+                                        if (b.BindCluster == currentClusterID)
+                                        {
+                                            if (b.BindCluster == 6)
+                                            {
+
+                                                if (b.BindType == 2)
+                                                {
+                                                    bindSceneListTemp.Add(b);
+                                                }
+                                                else
+                                                {
+                                                    bindDeviceListTemp.Add(b);
+                                                }
+                                            }
+                                            else
+                                            {
+                                                if (currentClusterID == 8)
+                                                {
+                                                    if (b.BindCluster == 8)
+                                                    {
+                                                        currentKey.bindList.Add(b);
+                                                    }
+                                                }
+                                                else
+                                                {
+                                                    currentKey.bindList.Add(b);
+                                                }
+                                            }
+                                        }
+                                    }
+                                }
+                                else
+                                {
+                                    Application.RunOnMainThread(() =>
+                                    {
+                                        CommonPage.Loading.Hide();
+                                        new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime), Direction = AMPopTipDirection.None, CloseTime = 1 }.Show(Common.CommonPage.Instance);
+                                        return;
+                                    });
+                                }
+                                if (currentKey.panelMode == 1)
+                                {
+                                    currentKey.bindList = bindSceneListTemp;
+                                    currentKey.currentKeySelectModeText = Language.StringByID(R.MyInternationalizationString.AddScene);
+                                }
+                                else if (currentKey.panelMode == 100 || currentKey.panelMode == 101 || currentKey.panelMode == 102)
+                                {
+                                    currentKey.bindList = bindDeviceListTemp;
+                                    currentKey.currentKeySelectModeText = Language.StringByID(R.MyInternationalizationString.AddSwitch);
+                                }
+                                else if (currentKey.panelMode == 200 || currentKey.panelMode == 201 || currentKey.panelMode == 203 || currentKey.panelMode == 204 || currentKey.panelMode == 205)
+                                {
+                                    currentKey.currentKeySelectModeText = Language.StringByID(R.MyInternationalizationString.AddDimmer);
+                                }
+                                else if (currentKey.panelMode == 300 || currentKey.panelMode == 301 || currentKey.panelMode == 302 || currentKey.panelMode == 303 || currentKey.panelMode == 304)
+                                {
+                                    currentKey.currentKeySelectModeText = Language.StringByID(R.MyInternationalizationString.AddCurtain);
+                                }
+                            }
+                            currentKey.ReSave();
+                        }
+                        #endregion 
+                        Application.RunOnMainThread(() =>
+                        {
+                            RefreshList();
+                            CommonPage.Loading.Hide();
+                        });
+                    }
+                    else
+                    {
+                        Application.RunOnMainThread(() =>
+                        {
+                            CommonPage.Loading.Hide();
+                            new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime), Direction = AMPopTipDirection.None, CloseTime = 1 }.Show(Common.CommonPage.Instance);
+                        });
+                        return;
+                    }
+                }
+                catch { }
+            });
+        }
+
+        /// <summary>
+        /// 鎸夐敭缁戝畾椤垫樉绀�
+        /// </summary>
         public void Show()
         {
-            this.TopFrameLayout(this, Language.StringByID(R.MyInternationalizationString.AddBindTargets));
+            #region TopFrameLayout
+            this.TopFrameLayout(this, Language.StringByID(R.MyInternationalizationString.PanelBindTargets));
             EventHandler<MouseEventArgs> eHandlerBack = (sender, e) =>
             {
                 RemoveFromParent();
@@ -55,18 +209,22 @@
 
             var btnAddFrameLayout = new FrameLayout()
             {
-                X = Application.GetRealWidth(913),
+                X = Application.GetRealWidth(888),
                 Width = Application.GetRealWidth(192),
             };
             this.titleFrameLayout.AddChidren(btnAddFrameLayout);
 
             var btnBindAdd = new Button
             {
+                X = Application.GetRealWidth(62),
                 Height = Application.GetRealHeight(72),
                 Width = Application.GetRealWidth(72),
                 UnSelectedImagePath = "BindPic/BindAdd.png",
             };
             btnAddFrameLayout.AddChidren(btnBindAdd);
+            #endregion
+
+            #region eHandlerAdd
             EventHandler<MouseEventArgs> eHandlerAdd = (sender, e) =>
             {
                 if (currentKey.bindList.Count != 0)
@@ -75,7 +233,7 @@
                     {
                         currentClusterID = 6;
                         currentKey.panelMode = 1;
-                        var addScenePage = new Shared.Phone.UserCenter.DeviceBind.AddScenePage(currentKey);
+                        var addScenePage = new Shared.Phone.UserCenter.DeviceBind.AddScenePage(currentKey, gwScenesList);
                         Shared.Phone.UserView.HomePage.Instance.AddChidren(addScenePage);
                         Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
                         addScenePage.Show();
@@ -137,179 +295,93 @@
                 }
                 else
                 {
+                    currentKey.panelMode = 65535;
                     SideslipFramelayout();
                 }
             };
             btnBindAdd.MouseDownEventHandler += eHandlerAdd;
             btnAddFrameLayout.MouseDownEventHandler += eHandlerAdd;
-            MidFrameLayoutContent();
+            #endregion
+            CommonPage.Loading.Start("");
+            middleFrameLayout();
+            if (currentKey.bindList.Count == 0)
+            {
+                IsRead = true;
+            }
+            else
+            {
+                IsRead = false;
+            }
+            InitListInfo();
+
         }
-
-        async void MidFrameLayoutContent()
+        /// <summary>
+        /// 涓儴甯冨眬
+        /// </summary>
+        void middleFrameLayout()
         {
-            try
+            midVerticalRefreshLayout = new VerticalFrameRefreshControl(29)
             {
-                localDeviceList.Clear();
-                scList.Clear();
-                foreach (var dev in Shared.Common.LocalDevice.Current.listAllDevice)
-                {
-                    localDeviceList.Add(dev);
-                }
-                scList = Shared.Common.Room.AllRoomSceneUIList;
-            }
-            catch { }
-
-            try
+            };
+            this.midFrameLayout.AddChidren(midVerticalRefreshLayout);
+            midVerticalRefreshLayout.BeginHeaderRefreshingAction += () =>
             {
-                CommonPage.Loading.Start("");
-                #region 鏁版嵁澶勭悊
-                var tempDeata = await currentKey.ReadPanelConfigureInfoAsync();
+                midVerticalRefreshLayout.BeginHeaderRefreshing();
+                IsRead = true;
+                InitListInfo();
+                midVerticalRefreshLayout.EndHeaderRefreshing();
+            };
 
-                if (tempDeata != null && tempDeata.deviceStatusReportData != null)
-                {
-                    currentClusterID = tempDeata.deviceStatusReportData.CluterID;
-
-                    foreach (var attr in tempDeata.deviceStatusReportData.AttriBute)
-                    {
-                        currentKey.panelMode = attr.AttriButeData;
-                        currentKey.ReSave();
-                        var getBindList = await currentKey.GetDeviceBindAsync();
-
-                        var bindDeviceListTemp = new System.Collections.Generic.List<BindListResponseObj> { };
-                        var bindSceneListTemp = new System.Collections.Generic.List<BindListResponseObj> { };
-                        if (getBindList != null && getBindList.getAllBindResponseData != null)
-                        {
-                            foreach (var b in getBindList.getAllBindResponseData.BindList)
-                            {
-                                if (b.BindCluster == currentClusterID)
-                                {
-                                    if (b.BindCluster == 6)
-                                    {
-
-                                        if (b.BindType == 2)
-                                        {
-                                            bindSceneListTemp.Add(b);
-                                        }
-                                        else
-                                        {
-                                            bindDeviceListTemp.Add(b);
-                                        }
-                                    }
-                                    else
-                                    {
-                                        currentKey.bindList.Add(b);
-                                    }
-                                }
-                            }
-                        }
-                        else
-                        {
-                            var btn = new Button()
-                            {
-                                Gravity = Gravity.Center,
-                            };
-                            this.midFrameLayout.AddChidren(btn);
-                            Application.RunOnMainThread(() =>
-                            {
-                                new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime), Direction = AMPopTipDirection.Up, CloseTime = 1 }.Show(btn);
-                            });
-                        }
-
-                        if (currentKey.panelMode == 1)
-                        {
-                            currentKey.bindList = bindSceneListTemp;
-                            currentKey.currentKeySelectModeText = Language.StringByID(R.MyInternationalizationString.AddScene);
-                        }
-                        else if (currentKey.panelMode == 100 || currentKey.panelMode == 101 || currentKey.panelMode == 102)
-                        {
-                            currentKey.bindList = bindDeviceListTemp;
-                            currentKey.currentKeySelectModeText = Language.StringByID(R.MyInternationalizationString.AddSwitch);
-                        }
-                        else if (currentKey.panelMode == 200 || currentKey.panelMode == 201 || currentKey.panelMode == 202 || currentKey.panelMode == 203 || currentKey.panelMode == 204 || currentKey.panelMode == 205)
-                        {
-                            currentKey.currentKeySelectModeText = Language.StringByID(R.MyInternationalizationString.AddDimmer);
-                        }
-                        else if (currentKey.panelMode == 300 || currentKey.panelMode == 301 || currentKey.panelMode == 302 || currentKey.panelMode == 303 || currentKey.panelMode == 304)
-                        {
-                            currentKey.currentKeySelectModeText = Language.StringByID(R.MyInternationalizationString.AddCurtain);
-                        }
-                    }
-                    #endregion 
-                }
-                else
-                {
-                    Application.RunOnMainThread(() =>
-                    {
-                        var btn = new Button()
-                        {
-                            Gravity = Gravity.Center,
-                        };
-                        this.midFrameLayout.AddChidren(btn);
-                        new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime), Direction = AMPopTipDirection.Up, CloseTime = 1 }.Show(btn);
-                    });
-                }
-            }
-            catch
-            { }
-            finally
-            {
-                RefreshList();
-                CommonPage.Loading.Hide();
-            }
+            BlankPicUI();
         }
 
         /// <summary>
-        /// 鎸夐敭缁戝畾鍦烘櫙琛ㄦ樉绀�
+        /// 绌烘暟鎹甎I鏄剧ず
         /// </summary>
-        /// <param name="gateway">Gateway.</param>
-        /// <param name="key">Key.</param>
-        async void RefreshList()
+        void BlankPicUI()
         {
-            this.midFrameLayout.RemoveAll();
-
-            var entryStatusPic = new Button
+            blankFrameLayout = new FrameLayout
             {
-                X = Application.GetRealWidth(164),
-                Y = Application.GetRealHeight(492),
+            };
+            midVerticalRefreshLayout.AddChidren(blankFrameLayout);
+
+            entryStatusPic = new Button
+            {
+                X = Application.GetRealWidth(213),
+                Y = Application.GetRealHeight(418),
                 UnSelectedImagePath = "BindPic/BindEmptyPic.png",
                 Visible = false,
             };
-            this.midFrameLayout.AddChidren(entryStatusPic);
+            blankFrameLayout.AddChidren(entryStatusPic);
 
-            var btnPicTip = new Button
+            btnPicTip = new Button
             {
-                X = Application.GetRealWidth(432),
                 Y = Application.GetRealHeight(1020),
                 Text = Language.StringByID(R.MyInternationalizationString.NoControlTargets),
                 TextColor = Shared.Common.ZigbeeColor.Current.XMGray3,
                 Gravity = Gravity.CenterHorizontal,
                 Visible = false,
+                TextSize = 12,
             };
-            this.midFrameLayout.AddChidren(btnPicTip);
-
-            topMidVerticalScrolViewLayout = new VerticalScrolViewLayout
-            {
-                Height = Application.GetMinRealAverage(0),
-                BackgroundColor = Shared.Common.ZigbeeColor.Current.XMWhite,
-
-            };
-            this.midFrameLayout.AddChidren(topMidVerticalScrolViewLayout);
-
-            midVerticalScrolViewLayout = new VerticalScrolViewLayout()
-            {
-                BackgroundColor = Shared.Common.ZigbeeColor.Current.XMWhite,
-            };
-            this.midFrameLayout.AddChidren(midVerticalScrolViewLayout);
-            midVerticalScrolViewLayout.RemoveAll();
-
+            blankFrameLayout.AddChidren(btnPicTip);
+        }
+        /// <summary>
+        /// 鎸夐敭缁戝畾琛ㄦ樉绀�
+        /// </summary> 
+        async void RefreshList()
+        {
+            midVerticalRefreshLayout.RemoveAll();
+            this.midFrameLayout.RemoveAll();
+            middleFrameLayout();
+            #region 鏁版嵁澶勭悊 
             if (currentKey.bindList.Count == 0)
             {
-                entryStatusPic.Height = Application.GetRealHeight(435);
-                entryStatusPic.Width = Application.GetRealWidth(757);
+                entryStatusPic.Height = Application.GetRealHeight(556);
+                entryStatusPic.Width = Application.GetRealWidth(654);
                 btnPicTip.Height = Application.GetRealHeight(49);
-                midVerticalScrolViewLayout.Height = 0;
                 btnPicTip.Visible = true;
                 entryStatusPic.Visible = true;
+                blankFrameLayout.Height = midVerticalRefreshLayout.Height;
             }
             else
             {
@@ -318,63 +390,38 @@
                 btnPicTip.Height = Application.GetRealHeight(0);
                 btnPicTip.Visible = false;
                 entryStatusPic.Visible = false;
-                topMidVerticalScrolViewLayout.Height = Application.GetRealHeight(170);
-                midVerticalScrolViewLayout.Y = topMidVerticalScrolViewLayout.Bottom;
-                midVerticalScrolViewLayout.Height = this.midFrameLayout.Height;
-                BackgroundColor = Shared.Common.ZigbeeColor.Current.XMMidFrameLayout;
-
+                blankFrameLayout.Height = Application.GetRealHeight(0);
                 if (currentKey.panelMode == 1)
                 {
-                    topMidVerticalScrolViewLayout.Height = Application.GetRealHeight(0);
-                    midVerticalScrolViewLayout.Y = Application.GetRealHeight(0);
+                    midVerticalRefreshLayout.Y = Application.GetRealHeight(0);
                 }
-
-                if (currentKey.panelMode != 1)
+                else
                 {
                     BindModeDisplay();
                 }
+                int curIndex = 0;
                 for (int i = 0; i < currentKey.bindList.Count; i++)
                 {
-                    var rowLayout = new RowLayout()
-                    {
-                        Height = Application.GetRealHeight(170),
-                    };
-                    midVerticalScrolViewLayout.AddChidren(rowLayout);
-
-                    #region 缁戝畾琛║I鏄撅紙鏃犳暟鎹鐞嗭級 
+                    curIndex = i;
                     var bindDevice = currentKey.bindList[i];
-                    var devicePic = new Button()
-                    {
-                        X = Application.GetRealWidth(50),
-                        Width = Application.GetMinRealAverage(110),
-                        Height = Application.GetMinRealAverage(110),
-                        Gravity = Gravity.CenterVertical,
-                    };
-                    rowLayout.AddChidren(devicePic);
-
-                    var btnBindName = new Button()
-                    {
-                        Width = Application.GetRealWidth(500 - 120),
-                        X = devicePic.Right + Application.GetRealWidth(20),
-                        TextColor = Shared.Common.ZigbeeColor.Current.TextBlack,
-                        TextAlignment = TextAlignment.CenterLeft,
-                    };
-                    rowLayout.AddChidren(btnBindName);
-
-                    var btnDel = new Button()
-                    {
-                        TextColor = Shared.Common.ZigbeeColor.Current.GXCTextWhiteColor,
-                        X = btnBindName.Right,
-                        TextID = R.MyInternationalizationString.DelBindDevice,
-                        BackgroundColor = Shared.Common.ZigbeeColor.Current.DelRowLayout,
-                    };
-                    rowLayout.AddRightView(btnDel);
-                    #endregion
-
-                    #region 缁戝畾鏁版嵁澶勭悊
-
+                    SceneUI curSceneUI = null;
                     bool isExistScene = false;
 
+                    var rowLayout = new RowLayoutControl(midVerticalRefreshLayout.rowSpace / 2);
+                    rowLayout.BackgroundColor = ZigbeeColor.Current.XMWhite;
+                    midVerticalRefreshLayout.AddChidrenRow(rowLayout);
+                    rowLayout.frameTable.UseClickStatu = false;
+                    var devicePic = rowLayout.frameTable.AddLeftIcon();
+                    devicePic.UnSelectedImagePath = "DoorLock/DoorLockUserPic.png";
+
+                    #region 缁戝畾鏁版嵁澶勭悊
+                    int currentIndex = i;
+                    var btnBindNameText = "";
+                    var btnFloorRoomNameText = "";
+                    if (currentIndex == currentKey.bindList.Count - 1)
+                    {
+                        rowLayout.LineColor = Shared.Common.ZigbeeColor.Current.XMWhite;
+                    }
                     foreach (var sc in currentKey.bindList)
                     {
                         if (sc.BindType == 2)
@@ -382,19 +429,28 @@
                             isExistScene = true;
                         }
                     }
-
                     if (isExistScene)
                     {
-                        devicePic.UnSelectedImagePath = "Item/Scene.png";
-                        devicePic.Width = Application.GetMinRealAverage(110);
-
-                        if (bindDevice.ESName == "")
+                        curSceneUI = Room.CurrentRoom.GetSceneUIBySceneId(bindDevice.BindScenesId);
+                        devicePic.UnSelectedImagePath = "Scene/SceneIcon.png";
+                        if (curSceneUI == null)
                         {
-                            btnBindName.Text = Language.StringByID(R.MyInternationalizationString.Unknown) + Language.StringByID(R.MyInternationalizationString.Scence) + "ID" + bindDevice.BindScenesId.ToString();
+                            if (string.IsNullOrEmpty(bindDevice.ESName))
+                            {
+                                btnBindNameText = Language.StringByID(R.MyInternationalizationString.OffLineScene) + "_" + "ID" + "_" + bindDevice.BindScenesId.ToString();
+                            }
+                            else
+                            {
+                                btnBindNameText = Language.StringByID(R.MyInternationalizationString.OffLineScene) + "_" + bindDevice.ESName;
+                            }
                         }
                         else
                         {
-                            btnBindName.Text = bindDevice.ESName;
+                            btnBindNameText = curSceneUI.Name;
+                            if (curSceneUI.GetZone() != null)
+                            {
+                                btnFloorRoomNameText = curSceneUI.GetZone();
+                            }
                         }
                     }
                     else
@@ -405,22 +461,44 @@
                             var tempDev = localDeviceList.Find(obj => obj.DeviceAddr == bindDevice.BindMacAddr && obj.DeviceEpoint == bindDevice.BindEpoint);
                             if (tempDev != null)
                             {
-                                var deviceUi = Common.LocalDevice.Current.GetDeviceUI(tempDev);
-                                devicePic.UnSelectedImagePath = deviceUi.IconPath;
-                                devicePic.Width = Application.GetRealWidth(110);
-                                devicePic.Text = "";
-                                if (tempDev.DeviceEpointName == "")
+                                //鑾峰彇璁惧鎵�灞炴埧闂�
+                                var tempDevRoom = Common.Room.CurrentRoom.GetRoomByDevice(tempDev);
+
+                                if (tempDevRoom != null)
                                 {
-                                    btnBindName.Text = tempDev.DeviceEpoint + Language.StringByID(R.MyInternationalizationString.uDeviceCircuit);
+                                    var tempDevFloorId = tempDevRoom.FloorId;
+                                    //鑾峰彇鎴块棿鐨勫悕瀛�
+                                    var tempDevRoomName = tempDevRoom.Name;
+                                    //鑾峰彇妤煎眰鐨勫悕瀛�
+                                    var tempDevFloorName = Common.Config.Instance.Home.GetFloorNameById(tempDevFloorId);
+                                    if (string.IsNullOrEmpty(tempDevFloorName))
+                                    {
+                                        btnFloorRoomNameText = tempDevRoomName;
+                                    }
+                                    else
+                                    {
+                                        btnFloorRoomNameText = tempDevFloorName + "," + tempDevRoomName;
+                                    }
+                                }
+                                var deviceUi = Common.LocalDevice.Current.GetDeviceUI(tempDev);
+                                if (deviceUi != null)
+                                {
+                                    devicePic.UnSelectedImagePath = deviceUi.IconPath;
+                                    devicePic.Width = Application.GetRealWidth(110);
+                                    devicePic.Text = "";
+                                }
+                                if (string.IsNullOrEmpty(tempDev.DeviceEpointName))
+                                {
+                                    btnBindNameText = tempDev.DeviceEpoint + Language.StringByID(R.MyInternationalizationString.uDeviceCircuit);
                                 }
                                 else
                                 {
-                                    btnBindName.Text = tempDev.DeviceEpointName;
+                                    btnBindNameText = tempDev.DeviceEpointName;
                                 }
                             }
                             else
                             {
-                                btnBindName.Text = bindDevice.BindMacAddr + "_" + bindDevice.BindEpoint;
+                                btnBindNameText = bindDevice.BindMacAddr + "_" + bindDevice.BindEpoint;
                                 devicePic.Width = Application.GetMinRealAverage(200);
                                 devicePic.TextAlignment = TextAlignment.CenterLeft;
                                 devicePic.TextColor = UserCenterColor.Current.Gray;
@@ -429,14 +507,19 @@
                         }
                     }
 
-                    //鍒犻櫎浜嬩欢澶勭悊
-                    btnDel.MouseUpEventHandler += async (sender, e) =>
+                    var btnBindName = rowLayout.frameTable.AddTopView(btnBindNameText, 800);
+                    var btnFloorRoomName = rowLayout.frameTable.AddBottomView(btnFloorRoomNameText, 800);
+                    rowLayout.frameTable.AddBottomLine();
+                    var btnDel = rowLayout.AddDeleteControl();
+                    btnDel.ButtonClickEvent += async (sender, e) =>
                     {
                         RemoveTargets(bindDevice, btnDel);
                     };
                     #endregion
                 }
+                midVerticalRefreshLayout.AdjustTableHeight(Application.GetRealHeight(23));
             }
+            #endregion
         }
 
         /// <summary>
@@ -444,159 +527,132 @@
         /// </summary>
         public void BindModeDisplay()
         {
-            var modeRowLayout = new RowLayout()
-            {
-                Height = Application.GetRealHeight(170),
-            };
-            topMidVerticalScrolViewLayout.AddChidren(modeRowLayout);
-
-            var btnKeyMode = new Button
-            {
-                X = Application.GetRealWidth(58),
-                Y = Application.GetRealHeight(63),
-                Width = Application.GetMinRealAverage(300),
-                Height = Application.GetMinRealAverage(58),
-                Text = Language.StringByID(R.MyInternationalizationString.keyMode),
-                TextColor = Shared.Common.ZigbeeColor.Current.XMBlack,
-            };
-            modeRowLayout.AddChidren(btnKeyMode);
-
-            var btnKeyModeTip = new Button
-            {
-                X = Application.GetRealWidth(1080 - 55 - 651),
-                Y = Application.GetRealHeight(63),
-                Width = Application.GetMinRealAverage(651),
-                Height = Application.GetMinRealAverage(58),
-                TextAlignment = TextAlignment.CenterRight,
-                TextColor = Shared.Common.ZigbeeColor.Current.XMGray3,
-            };
-            modeRowLayout.AddChidren(btnKeyModeTip);
-
-            var btnDel = new Button()
-            {
-                TextColor = Shared.Common.ZigbeeColor.Current.GXCTextWhiteColor,
-                TextID = R.MyInternationalizationString.DelBindDevice,
-                BackgroundColor = Shared.Common.ZigbeeColor.Current.DelRowLayout,
-            };
-            modeRowLayout.AddRightView(btnDel);
-
+            var modeRowLayout = new RowLayoutControl(midVerticalRefreshLayout.rowSpace / 2);
+            modeRowLayout.BackgroundColor = ZigbeeColor.Current.XMWhite;
+            midVerticalRefreshLayout.AddChidrenRow(modeRowLayout);
+            modeRowLayout.frameTable.UseClickStatu = false;
+            modeRowLayout.frameTable.AddLeftCaption(Language.StringByID(R.MyInternationalizationString.keyMode), 400);
+            var btnKeyModeTipText = "";
+            #region 褰撳墠妯″紡鏂囨湰鏄剧ず
             switch (currentKey.panelMode)
             {
                 case 100:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.OnOffOn;
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.OnOffOn);
                     break;
                 case 101:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.OnOffoFF;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.OnOffoFF);
                     break;
                 case 102:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.OnOffOnOff;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.OnOffOnOff);
                     break;
                 case 200:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.DimmerMode1;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.DimmerMode1);
                     break;
                 case 201:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.DimmerMode2;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.DimmerMode2);
                     break;
                 case 203:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.DimmerMode3;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.DimmerMode3);
                     break;
                 case 204:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.DimmerMode4;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.DimmerMode4);
                     break;
                 case 205:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.DimmerMode5;
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.DimmerMode5);
                     break;
                 case 300:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.WcdUp;
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.WcdUp);
                     break;
                 case 301:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.WcdDown;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.WcdDown);
                     break;
                 case 302:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.WcdStop;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.WcdStop);
                     break;
                 case 303:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.WcdUpStop;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.WcdUpStop);
                     break;
                 case 304:
-                    btnKeyModeTip.TextID = R.MyInternationalizationString.WcdDownStop;
-
+                    btnKeyModeTipText = Language.StringByID(R.MyInternationalizationString.WcdDownStop);
                     break;
             }
-
-            btnDel.MouseUpEventHandler += async (sender, e) =>
+            #endregion
+            modeRowLayout.frameTable.AddMostRightView(btnKeyModeTipText, 800);
+            modeRowLayout.frameTable.AddBottomLine();
+            var btnDel = modeRowLayout.AddDeleteControl();
+            //涓�閿竻闄ゆ寜閿簨浠�
+            btnDel.ButtonClickEvent += async (sender, e) =>
             {
-                bool isDelSuccess = false;
-                try
-                {
-                    CommonPage.Loading.Start("");
-                    var bindResult = await currentKey.ClearBindInfoAsync();
-                    if (bindResult.clearBindInfoResponseData != null)
-                    {
-                        if (bindResult.clearBindInfoResponseData.Result != 0)
-                        {
-                            new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.RemoveFailed), Direction = AMPopTipDirection.Up, CloseTime = 1 }.Show(btnDel);
-                            CommonPage.Loading.Hide();
-                            return;
-                        }
-                        else
-                        {
-                            var temp = await currentKey.ConfigureHdlKeyValueAsync(Panel.KeyMode.Default);
-                            if (temp.setWritableValueResponData?.Status != 0)
-                            {
-                                var temp1 = await currentKey.ConfigureHdlKeyValueAsync(Panel.KeyMode.Default);
-                                if (temp1.setWritableValueResponData?.Status != 0)
-                                {
-                                    new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.ChangeBindMode), Direction = AMPopTipDirection.Up, CloseTime = 2 }.Show(btnDel);
-                                }
-                                else
-                                {
-                                    isDelSuccess = true;
-                                }
-                            }
-                            else
-                            {
-                                isDelSuccess = true;
-                            }
-                        }
-                    }
-                }
-                catch { }
-                finally
-                {
-                    if (isDelSuccess)
-                    {
-                        currentKey.panelMode = 65535;
-                        currentKey.bindList.Clear();
-                        RefreshList();
-                        //濡傛灉鏄満鏅紝鐢ㄦ埛鍒犻櫎娓呯┖褰撳墠鍒版埧闂村垪琛�
-                        currentKey.RoomId = "";
-                        currentKey.ReSave();
-                    }
-                    CommonPage.Loading.Hide();
-                }
-
+                string msg = Language.StringByID(R.MyInternationalizationString.ClearAllTargets).Replace("{0}", "\r\n");
+                var alert = new Shared.Phone.UserCenter.ShowMsgControl(ShowMsgType.Confirm, msg, Language.StringByID(R.MyInternationalizationString.DoorlockConfirm));
+                alert.Show();
+                //浣跨敤纭鍨嬪脊妗嗘椂,鐨勫洖璋冨嚱鏁�
+                alert.ConfirmClickEvent += async () =>
+                 {
+                     bool isDelSuccess = false;
+                     try
+                     {
+                         CommonPage.Loading.Start("");
+                         var bindResult = await currentKey.ClearBindInfoAsync();
+                         if (bindResult != null && bindResult.clearBindInfoResponseData != null)
+                         {
+                             if (bindResult.clearBindInfoResponseData.Result != 0)
+                             {
+                                 new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.RemoveFailed), Direction = AMPopTipDirection.Up, CloseTime = 1 }.Show(btnDel);
+                                 CommonPage.Loading.Hide();
+                                 return;
+                             }
+                             else
+                             {
+                                 var temp = await currentKey.ConfigureHdlKeyValueAsync(Panel.KeyMode.Default);
+                                 if (temp.setWritableValueResponData?.Status != 0)
+                                 {
+                                     var temp1 = await currentKey.ConfigureHdlKeyValueAsync(Panel.KeyMode.Default);
+                                     if (temp1.setWritableValueResponData?.Status != 0)
+                                     {
+                                         new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.ChangeBindMode), Direction = AMPopTipDirection.Up, CloseTime = 2 }.Show(btnDel);
+                                     }
+                                     else
+                                     {
+                                         isDelSuccess = true;
+                                     }
+                                 }
+                                 else
+                                 {
+                                     isDelSuccess = true;
+                                 }
+                             }
+                         }
+                         else
+                         {
+                             new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime), Direction = AMPopTipDirection.Up, CloseTime = 2 }.Show(btnDel);
+                         }
+                     }
+                     catch { }
+                     finally
+                     {
+                         if (isDelSuccess)
+                         {
+                             currentKey.panelMode = 65535;
+                             currentKey.bindList.Clear();
+                             RefreshList();
+                             //濡傛灉鏄満鏅紝鐢ㄦ埛鍒犻櫎娓呯┖褰撳墠鍒版埧闂村垪琛�
+                             currentKey.RoomId = "";
+                             currentKey.ReSave();
+                         }
+                         CommonPage.Loading.Hide();
+                     }
+                 };
             };
         }
 
         /// <summary>
         /// 渚ц竟瀵艰埅鏍�
         /// </summary>
-        void SideslipFramelayout()
+        async void SideslipFramelayout()
         {
             #region UI
-            var dialog = new Dialog
-            {
-            };
+            var dialog = new Dialog { };
             dialog.Show();
 
             var flMain = new FrameLayout { BackgroundColor = 0x00000000 };
@@ -624,11 +680,33 @@
             sidelipFrameLayout.AddChidren(sidelipVerticalScrolViewLayout);
             #endregion
 
-            #region  rowView
             Button oldbuttonText = null;
             string oldKeySelectModeText = currentKey.currentKeySelectModeText;
-            for (var i = 0; i < 4; i++)
+
+            if (typeModeList == null)
             {
+                //鍐嶆鍔ㄦ�佽幏鍙栨寜閿敮鎸佺殑澶х被
+                CommonPage.Loading.Start();
+                typeModeList = await GetTypeMode();
+                if (typeModeList == null)
+                {
+                    Application.RunOnMainThread(() =>
+                    {
+                        new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime), Direction = AMPopTipDirection.None, CloseTime = 1 }.Show(Common.CommonPage.Instance);
+                    });
+                    CommonPage.Loading.Hide();
+                    dialog.Close();
+                    return;
+                }
+                else
+                {
+                    CommonPage.Loading.Hide();
+                }
+            }
+
+            foreach (var value in typeModeList)
+            {
+                #region  rowView
                 var rowView = new FrameLayout()
                 {
                     Height = Application.GetRealHeight(150),
@@ -643,6 +721,7 @@
                     Y = Application.GetRealHeight(69),
                     TextColor = Shared.Common.ZigbeeColor.Current.XMGray3,
                     TextSize = 14,
+                    IsBold = false,
                     TextAlignment = TextAlignment.CenterLeft,
                 };
                 rowView.AddChidren(btnMethodText);
@@ -657,321 +736,363 @@
                 };
                 rowView.AddChidren(line2);
 
-                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddScene) && i == 0)
+                if (string.IsNullOrEmpty(currentKey.currentKeySelectModeText) && value == 1)
                 {
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
                     oldbuttonText = btnMethodText;
                 }
-                else if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddSwitch) && i == 1)
+                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddScene) && value == 1)
                 {
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
                     oldbuttonText = btnMethodText;
                 }
-                else if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddDimmer) && i == 2)
+                else if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddSwitch) && value == 100)
                 {
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
                     oldbuttonText = btnMethodText;
                 }
-                else if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddCurtain) && i == 3)
+                else if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddDimmer) && value == 200)
                 {
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
+                    oldbuttonText = btnMethodText;
+                }
+                else if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddCurtain) && value == 300)
+                {
+                    btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
                     oldbuttonText = btnMethodText;
                 }
                 #endregion
 
-                EventHandler<MouseEventArgs> eHandler = (sender, e) =>
-               {
-                   if (!btnMethodText.IsSelected)
-                   {
-                       if (oldbuttonText != null)
-                       {
-                           oldbuttonText.TextColor = Shared.Common.ZigbeeColor.Current.XMGray3;
-                       }
-                       oldbuttonText = btnMethodText;
-                       currentKey.currentKeySelectModeText = btnMethodText.Text;
-                       oldbuttonText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
-                   }
-                   if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddScene))
-                   {
-                       if (currentKey.bindList.Count != 0)
-                       {
-                           var bindSc = currentKey.bindList.Find(obj => (obj.BindType == 2));
-                           if (bindSc != null)
-                           {
-                               var alert = new Alert(Language.StringByID(R.MyInternationalizationString.Tip), Language.StringByID(R.MyInternationalizationString.DelLocalBindListThenAddAgain),
-                                                             Language.StringByID(R.MyInternationalizationString.Cancel), Language.StringByID(R.MyInternationalizationString.Confrim));
-                               alert.Show();
-
-                               alert.ResultEventHandler += async (s1, e1) =>
-                               {
-                                   if (e1)
-                                   {
-                                       var result = await RemoveTargets(bindSc, line2);
-                                       if (result == 0)
-                                       {
-                                           var addScenePage = new Shared.Phone.UserCenter.DeviceBind.AddScenePage(currentKey);
-                                           Shared.Phone.UserView.HomePage.Instance.AddChidren(addScenePage);
-                                           Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                                           addScenePage.Show();
-
-                                           Action<List<BindListResponseObj>> action = (obj) =>
-                                           {
-                                               currentKey.bindList = obj;
-                                               RefreshList();
-                                           };
-                                           addScenePage.action += action;
-                                           dialog.Close();
-                                       }
-                                       else
-                                       {
-                                           currentKey.currentKeySelectModeText = oldKeySelectModeText;
-                                           dialog.Close();
-                                       }
-                                   }
-                                   else
-                                   {
-                                       currentKey.currentKeySelectModeText = oldKeySelectModeText;
-                                       dialog.Close();
-                                   }
-                               };
-                           }
-                       }
-                       else
-                       {
-                           var addScenePage = new Shared.Phone.UserCenter.DeviceBind.AddScenePage(currentKey);
-                           Shared.Phone.UserView.HomePage.Instance.AddChidren(addScenePage);
-                           Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                           addScenePage.Show();
-
-                           Action<List<BindListResponseObj>> action = (obj) =>
-                           {
-                               currentKey.bindList = obj;
-                               RefreshList();
-                           };
-                           addScenePage.action += action;
-                           dialog.Close();
-                       }
-                   }
-                   if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddSwitch))
-                   {
-                       if (currentKey.bindList.Count != 0)
-                       {
-                           var bindSc = currentKey.bindList.Find(obj => (obj.BindType == 2));
-                           if (bindSc != null)
-                           {
-                               var alert = new Alert(Language.StringByID(R.MyInternationalizationString.Tip), Language.StringByID(R.MyInternationalizationString.DelLocalBindListThenAddAgain1),
-                                                             Language.StringByID(R.MyInternationalizationString.Cancel), Language.StringByID(R.MyInternationalizationString.Confrim));
-                               alert.Show();
-
-                               alert.ResultEventHandler += async (s1, e1) =>
-                               {
-                                   if (e1)
-                                   {
-                                       var result = await RemoveTargets(bindSc, line2);
-                                       if (result == 0)
-                                       {
-                                           var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddSwitch");
-                                           Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
-                                           Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                                           addDevicePage.Show();
-
-                                           Action<List<BindListResponseObj>> action = (obj) =>
-                                           {
-                                               currentKey.bindList = obj;
-                                               RefreshList();
-                                           };
-                                           addDevicePage.actionAddDevicePage += action;
-                                           dialog.Close();
-                                       }
-                                       else
-                                       {
-                                           currentKey.currentKeySelectModeText = oldKeySelectModeText;
-                                           dialog.Close();
-                                       }
-                                   }
-                                   else
-                                   {
-                                       currentKey.currentKeySelectModeText = oldKeySelectModeText;
-                                       dialog.Close();
-                                   }
-                               };
-                           }
-                       }
-                       else
-                       {
-                           var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddSwitch");
-                           Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
-                           Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                           addDevicePage.Show();
-
-                           Action<List<BindListResponseObj>> action = (obj) =>
-                           {
-                               currentKey.bindList = obj;
-                               RefreshList();
-                           };
-                           addDevicePage.actionAddDevicePage += action;
-                           dialog.Close();
-                       }
-                   }
-                   if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddDimmer))
-                   {
-                       if (currentKey.bindList.Count != 0)
-                       {
-                           var bindSc = currentKey.bindList.Find(obj => (obj.BindType == 2));
-                           if (bindSc != null)
-                           {
-                               var alert = new Alert(Language.StringByID(R.MyInternationalizationString.Tip), Language.StringByID(R.MyInternationalizationString.DelLocalBindListThenAddAgain2),
-                                                          Language.StringByID(R.MyInternationalizationString.Cancel), Language.StringByID(R.MyInternationalizationString.Confrim));
-                               alert.Show();
-
-                               alert.ResultEventHandler += async (s1, e1) =>
-                               {
-                                   if (e1)
-                                   {
-                                       var result = await RemoveTargets(bindSc, line2);
-                                       if (result == 0)
-                                       {
-                                           var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddDimmer");
-                                           Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
-                                           Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                                           addDevicePage.Show();
-
-                                           Action<List<BindListResponseObj>> action = (obj) =>
-                                           {
-                                               currentKey.bindList = obj;
-                                               RefreshList();
-                                           };
-                                           addDevicePage.actionAddDevicePage += action;
-                                           dialog.Close();
-                                       }
-                                       else
-                                       {
-                                           currentKey.currentKeySelectModeText = oldKeySelectModeText;
-                                           dialog.Close();
-                                       }
-                                   }
-                                   else
-                                   {
-                                       currentKey.currentKeySelectModeText = oldKeySelectModeText;
-                                       dialog.Close();
-                                   }
-                               };
-                           }
-                       }
-                       else
-                       {
-                           var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddDimmer");
-                           Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
-                           Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                           addDevicePage.Show();
-
-                           Action<List<BindListResponseObj>> action = (obj) =>
-                           {
-                               currentKey.bindList = obj;
-                               RefreshList();
-                           };
-                           addDevicePage.actionAddDevicePage += action;
-                           dialog.Close();
-                       }
-
-
-                   }
-                   if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddCurtain))
-                   {
-                       if (currentKey.bindList.Count != 0)
-                       {
-                           var bindSc = currentKey.bindList.Find(obj => (obj.BindType == 2));
-                           if (bindSc != null)
-                           {
-                               var alert = new Alert(Language.StringByID(R.MyInternationalizationString.Tip), Language.StringByID(R.MyInternationalizationString.DelLocalBindListThenAddAgain3),
-                                                                                         Language.StringByID(R.MyInternationalizationString.Cancel), Language.StringByID(R.MyInternationalizationString.Confrim));
-                               alert.Show();
-
-                               alert.ResultEventHandler += async (s1, e1) =>
-                               {
-                                   if (e1)
-                                   {
-                                       var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddCurtain");
-                                       Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
-                                       Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                                       addDevicePage.Show();
-
-                                       Action<List<BindListResponseObj>> action = (obj) =>
-                                       {
-                                           currentKey.bindList = obj;
-                                           RefreshList();
-                                       };
-                                       addDevicePage.actionAddDevicePage += action;
-                                       dialog.Close();
-                                   }
-                                   else
-                                   {
-                                       currentKey.currentKeySelectModeText = oldKeySelectModeText;
-                                       dialog.Close();
-                                   }
-                               };
-                           }
-                       }
-                       else
-                       {
-                           var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddCurtain");
-                           Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
-                           Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                           addDevicePage.Show();
-
-                           Action<List<BindListResponseObj>> action = (obj) =>
-                           {
-                               currentKey.bindList = obj;
-                               RefreshList();
-                           };
-                           addDevicePage.actionAddDevicePage += action;
-                           dialog.Close();
-                       }
-                   }
-               };
-                btnMethodText.MouseUpEventHandler += eHandler;
-                rowView.MouseUpEventHandler += eHandler;
-
-                switch (i)
+                #region 鏁版嵁澶勭悊
+                switch (value)
                 {
-                    case 0:
+                    case 1:
                         btnMethodText.Text = Language.StringByID(R.MyInternationalizationString.AddScene);
                         break;
-                    case 1:
+                    case 100:
                         btnMethodText.Text = Language.StringByID(R.MyInternationalizationString.AddSwitch);
                         break;
-                    case 2:
+                    case 200:
                         btnMethodText.Text = Language.StringByID(R.MyInternationalizationString.AddDimmer);
                         break;
-                    case 3:
+                    case 300:
                         btnMethodText.Text = Language.StringByID(R.MyInternationalizationString.AddCurtain);
+                        line2.Visible = false;
                         break;
                 }
 
-                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddScene) && i == 0)
+                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddScene) && value == 1)
                 {
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
                     oldbuttonText = btnMethodText;
                 }
-                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddSwitch) && i == 1)
+                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddSwitch) && value == 100)
                 {
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
                     oldbuttonText = btnMethodText;
                 }
-                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddDimmer) && i == 2)
+                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddDimmer) && value == 200)
                 {
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
                     oldbuttonText = btnMethodText;
                 }
-                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddCurtain) && i == 3)
+                if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddCurtain) && value == 300)
                 {
                     btnMethodText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    btnMethodText.IsBold = true;
                     oldbuttonText = btnMethodText;
                 }
+                #endregion
+
+                //绫诲瀷浜嬩欢閫変腑澶勭悊
+                EventHandler<MouseEventArgs> eHandler = (sender, e) =>
+                {
+                    if (!btnMethodText.IsSelected)
+                    {
+                        if (oldbuttonText != null)
+                        {
+                            oldbuttonText.TextColor = Shared.Common.ZigbeeColor.Current.XMGray3;
+                        }
+                        oldbuttonText = btnMethodText;
+                        currentKey.currentKeySelectModeText = btnMethodText.Text;
+                        oldbuttonText.TextColor = Shared.Common.ZigbeeColor.Current.XMBlack;
+                    }
+                    if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddScene))
+                    {
+                        if (currentKey.bindList.Count != 0)
+                        {
+                            var bindSc = currentKey.bindList.Find(obj => (obj.BindType == 2));
+                            if (bindSc != null)
+                            {
+                                string msg = Language.StringByID(R.MyInternationalizationString.DelLocalBindListThenAddAgain);
+                                var alert = new Shared.Phone.UserCenter.ShowMsgControl(ShowMsgType.Confirm, msg, Language.StringByID(R.MyInternationalizationString.DoorlockConfirm));
+                                alert.Show();
+                                //浣跨敤纭鍨嬪脊妗嗘椂,鐨勫洖璋冨嚱鏁�
+                                alert.ConfirmClickEvent += async () =>
+                                 {
+                                     var result = await RemoveTargets(bindSc, line2);
+                                     if (result == 0)
+                                     {
+                                         var addScenePage = new Shared.Phone.UserCenter.DeviceBind.AddScenePage(currentKey, gwScenesList);
+                                         Shared.Phone.UserView.HomePage.Instance.AddChidren(addScenePage);
+                                         Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                                         addScenePage.Show();
+
+                                         Action<List<BindListResponseObj>> action = (obj) =>
+                                         {
+                                             currentKey.bindList = obj;
+                                             RefreshList();
+                                         };
+                                         addScenePage.action += action;
+                                         dialog.Close();
+                                     }
+                                     else
+                                     {
+                                         currentKey.currentKeySelectModeText = oldKeySelectModeText;
+                                         dialog.Close();
+                                     }
+                                 };
+                            }
+                        }
+                        else
+                        {
+                            var addScenePage = new Shared.Phone.UserCenter.DeviceBind.AddScenePage(currentKey, gwScenesList);
+                            Shared.Phone.UserView.HomePage.Instance.AddChidren(addScenePage);
+                            Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                            addScenePage.Show();
+
+                            Action<List<BindListResponseObj>> action = (obj) =>
+                            {
+                                currentKey.bindList = obj;
+                                RefreshList();
+                            };
+                            addScenePage.action += action;
+                            dialog.Close();
+                        }
+                    }
+                    if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddSwitch))
+                    {
+                        if (currentKey.bindList.Count != 0)
+                        {
+                            var bindSc = currentKey.bindList.Find(obj => (obj.BindType == 2));
+                            if (bindSc != null)
+                            {
+                                string msg = Language.StringByID(R.MyInternationalizationString.DelLocalBindListThenAddAgain1);
+                                var alert = new Shared.Phone.UserCenter.ShowMsgControl(ShowMsgType.Confirm, msg, Language.StringByID(R.MyInternationalizationString.DoorlockConfirm));
+                                alert.Show();
+                                //浣跨敤纭鍨嬪脊妗嗘椂,鐨勫洖璋冨嚱鏁�
+                                alert.ConfirmClickEvent += async () =>
+                                 {
+                                     var result = await RemoveTargets(bindSc, line2);
+                                     if (result == 0)
+                                     {
+                                         var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddSwitch");
+                                         Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
+                                         Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                                         addDevicePage.Show();
+
+                                         Action<List<BindListResponseObj>> action = (obj) =>
+                                         {
+                                             currentKey.bindList = obj;
+                                             RefreshList();
+                                         };
+                                         addDevicePage.actionAddDevicePage += action;
+                                         dialog.Close();
+                                     }
+                                     else
+                                     {
+                                         currentKey.currentKeySelectModeText = oldKeySelectModeText;
+                                         dialog.Close();
+                                     }
+                                 };
+                            }
+                        }
+                        else
+                        {
+                            var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddSwitch");
+                            Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
+                            Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                            addDevicePage.Show();
+
+                            Action<List<BindListResponseObj>> action = (obj) =>
+                            {
+                                currentKey.bindList = obj;
+                                RefreshList();
+                            };
+                            addDevicePage.actionAddDevicePage += action;
+                            dialog.Close();
+                        }
+                    }
+                    if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddDimmer))
+                    {
+                        if (currentKey.bindList.Count != 0)
+                        {
+                            var bindSc = currentKey.bindList.Find(obj => (obj.BindType == 2));
+                            if (bindSc != null)
+                            {
+                                var dialog1 = new Dialog { };
+                                var doorDialog = new Shared.Phone.UserCenter.DoorLock.DoorlockDialog(dialog1, Language.StringByID(R.MyInternationalizationString.Tip));
+                                doorDialog.Show();
+                                doorDialog.dialogMidFraFrameLayout.Height = Application.GetRealHeight(58);
+                                doorDialog.dialogMidFraFrameLayout.X = Application.GetRealWidth(0);
+                                doorDialog.dialogMidFraFrameLayout.Y = Application.GetRealHeight(202);
+                                doorDialog.dialogMidFraFrameLayout.AddChidren(doorDialog.dialogMidText);
+                                doorDialog.dialogMidText.Text = Language.StringByID(R.MyInternationalizationString.DelLocalBindListThenAddAgain2);
+                                doorDialog.dialogMidFraFrameLayout.AddChidren(doorDialog.dialogMidText);
+                                doorDialog.dialogBtnConfirm.Text = Language.StringByID(R.MyInternationalizationString.DoorlockConfirm);
+                                doorDialog.dialogBtnCancel.MouseUpEventHandler += (sender1, e1) =>
+                                {
+                                    currentKey.currentKeySelectModeText = oldKeySelectModeText;
+                                    dialog.Close();
+                                    dialog1.Close();
+                                };
+                                doorDialog.dialogBtnConfirm.MouseUpEventHandler += async (sender1, e1) =>
+                                {
+                                    var result = await RemoveTargets(bindSc, line2);
+                                    if (result == 0)
+                                    {
+                                        var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddDimmer");
+                                        Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
+                                        Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                                        addDevicePage.Show();
+
+                                        Action<List<BindListResponseObj>> action = (obj) =>
+                                        {
+                                            currentKey.bindList = obj;
+                                            RefreshList();
+                                        };
+                                        addDevicePage.actionAddDevicePage += action;
+                                        dialog.Close();
+                                        dialog1.Close();
+                                    }
+                                    else
+                                    {
+                                        currentKey.currentKeySelectModeText = oldKeySelectModeText;
+                                        dialog.Close();
+                                        dialog1.Close();
+                                    }
+
+                                };
+                            }
+                        }
+                        else
+                        {
+                            var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddDimmer");
+                            Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
+                            Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                            addDevicePage.Show();
+
+                            Action<List<BindListResponseObj>> action = (obj) =>
+                            {
+                                currentKey.bindList = obj;
+                                RefreshList();
+                            };
+                            addDevicePage.actionAddDevicePage += action;
+                            dialog.Close();
+                        }
+                    }
+                    if (currentKey.currentKeySelectModeText == Language.StringByID(R.MyInternationalizationString.AddCurtain))
+                    {
+                        if (currentKey.bindList.Count != 0)
+                        {
+                            var bindSc = currentKey.bindList.Find(obj => (obj.BindType == 2));
+                            if (bindSc != null)
+                            {
+                                var dialog1 = new Dialog { };
+                                var doorDialog = new Shared.Phone.UserCenter.DoorLock.DoorlockDialog(dialog1, Language.StringByID(R.MyInternationalizationString.Tip));
+                                doorDialog.Show();
+                                doorDialog.dialogMidFraFrameLayout.Height = Application.GetRealHeight(58);
+                                doorDialog.dialogMidFraFrameLayout.X = Application.GetRealWidth(0);
+                                doorDialog.dialogMidFraFrameLayout.Y = Application.GetRealHeight(202);
+                                doorDialog.dialogMidFraFrameLayout.AddChidren(doorDialog.dialogMidText);
+                                doorDialog.dialogMidText.Text = Language.StringByID(R.MyInternationalizationString.DelLocalBindListThenAddAgain3);
+                                doorDialog.dialogMidFraFrameLayout.AddChidren(doorDialog.dialogMidText);
+                                doorDialog.dialogBtnConfirm.Text = Language.StringByID(R.MyInternationalizationString.DoorlockConfirm);
+                                doorDialog.dialogBtnCancel.MouseUpEventHandler += (sender1, e1) =>
+                                {
+                                    currentKey.currentKeySelectModeText = oldKeySelectModeText;
+                                    dialog.Close();
+                                    dialog1.Close();
+                                };
+                                doorDialog.dialogBtnConfirm.MouseUpEventHandler += async (sender1, e1) =>
+                                {
+                                    var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddCurtain");
+                                    Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
+                                    Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                                    addDevicePage.Show();
+
+                                    Action<List<BindListResponseObj>> action = (obj) =>
+                                    {
+                                        currentKey.bindList = obj;
+                                        RefreshList();
+                                    };
+                                    addDevicePage.actionAddDevicePage += action;
+                                    dialog.Close();
+                                    dialog1.Close();
+                                };
+                            }
+                        }
+                        else
+                        {
+                            var addDevicePage = new Shared.Phone.UserCenter.DeviceBind.AddDevicePage(currentKey, "AddCurtain");
+                            Shared.Phone.UserView.HomePage.Instance.AddChidren(addDevicePage);
+                            Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
+                            addDevicePage.Show();
+
+                            Action<List<BindListResponseObj>> action = (obj) =>
+                            {
+                                currentKey.bindList = obj;
+                                RefreshList();
+                            };
+                            addDevicePage.actionAddDevicePage += action;
+                            dialog.Close();
+                        }
+                    }
+                };
+                btnMethodText.MouseUpEventHandler += eHandler;
+                rowView.MouseUpEventHandler += eHandler;
             }
         }
 
-        async System.Threading.Tasks.Task<int> RemoveTargets(BindListResponseObj bindDevice, Button btnDel)
+        //鑾峰彇鎸夐敭鏀寔鐨勫ぇ绫�
+        private async System.Threading.Tasks.Task<List<int>> GetTypeMode()
+        {
+            if (typeModeList != null)
+            {
+                typeModeList.Clear();
+            }
+            if (currentKey.privateFuncSecondLevelList.Count == 0 || currentKey.privateFuncSecondLevelList.Contains(1) == false || currentKey.privateFuncSecondLevelList.Contains(100) == false || currentKey.privateFuncSecondLevelList.Contains(200) == false || currentKey.privateFuncSecondLevelList.Contains(300) == false)
+            {
+                //鑾峰彇绗簩绾у姛鑳�
+                typeModeList = await currentKey.GetPanelDeviceFunctionLevel2(256);
+                if (typeModeList == null)
+                {
+                    return null;
+                }
+                currentKey.privateFuncSecondLevelList = typeModeList;
+            }
+            else
+            {
+                typeModeList = currentKey.privateFuncSecondLevelList;
+            }
+            return typeModeList;
+        }
+
+        /// <summary>
+        /// 鍒犻櫎褰撳墠鐩爣鏂规硶
+        /// </summary>
+        /// <param name="bindDevice"></param>
+        /// <param name="btnDel"></param>
+        /// <returns></returns>
+        private async System.Threading.Tasks.Task<int> RemoveTargets(BindListResponseObj bindDevice, Button btnDel)
         {
             var delDevice = new DelDeviceBindData();
             delDevice.DeviceAddr = currentKey.DeviceAddr;
@@ -1000,98 +1121,107 @@
                 CommonPage.Loading.Start("");
                 var delResult = new DelDeviceBindResponseAllData();
                 delResult = await currentKey.DelDeviceBindAsync(delDevice);
-                if (delResult.delDeviceBindResponseData?.RemoveBindList != null)
+                if (delResult != null && delResult.delDeviceBindResponseData != null)
                 {
-                    foreach (var re in delResult.delDeviceBindResponseData.RemoveBindList)
+                    if (delResult.delDeviceBindResponseData?.RemoveBindList != null)
                     {
-                        switch (re.Result)
+                        foreach (var re in delResult.delDeviceBindResponseData.RemoveBindList)
                         {
-                            case 0:
-                                currentKey.bindList.Remove(bindDevice);
-                                RefreshList();
-                                //濡傛灉鏄満鏅紝鐢ㄦ埛鍒犻櫎娓呯┖褰撳墠鍒版埧闂村垪琛�
-                                currentKey.RoomId = "";
-                                currentKey.ReSave();
-                                return 0;
-                                break;
-                            case 1:
-                                currentKey.bindList.Clear();
-                                try
-                                {
-                                    CommonPage.Loading.Start("");
-
-                                    var getBindList = await currentKey.GetDeviceBindAsync();
-                                    var bindDeviceListTemp = new System.Collections.Generic.List<BindListResponseObj> { };
-                                    var bindSceneListTemp = new System.Collections.Generic.List<BindListResponseObj> { };
-                                    if (getBindList != null)
+                            switch (re.Result)
+                            {
+                                case 0:
+                                    currentKey.bindList.Remove(bindDevice);
+                                    RefreshList();
+                                    //濡傛灉鏄満鏅紝鐢ㄦ埛鍒犻櫎娓呯┖褰撳墠鍒版埧闂村垪琛�
+                                    if (re.BindType == 2)
                                     {
-                                        if (getBindList.getAllBindResponseData != null)
-                                        {
-                                            foreach (var b in getBindList.getAllBindResponseData.BindList)
-                                            {
-                                                if (b.BindCluster == currentClusterID)
-                                                {
-                                                    if (b.BindCluster == 6)
-                                                    {
+                                        currentKey.panelMode = 65535;
+                                    }
+                                    currentKey.RoomId = "";
+                                    currentKey.ReSave();
+                                    return 0;
+                                    break;
+                                case 1:
+                                    currentKey.bindList.Clear();
+                                    try
+                                    {
+                                        CommonPage.Loading.Start("");
 
-                                                        if (b.BindType == 2)
+                                        var getBindList = await currentKey.GetDeviceBindAsync();
+                                        var bindDeviceListTemp = new System.Collections.Generic.List<BindListResponseObj> { };
+                                        var bindSceneListTemp = new System.Collections.Generic.List<BindListResponseObj> { };
+                                        if (getBindList != null)
+                                        {
+                                            if (getBindList.getAllBindResponseData != null)
+                                            {
+                                                foreach (var b in getBindList.getAllBindResponseData.BindList)
+                                                {
+                                                    if (b.BindCluster == currentClusterID)
+                                                    {
+                                                        if (b.BindCluster == 6)
                                                         {
-                                                            bindSceneListTemp.Add(b);
+
+                                                            if (b.BindType == 2)
+                                                            {
+                                                                bindSceneListTemp.Add(b);
+                                                            }
+                                                            else
+                                                            {
+                                                                bindDeviceListTemp.Add(b);
+                                                            }
                                                         }
                                                         else
                                                         {
-                                                            bindDeviceListTemp.Add(b);
+                                                            currentKey.bindList.Add(b);
                                                         }
-                                                    }
-                                                    else
-                                                    {
-                                                        currentKey.bindList.Add(b);
                                                     }
                                                 }
                                             }
                                         }
+                                        if (currentKey.panelMode == 1)
+                                        {
+                                            currentKey.bindList = bindSceneListTemp;
+                                        }
+                                        else if (currentKey.panelMode == 100 || currentKey.panelMode == 101 || currentKey.panelMode == 102)
+                                        {
+                                            currentKey.bindList = bindDeviceListTemp;
+                                        }
                                     }
-                                    if (currentKey.panelMode == 1)
+                                    catch { }
+                                    finally
                                     {
-                                        currentKey.bindList = bindSceneListTemp;
-                                    }
-                                    else if (currentKey.panelMode == 100 || currentKey.panelMode == 101 || currentKey.panelMode == 102)
-                                    {
-                                        currentKey.bindList = bindDeviceListTemp;
-                                    }
-                                }
-                                catch { }
-                                finally
-                                {
-                                    RefreshList();
-                                    CommonPage.Loading.Hide();
-                                }
-                                break;
-                            case 4:
-
-                                if (delResult.removeBindResultResponseData != null)
-                                {
-
-                                    if (delResult.removeBindResultResponseData.Result == 0)
-                                    {
-                                        currentKey.bindList.Remove(bindDevice);
                                         RefreshList();
-                                        return 0;
+                                        CommonPage.Loading.Hide();
                                     }
-                                    else
+                                    break;
+                                case 2:
+                                    if (delResult.removeBindResultResponseData != null)
                                     {
-                                        new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.RemoveFailed), Direction = AMPopTipDirection.Up, CloseTime = 2 }.Show(btnDel);
+                                        if (delResult.removeBindResultResponseData.Result == 0)
+                                        {
+                                            currentKey.bindList.Remove(bindDevice);
+                                            RefreshList();
+                                            return 0;
+                                        }
+                                        else
+                                        {
+                                            new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.RemoveFailed), Direction = AMPopTipDirection.Up, CloseTime = 2 }.Show(btnDel);
+                                        }
                                     }
-                                }
-                                break;
-                            default:
-                                break;
+                                    break;
+                                default:
+                                    break;
+                            }
                         }
+                    }
+                    else
+                    {
+                        new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.RemoveFailed), Direction = AMPopTipDirection.Up, CloseTime = 2 }.Show(btnDel);
                     }
                 }
                 else
                 {
-                    new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.RemoveFailed), Direction = AMPopTipDirection.Up, CloseTime = 2 }.Show(btnDel);
+                    new Tip() { MaxWidth = 150, Text = Language.StringByID(R.MyInternationalizationString.GwResponseOvertime), Direction = AMPopTipDirection.None, CloseTime = 2 }.Show(CommonPage.Instance);
                 }
             }
             catch { }
@@ -1099,7 +1229,6 @@
             {
                 CommonPage.Loading.Hide();
             }
-
             return -1;
         }
 
@@ -1126,3 +1255,4 @@
         }
     }
 }
+

--
Gitblit v1.8.0