From b8cbf4a8b6910eefcb83b6d3a39e9b5b5a9cd79e Mon Sep 17 00:00:00 2001
From: gxc <guoxuecheng@guoxuechengdeMacBook-Pro.local>
Date: 星期五, 10 一月 2020 16:39:22 +0800
Subject: [PATCH] 2019.1.10

---
 ZigbeeApp/Shared/Phone/Device/Category/Category.cs |  586 ++++++++++++++++++++++++++++++++--------------------------
 1 files changed, 320 insertions(+), 266 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Category/Category.cs b/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
index 6660e7d..fca0186 100644
--- a/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
@@ -8,6 +8,7 @@
 using Shared.Phone.Device.AC;
 using Shared.Phone.UserCenter.DoorLock;
 using Shared.Phone.Device.DeviceLogic;
+using Shared.Phone.UserCenter;
 
 namespace Shared.Phone.Device.Category
 {
@@ -25,7 +26,7 @@
         /// <summary>
         /// low_High
         /// </summary>
-        private const int low_High= 127;
+        private const int low_High = 127;
         /// <summary>
         /// 鍔熻兘
         /// </summary>
@@ -258,7 +259,7 @@
                                         var attriButeList = common.DeviceStatusReport.AttriBute;
                                         var ac = deviceUI.CommonDevice as ZigBee.Device.AC;
                                         ac.DeviceStatusReport = common.DeviceStatusReport;
-                                        foreach(var attList in attriButeList)
+                                        foreach (var attList in attriButeList)
                                         {
                                             var curTemp = (attList.AttriButeData / 100 < ACControlBase.Temperature_High && attList.AttriButeData / 100 > ACControlBase.Temperature_Low) ? attList.AttriButeData / 100 : ACControlBase.Temperature_Default;
                                             switch (attList.AttributeId)
@@ -307,7 +308,7 @@
                                         var ac = deviceUI.CommonDevice as ZigBee.Device.AC;
                                         var attriButeList = common.DeviceStatusReport.AttriBute;
                                         ac.DeviceStatusReport = common.DeviceStatusReport;
-                                        foreach(var attList in attriButeList)
+                                        foreach (var attList in attriButeList)
                                         {
                                             switch (attList.AttributeId)
                                             {
@@ -575,7 +576,7 @@
                 TextID = R.MyInternationalizationString.Category,
                 TextSize = 24,
                 TextColor = ZigbeeColor.Current.GXCTextDeepBlackColor,
-                IsBold=true
+                IsBold = true
             };
             topView.AddChidren(title);
 
@@ -619,7 +620,7 @@
             functionBtn.SetTitle(R.MyInternationalizationString.Function);
             functionBtn.X = sceneBtn.Right;
             //鑷姩鍖�
-            automationBtn = new ButtonLineForm(CommonFormResouce.X_Left + 150 * 2 + 20+50, 34);
+            automationBtn = new ButtonLineForm(CommonFormResouce.X_Left + 150 * 2 + 20 + 50, 34);
             automationBtn.Init();
             automationBtn.SetTitle(R.MyInternationalizationString.Automation);
             automationBtn.X = functionBtn.Right;
@@ -637,8 +638,8 @@
                 Gravity = Gravity.CenterVertical,
                 TextAlignment = TextAlignment.CenterRight,
                 TextColor = ZigbeeColor.Current.GXCTextBlackColor,
-                TextSize=14,
-                IsBold=true
+                TextSize = 14,
+                IsBold = true
             };
 
             selectFloorBtn = new Button()
@@ -706,7 +707,7 @@
             addBtn.MouseUpEventHandler += AddBtn_MouseUpEventHandler;
 
             selectFloorBtn.MouseUpEventHandler += SelectedFloor_MouseUpEventHandler;
-            floorBtn.MouseUpEventHandler+= SelectedFloor_MouseUpEventHandler;
+            floorBtn.MouseUpEventHandler += SelectedFloor_MouseUpEventHandler;
 
         }
 
@@ -717,9 +718,9 @@
         /// <param name="mouseEventArgs">The ${ParameterType} instance containing the event data.</param>
         private void SelectedFloor_MouseUpEventHandler(object sender, MouseEventArgs mouseEventArgs)
         {
-            var floors = new SelectFloor ();
+            var floors = new SelectFloor();
             AddChidren(floors);
-            floors.Init(580,330,Direction.Right);
+            floors.Init(580, 330, Direction.Right);
             floors.changeFloor = true;
             floors.FloorAction += (floorId) =>
             {
@@ -763,11 +764,11 @@
         /// <param name="sender">Sender.</param>
         /// <param name="mouseEventArgs">The ${ParameterType} instance containing the event data.</param>
         private void AutomationBtn_MouseUpEventHandler(object sender, MouseEventArgs mouseEventArgs)
-        {
-            Common.Logic.LogicDviceList.Clear();
-            if (Common.Logic.LogicDviceList.Count == 0)
-            {
-                Common.Logic.LogicDviceList.AddRange(LocalDevice.Current.listAllDevice.ToArray());
+        {
+            Common.Logic.LogicDviceList.Clear();
+            if (Common.Logic.LogicDviceList.Count == 0)
+            {
+                Common.Logic.LogicDviceList.AddRange(LocalDevice.Current.listAllDevice.ToArray());
             }
             functionBtn.IsSelected = false;
             sceneBtn.IsSelected = false;
@@ -808,6 +809,10 @@
             UserView.HomePage.Instance.AddChidren(scene);
             UserView.HomePage.Instance.PageIndex += 1;
             scene.Show();
+            scene.AddAction = () =>
+            {
+                ShowScene();
+            };
         }
 
         /// <summary>
@@ -917,10 +922,10 @@
         {
             var noFunction = new Button()
             {
-                Y=Application.GetRealHeight(320),
-                Width=Application.GetMinRealAverage(757),
+                Y = Application.GetRealHeight(320),
+                Width = Application.GetMinRealAverage(757),
                 Height = Application.GetMinRealAverage(435),
-                UnSelectedImagePath="Item/NoFunction.png",
+                UnSelectedImagePath = "Item/NoFunction.png",
                 Gravity = Gravity.CenterHorizontal
             };
             functionSceneBodyView.AddChidren(noFunction);
@@ -931,10 +936,10 @@
                 Height = Application.GetRealHeight(200),
                 Width = Application.GetRealWidth(700),
                 Gravity = Gravity.CenterHorizontal,
-                Text = Language.StringByID(R.MyInternationalizationString.NoFunction).Replace("{\\r\\n}","\r\n"),
+                Text = Language.StringByID(R.MyInternationalizationString.NoFunction).Replace("{\\r\\n}", "\r\n"),
                 TextColor = ZigbeeColor.Current.GXCPlaceHolderTextColor,
                 TextAlignment = TextAlignment.Center,
-                IsMoreLines=true
+                IsMoreLines = true
             };
             functionSceneBodyView.AddChidren(noFunctionTip);
         }
@@ -988,7 +993,7 @@
                 deviceListScrolView = new VerticalScrolViewLayout
                 {
                     X = Application.GetRealWidth(CommonFormResouce.X_Left),
-                    Y = Application.GetRealHeight(35+279),
+                    Y = Application.GetRealHeight(35 + 279),
                     Width = Application.GetRealWidth(1028),
                     Height = Application.GetRealHeight(942),
                     BackgroundColor = ZigbeeColor.Current.GXCBackgroundColor
@@ -997,7 +1002,7 @@
                 deviceListScrolView.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft);
 
                 tempFunctionTypeBtn = new FunctionButton();
-                tempFunctionTypeBtn.Init("","");
+                tempFunctionTypeBtn.Init("", "");
 
                 foreach (var deviceType in typeIdDic)
                 {
@@ -1013,7 +1018,7 @@
                     };
                     string imgPath = string.Empty;
                     string imgSeletedPath = string.Empty;
-                    Common.LocalDevice.Current.GetDeviceBeloneIcon(deviceType.Value, ref imgPath, ref imgSeletedPath);
+                    Common.LocalDevice.Current.GetDeviceObjectIcon(deviceType.Value, ref imgPath, ref imgSeletedPath);
                     functionTypeIMG.Init(imgPath, imgSeletedPath);
                     functionTypeIMG.SetTitle(deviceType.Key);
                     typeRowLayout.AddChidren(functionTypeIMG);
@@ -1053,43 +1058,14 @@
                     {
                         try
                         {
-                            //鍒犻櫎璁惧
-                            EventHandler<MouseEventArgs> delEvent = (delSender, delE) =>
+                            var deviceTypeRowLayout = new RowLayout()
                             {
-                                var alert = new CustomAlert();
-                                AddChidren(alert);
-                                alert.Show(Language.StringByID(R.MyInternationalizationString.DeleteFunction));
-                                alert.ResultEventHandler += (e2) =>
-                                {
-                                    if (e2)
-                                    {
-                                        if(Common.Room.CurrentRoom.IsLove)
-                                        {
-                                            Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.FileName);
-                                            deviceListScrolView.RemoveViewByTag((delSender as Button).Tag);
-                                            sameTypeList.Remove(deviceUI);
-                                        }
-                                        else
-                                        {
-                                            Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.CommonDevice);
-                                            deviceListScrolView.RemoveViewByTag((delSender as Button).Tag);
-                                            sameTypeList.Remove(deviceUI);
-                                        }
-                                        //if (sameTypeList.Count == 0)
-                                        //{
-                                        //    RefreshBodyView();
-                                        //}
-                                    }
-                                };
+                                Height = Application.GetRealHeight(127 + 35),
+                                LineColor = ZigbeeColor.Current.GXCClearColor,
+                                Tag = deviceUI,
+                                SubViewWidth=Application.GetRealWidth(184)
                             };
-                            EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
-                            {
-                                var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
-                                UserView.HomePage.Instance.AddChidren(detailInfo);
-                                UserView.HomePage.Instance.PageIndex += 1;
-                                detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
-                                detailInfo.action = RefreshBodyView;
-                            };
+                            deviceListScrolView.AddChidren(deviceTypeRowLayout);
 
                             if (deviceUI.CommonDevice.Type == DeviceType.OnOffOutput)
                             {
@@ -1117,19 +1093,10 @@
                                         }
                                     })
                                     { IsBackground = true }.Start();
-
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
+                                    
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
                                     deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(light.IsOnline == 1);
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = light.OnOffStatus == 1;
                                     deviceTypeRowLayout.AddChidren(deviceRow);
@@ -1165,51 +1132,37 @@
                                             }
                                         });
                                     };
-
                                     deviceRow.ClickBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
-                                        if (deviceUI.CommonDevice.DfunctionType == DeviceFunctionType.A寮�鍏�)
+                                        var lightControl = new Phone.Device.Light.OnOffControl();
+                                        UserView.HomePage.Instance.AddChidren(lightControl);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        lightControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        lightControl.action += (curDev, curRoom) =>
                                         {
-                                            var lightControl = new Phone.Device.Light.OnOffControl();
-                                            UserView.HomePage.Instance.AddChidren(lightControl);
-                                            UserView.HomePage.Instance.PageIndex += 1;
-                                            //lightControl.action = RefreshBodyView;
-                                            lightControl.Show(deviceUI, Common.Room.CurrentRoom);
-                                        }
-                                        else if (deviceUI.CommonDevice.DfunctionType == DeviceFunctionType.A鎻掑骇)
-                                        {
-                                            var lightControl = new Phone.Device.Light.PlugControl();
-                                            UserView.HomePage.Instance.AddChidren(lightControl);
-                                            UserView.HomePage.Instance.PageIndex += 1;
-                                            //lightControl.action = RefreshBodyView;
-                                            lightControl.Show(deviceUI, Common.Room.CurrentRoom);
-                                        }
-                                        else
-                                        {
-                                            var lightControl = new Phone.Device.Light.LightControl();
-                                            UserView.HomePage.Instance.AddChidren(lightControl);
-                                            UserView.HomePage.Instance.PageIndex += 1;
-                                            //lightControl.action = RefreshBodyView;
-                                            lightControl.Show(deviceUI, Common.Room.CurrentRoom);
-                                        }
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
                                     };
 
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
+                                    };
                                     var editBtn = new CommonForm.RowLayoutEditButton()
                                     {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    var delBtn = new CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
+                                        Tag = deviceUI
                                     };
                                     if (Common.Room.CurrentRoom.IsSharedRoom == false)
                                     {
                                         deviceTypeRowLayout.AddRightView(editBtn);
                                         editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
                                     }
                                 }
                             }
@@ -1239,22 +1192,12 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
                                     deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(airSwitch.IsOnline == 1);
                                     deviceRow.IsSelected = airSwitch.OnOffStatus == 1;
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceTypeRowLayout.AddChidren(deviceRow);
-
                                     deviceRow.SwitchBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
                                         zbGateway = deviceUI.CommonDevice.Gateway;
@@ -1286,33 +1229,41 @@
                                             }
                                         });
                                     };
-
                                     deviceRow.ClickBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
 
                                         var lightControl = new Phone.Device.Light.AirSwitchControl();
                                         UserView.HomePage.Instance.AddChidren(lightControl);
                                         UserView.HomePage.Instance.PageIndex += 1;
-                                        //lightControl.action = RefreshBodyView;
                                         lightControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        lightControl.action += (curDev, curRoom) =>
+                                        {
+
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+
+                                        };
                                     };
 
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+
+                                        };
+                                    };
                                     var editBtn = new CommonForm.RowLayoutEditButton()
                                     {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    var delBtn = new CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
+                                        Tag = deviceUI
                                     };
                                     if (Common.Room.CurrentRoom.IsSharedRoom == false)
                                     {
                                         deviceTypeRowLayout.AddRightView(editBtn);
                                         editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
                                     }
                                 }
                             }
@@ -1342,18 +1293,9 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
                                     deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(dimmableLight.IsOnline == 1);
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = dimmableLight.OnOffStatus == 1;
                                     deviceTypeRowLayout.AddChidren(deviceRow);
@@ -1396,26 +1338,33 @@
                                         UserView.HomePage.Instance.AddChidren(dimmableLightControl);
                                         UserView.HomePage.Instance.PageIndex += 1;
                                         UserView.HomePage.Instance.ScrollEnabled = false;
-                                        //dimmableLightControl.action = RefreshBodyView;
                                         dimmableLightControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        dimmableLightControl.action += (curDev, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
+
                                     };
 
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
+                                    };
                                     var editBtn = new CommonForm.RowLayoutEditButton()
                                     {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
+                                        Tag = deviceUI
                                     };
                                     if (Common.Room.CurrentRoom.IsSharedRoom == false)
                                     {
                                         deviceTypeRowLayout.AddRightView(editBtn);
                                         editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
                                     }
                                 }
                             }
@@ -1447,18 +1396,9 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
                                     deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(ac.IsOnline == 1);
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = ac.currentSystemMode != 1;
                                     deviceTypeRowLayout.AddChidren(deviceRow);
@@ -1495,34 +1435,41 @@
                                             }
                                         });
                                     };
-
-                                    var editBtn = new CommonForm.RowLayoutEditButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    var delBtn = new CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                        Radius = 0
-                                    };
-                                    if (Common.Room.CurrentRoom.IsSharedRoom == false)
-                                    {
-                                        deviceTypeRowLayout.AddRightView(editBtn);
-                                        editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
-                                    }
-
                                     deviceRow.ClickBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
                                         var acControl = new Phone.Device.AC.ACControl();
                                         UserView.HomePage.Instance.AddChidren(acControl);
                                         UserView.HomePage.Instance.PageIndex += 1;
                                         UserView.HomePage.Instance.ScrollEnabled = false;
-                                        //rollerShadeControl.action = RefreshBodyView;
                                         acControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        acControl.action += (curDev, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+
+                                        };
                                     };
+
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+
+                                        };
+                                    };
+                                    var editBtn = new CommonForm.RowLayoutEditButton()
+                                    {
+                                        Tag = deviceUI
+                                    };
+                                    if (Common.Room.CurrentRoom.IsSharedRoom == false)
+                                    {
+                                        deviceTypeRowLayout.AddRightView(editBtn);
+                                        editBtn.MouseUpEventHandler += deviceDetailHandler;
+                                    }
                                 }
                             }
                             else if (deviceUI.CommonDevice.Type == DeviceType.WindowCoveringDevice)
@@ -1552,18 +1499,9 @@
                                     })
                                     { IsBackground = true }.Start();
 
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                     var deviceRow = new CategoryFunctionForWinRow(0, 35);
                                     deviceRow.Init(deviceUI);
                                     deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                    //deviceRow.SetOnLineStatu(rollerShade.IsOnline == 1);
                                     deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                     deviceRow.IsSelected = rollerShade.WcdCurrentPositionLiftPercentage != 0;
                                     deviceRow.SetRollerShadeIcon(rollerShade.WcdType);
@@ -1586,47 +1524,46 @@
                                         { IsBackground = true }.Start();
                                     }
 
-                                    var editBtn = new CommonForm.RowLayoutEditButton()
-                                    {
-                                        Tag = deviceUI,
-                                    };
-                                    var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
-                                    {
-                                        Tag = deviceUI,
-                                    };
-                                    if (Common.Room.CurrentRoom.IsSharedRoom == false)
-                                    {
-                                        deviceTypeRowLayout.AddRightView(editBtn);
-                                        editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
-                                    }
-
                                     deviceRow.ClickBtn.MouseUpEventHandler += (send2, e2) =>
                                     {
                                         var rollerShadeControl = new Phone.Device.Curtain.RollerShadeControl();
                                         UserView.HomePage.Instance.AddChidren(rollerShadeControl);
                                         UserView.HomePage.Instance.PageIndex += 1;
                                         UserView.HomePage.Instance.ScrollEnabled = false;
-                                        //rollerShadeControl.action = RefreshBodyView;
                                         rollerShadeControl.Show(deviceUI, Common.Room.CurrentRoom);
+                                        rollerShadeControl.action += (curDev, curRoom) =>
+                                        {
+                                            ReFreshDeviceActionForWin(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
                                     };
+
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
+                                    {
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceActionForWin(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
+                                    };
+                                    var editBtn = new CommonForm.RowLayoutEditButton()
+                                    {
+                                        Tag = deviceUI
+                                    };
+                                    if (Common.Room.CurrentRoom.IsSharedRoom == false)
+                                    {
+                                        deviceTypeRowLayout.AddRightView(editBtn);
+                                        editBtn.MouseUpEventHandler += deviceDetailHandler;
+                                    }
                                 }
                             }
                             else if (deviceUI.CommonDevice.Type == DeviceType.DoorLock)
                             {
-                                var deviceTypeRowLayout = new RowLayout()
-                                {
-                                    Height = Application.GetRealHeight(129 + 35),
-                                    LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                    Tag = deviceUI
-                                };
-                                deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                 var deviceRow = new CategoryFunctionRow(0, 35);
                                 deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
                                 deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                //deviceRow.SetOnLineStatu(deviceUI.CommonDevice.IsOnline == 1);
                                 deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                 deviceRow.HideSwitchBtn(true);
                                 deviceTypeRowLayout.AddChidren(deviceRow);
@@ -1638,12 +1575,18 @@
                                     HomePage.Instance.PageIndex += 1;
                                     userDoorLockPage.Show();
                                 };
-
-                                var editBtn = new CommonForm.RowLayoutEditButton()
+                                EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
                                 {
-                                    Tag = deviceUI
+                                    var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                    UserView.HomePage.Instance.AddChidren(detailInfo);
+                                    UserView.HomePage.Instance.PageIndex += 1;
+                                    detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                    detailInfo.EditAction += (curDevice, curRoom) =>
+                                    {
+                                        ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                    };
                                 };
-                                var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
+                                var editBtn = new CommonForm.RowLayoutEditButton()
                                 {
                                     Tag = deviceUI
                                 };
@@ -1651,20 +1594,10 @@
                                 {
                                     deviceTypeRowLayout.AddRightView(editBtn);
                                     editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                    deviceTypeRowLayout.AddRightView(delBtn);
-                                    delBtn.MouseUpEventHandler += delEvent;
                                 }
                             }
                             else if (deviceUI.CommonDevice.Type == DeviceType.IASZone)
                             {
-                                var deviceTypeRowLayout = new RowLayout()
-                                {
-                                    Height = Application.GetRealHeight(129 + 35),
-                                    LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                    Tag = deviceUI
-                                };
-                                deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                 var deviceRow = new CategoryFunctionRow(0, 35);
                                 deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
                                 deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
@@ -1673,11 +1606,18 @@
                                 deviceRow.HideSwitchBtn(true);
                                 deviceTypeRowLayout.AddChidren(deviceRow);
 
-                                var editBtn = new CommonForm.RowLayoutEditButton()
+                                EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
                                 {
-                                    Tag = deviceUI
+                                    var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                    UserView.HomePage.Instance.AddChidren(detailInfo);
+                                    UserView.HomePage.Instance.PageIndex += 1;
+                                    detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                    detailInfo.EditAction += (curDevice, curRoom) =>
+                                    {
+                                        ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                    };
                                 };
-                                var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
+                                var editBtn = new CommonForm.RowLayoutEditButton()
                                 {
                                     Tag = deviceUI
                                 };
@@ -1685,8 +1625,6 @@
                                 {
                                     deviceTypeRowLayout.AddRightView(editBtn);
                                     editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                    deviceTypeRowLayout.AddRightView(delBtn);
-                                    delBtn.MouseUpEventHandler += delEvent;
                                 }
                             }
                             else if (deviceUI.CommonDevice.Type == DeviceType.TemperatureSensor)
@@ -1727,13 +1665,6 @@
                                         }
                                     })
                                     { IsBackground = true }.Start();
-                                    var deviceTypeRowLayout = new RowLayout()
-                                    {
-                                        Height = Application.GetRealHeight(129 + 35),
-                                        LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                        Tag = deviceUI
-                                    };
-                                    deviceListScrolView.AddChidren(deviceTypeRowLayout);
 
                                     var deviceRow = new CategoryFunctionRow(0, 35);
                                     deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
@@ -1743,11 +1674,18 @@
                                     deviceRow.HideSwitchBtn(true);
                                     deviceTypeRowLayout.AddChidren(deviceRow);
 
-                                    var editBtn = new CommonForm.RowLayoutEditButton()
+                                    EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
                                     {
-                                        Tag = deviceUI
+                                        var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                        UserView.HomePage.Instance.AddChidren(detailInfo);
+                                        UserView.HomePage.Instance.PageIndex += 1;
+                                        detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                        detailInfo.EditAction += (curDevice, curRoom) =>
+                                        {
+                                            ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                        };
                                     };
-                                    var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
+                                    var editBtn = new CommonForm.RowLayoutEditButton()
                                     {
                                         Tag = deviceUI
                                     };
@@ -1755,35 +1693,30 @@
                                     {
                                         deviceTypeRowLayout.AddRightView(editBtn);
                                         editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                        deviceTypeRowLayout.AddRightView(delBtn);
-                                        delBtn.MouseUpEventHandler += delEvent;
                                     }
-
                                 }
                             }
                             else
                             {
-                                var deviceTypeRowLayout = new RowLayout()
-                                {
-                                    Height = Application.GetRealHeight(129 + 35),
-                                    LineColor = ZigbeeColor.Current.GXCBackgroundColor,
-                                    Tag = deviceUI
-                                };
-                                deviceListScrolView.AddChidren(deviceTypeRowLayout);
-
                                 var deviceRow = new CategoryFunctionRow(0, 35);
                                 deviceRow.Init(deviceUI.IconPath, deviceUI.OnlineIconPath);
                                 deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
-                                //deviceRow.SetOnLineStatu(deviceUI.CommonDevice.IsOnline == 1);
                                 deviceRow.SetStatuText(deviceUI.GetDeviceStatu());
                                 deviceRow.HideSwitchBtn(true);
                                 deviceTypeRowLayout.AddChidren(deviceRow);
 
-                                var editBtn = new CommonForm.RowLayoutEditButton()
+                                EventHandler<MouseEventArgs> deviceDetailHandler = (send2, e2) =>
                                 {
-                                    Tag = deviceUI
+                                    var detailInfo = new Device.CommonForm.DeviceDetailInfo { };
+                                    UserView.HomePage.Instance.AddChidren(detailInfo);
+                                    UserView.HomePage.Instance.PageIndex += 1;
+                                    detailInfo.Show(deviceUI, Shared.Common.Room.CurrentRoom);
+                                    detailInfo.EditAction += (curDevice, curRoom) =>
+                                    {
+                                        ReFreshDeviceAction(deviceUI, curRoom, sameTypeList, deviceListScrolView, deviceRow);
+                                    };
                                 };
-                                var delBtn = new Device.CommonForm.RowLayoutDeleteButton()
+                                var editBtn = new CommonForm.RowLayoutEditButton()
                                 {
                                     Tag = deviceUI
                                 };
@@ -1791,20 +1724,141 @@
                                 {
                                     deviceTypeRowLayout.AddRightView(editBtn);
                                     editBtn.MouseUpEventHandler += deviceDetailHandler;
-                                    deviceTypeRowLayout.AddRightView(delBtn);
-                                    delBtn.MouseUpEventHandler += delEvent;
                                 }
                             }
-                        }
-                        catch
-                        {
 
+                            //鍒犻櫎璁惧
+                            EventHandler<MouseEventArgs> delEvent = (delSender, delE) =>
+                            {
+                                var alert = new UserCenter.ShowMsgControl(ShowMsgType.Confirm, Language.StringByID(R.MyInternationalizationString.DeleteFunction));
+                                alert.Show();
+                                alert.ConfirmClickEvent += () =>
+                                {
+                                    if (Common.Room.CurrentRoom.IsLove)
+                                    {
+                                        Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.FileName);
+                                        deviceListScrolView.RemoveViewByTag((delSender as Button).Tag);
+                                        sameTypeList.Remove(deviceUI);
+                                    }
+                                    else
+                                    {
+                                        Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.CommonDevice);
+                                        deviceListScrolView.RemoveViewByTag((delSender as Button).Tag);
+                                        sameTypeList.Remove(deviceUI);
+                                        if (Common.Room.CurrentRoom.GetLoveRoom().DeviceUIList.Find((obj) => obj.FileName == deviceUI.FileName) != null)
+                                        {
+                                            Common.Room.CurrentRoom.GetLoveRoom().DeleteDevice(deviceUI.FileName);
+                                        }
+                                    }
+                                    if (sameTypeList.Count == 0)
+                                    {
+                                        RefreshBodyView();
+                                    }
+                                };
+                            };
+                            var delBtn = new CommonForm.RowLayoutDeleteButton()
+                            {
+                                Tag = deviceUI
+                            };
+                            if (Common.Room.CurrentRoom.IsSharedRoom == false)
+                            {
+                                deviceTypeRowLayout.AddRightView(delBtn);
+                                delBtn.MouseUpEventHandler += delEvent;
+                            }
                         }
+                        catch { }
                     });
                 })
                 { IsBackground = true }.Start();
             }
         }
+
+        /// <summary>
+        /// ReFreshDeviceAction
+        /// </summary>
+        /// <param name="curRoom"></param>
+        /// <param name="sameTypeList"></param>
+        /// <param name="devListScrolView"></param>
+        /// <param name="deviceRow"></param>
+        private void ReFreshDeviceAction(DeviceUI deviceUI, Common.Room curRoom, List<DeviceUI> sameTypeList, VerticalScrolViewLayout devListScrolView, CategoryFunctionRow deviceRow)
+        {
+            if (Common.Room.CurrentRoom.IsLove)
+            {
+                deviceRow.SetDeviceIcon(deviceUI.IconPath, deviceUI.OnlineIconPath);
+                deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
+                if (Common.Room.CurrentRoom.IsCollectInRoom(deviceUI.FileName) == false)
+                {
+                    devListScrolView.RemoveViewByTag(deviceUI);
+                    sameTypeList.Remove(deviceUI);
+                    if (sameTypeList.Count == 0)
+                    {
+                        RefreshFunction(Common.Room.CurrentRoom);
+                    }
+                }
+            }
+            else
+            {
+                if (curRoom.Id != Common.Room.CurrentRoom.Id)
+                {
+                    Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.FileName);
+                    devListScrolView.RemoveViewByTag(deviceUI);
+                    sameTypeList.Remove(deviceUI);
+                    if (sameTypeList.Count == 0)
+                    {
+                        RefreshFunction(Common.Room.CurrentRoom);
+                    }
+                }
+                else
+                {
+                    deviceRow.SetDeviceIcon(deviceUI.IconPath, deviceUI.OnlineIconPath);
+                    deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
+                }
+            }
+        }
+
+        /// <summary>
+        /// ReFreshDeviceAction
+        /// </summary>
+        /// <param name="curRoom"></param>
+        /// <param name="sameTypeList"></param>
+        /// <param name="devListScrolView"></param>
+        /// <param name="deviceRow"></param>
+        private void ReFreshDeviceActionForWin(DeviceUI deviceUI, Common.Room curRoom, List<DeviceUI> sameTypeList, VerticalScrolViewLayout devListScrolView, CategoryFunctionForWinRow deviceRow)
+        {
+            if (Common.Room.CurrentRoom.IsLove)
+            {
+                deviceRow.SetDeviceIcon(deviceUI.IconPath, deviceUI.OnlineIconPath);
+                deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
+                if (Common.Room.CurrentRoom.IsCollectInRoom(deviceUI.FileName) == false)
+                {
+                    devListScrolView.RemoveViewByTag(deviceUI);
+                    sameTypeList.Remove(deviceUI);
+                    if (sameTypeList.Count == 0)
+                    {
+                        RefreshFunction(Common.Room.CurrentRoom);
+                    }
+                }
+            }
+            else
+            {
+                if (curRoom.Id != Common.Room.CurrentRoom.Id)
+                {
+                    Shared.Common.Room.CurrentRoom.DeleteDevice(deviceUI.FileName);
+                    devListScrolView.RemoveViewByTag(deviceUI);
+                    sameTypeList.Remove(deviceUI);
+                    if (sameTypeList.Count == 0)
+                    {
+                        RefreshFunction(Common.Room.CurrentRoom);
+                    }
+                }
+                else
+                {
+                    deviceRow.SetDeviceIcon(deviceUI.IconPath, deviceUI.OnlineIconPath);
+                    deviceRow.SetTitle(deviceUI.CommonDevice.DeviceEpointName);
+                }
+            }
+        }
+
 
         /// <summary>
         /// AddRoomView
@@ -1824,12 +1878,12 @@
             functionSceneBodyView = new FrameLayout()
             {
                 Y = roomFL.Bottom,
-                Height = Application.GetRealHeight(973+279),
+                Height = Application.GetRealHeight(973 + 279),
                 BackgroundColor = ZigbeeColor.Current.GXCGrayBackgroundColor
             };
             functionSceneAutoBodyView.AddChidren(functionSceneBodyView);
 
-            RoomButton curBtn = new RoomButton(0,0);
+            RoomButton curBtn = new RoomButton(0, 0);
             foreach (var room in Common.Room.CurrentRoom.GetRoomsByCurrentFloorIdAppendLoveRoom())
             {
                 var row = new FrameLayout()
@@ -1849,7 +1903,7 @@
                 {
                     roomBtn.IsSelected = true;
                     curBtn = roomBtn;
-                    if(sceneBtn.IsSelected)
+                    if (sceneBtn.IsSelected)
                     {
                         RefreshScene(room);
                     }
@@ -1861,7 +1915,7 @@
 
                 roomBtn.ButtonClickEvent += (sender, e) =>
                 {
-                    if (sender  == curBtn)
+                    if (sender == curBtn)
                     {
                         return;
                     }
@@ -1939,7 +1993,7 @@
                 Height = Application.GetRealHeight(200),
                 Width = Application.GetRealWidth(700),
                 Gravity = Gravity.CenterHorizontal,
-                Text = Language.StringByID(R.MyInternationalizationString.NoScene).Replace("{\\r\\n}","\r\n"),
+                Text = Language.StringByID(R.MyInternationalizationString.NoScene).Replace("{\\r\\n}", "\r\n"),
                 TextColor = ZigbeeColor.Current.GXCPlaceHolderTextColor,
                 TextAlignment = TextAlignment.Center,
                 IsMoreLines = true
@@ -1974,7 +2028,7 @@
                     if (delayScenesListResponseInfo.ScenesId == sceneView.scene.Id)
                     {
                         sceneView.scene.RemainTime = delayScenesListResponseInfo.RemainTime;
-                        var remainTime= delayScenesListResponseInfo.RemainTime;
+                        var remainTime = delayScenesListResponseInfo.RemainTime;
                         if (remainTime > 0)
                         {
                             new System.Threading.Thread(() =>
@@ -2021,10 +2075,10 @@
         /// 鑷姩鍖�
         /// </summary>
         private async void ShowAutotion()
-        {
-
-            functionSceneAutoBodyView.BackgroundColor = ZigbeeColor.Current.LogicMiddleBackgroundColor;
-
+        {
+
+            functionSceneAutoBodyView.BackgroundColor = ZigbeeColor.Current.LogicMiddleBackgroundColor;
+
             var bjFrameLayout = new FrameLayout
             {
                 Width = Application.GetRealWidth(1080 - 58),
@@ -2056,7 +2110,7 @@
                 TextID = MyInternationalizationString.logictemplate,
                 Gravity = Gravity.CenterVertical,
                 TextColor = ZigbeeColor.Current.LogicBtnSelectedColor,
-                TextSize=15,
+                TextSize = 15,
             };
             bjFrameLayout.AddChidren(recommendtextBtn);
 
@@ -2816,4 +2870,4 @@
 
 
     }
-}
+}
\ No newline at end of file

--
Gitblit v1.8.0