From bc6d6b77675b8915635aa04ba765ea627ac63cfa Mon Sep 17 00:00:00 2001
From: gxc <guoxuecheng@guoxuechengdeMacBook-Pro.local>
Date: 星期二, 17 十二月 2019 09:38:17 +0800
Subject: [PATCH] 2019.12.17

---
 ZigbeeApp/Shared/Phone/Device/Category/Category.cs |  140 +++++++++++++++++++---------------------------
 1 files changed, 58 insertions(+), 82 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Category/Category.cs b/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
index f1eaa77..e52cefb 100644
--- a/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Category/Category.cs
@@ -149,6 +149,10 @@
                 {
                     try
                     {
+                        if (common.DeviceStatusReport.AttriBute == null || common.DeviceStatusReport.AttriBute.Count == 0)
+                        {
+                            return;
+                        }
                         for (int i = 0; deviceListScrolView != null && i < deviceListScrolView.ChildrenCount; i++)
                         {
                             var rowLayout = deviceListScrolView.GetChildren(i) as RowLayout;
@@ -169,10 +173,6 @@
                                     {
                                         var light = deviceUI.CommonDevice as ToggleLight;
                                         light.DeviceStatusReport = common.DeviceStatusReport;
-                                        if (light.DeviceStatusReport.AttriBute == null || light.DeviceStatusReport.AttriBute.Count == 0)
-                                        {
-                                            continue;
-                                        }
                                         light.OnOffStatus = light.DeviceStatusReport.AttriBute[0].AttriButeData;
                                         var row = rowLayout.GetChildren(0) as CategoryFunctionRow;
                                         row.SetStatu(light.OnOffStatus == 1);
@@ -194,10 +194,6 @@
                                     {
                                         var airSwitch = deviceUI.CommonDevice as ZigBee.Device.AirSwitch;
                                         airSwitch.DeviceStatusReport = common.DeviceStatusReport;
-                                        if (airSwitch.DeviceStatusReport.AttriBute == null || airSwitch.DeviceStatusReport.AttriBute.Count == 0)
-                                        {
-                                            return;
-                                        }
                                         airSwitch.OnOffStatus = airSwitch.DeviceStatusReport.AttriBute[0].AttriButeData;
                                         var row = rowLayout.GetChildren(0) as CategoryFunctionRow;
                                         row.SetStatu(airSwitch.OnOffStatus == 1);
@@ -249,57 +245,47 @@
                                     if (common.DeviceStatusReport.CluterID == 513)
                                     {
                                         var attriButeList = common.DeviceStatusReport.AttriBute;
-                                        if (attriButeList == null || attriButeList.Count == 0)
-                                        {
-                                            return;
-                                        }
                                         var ac = deviceUI.CommonDevice as ZigBee.Device.AC;
                                         ac.DeviceStatusReport = common.DeviceStatusReport;
-
-                                        var curTemp = (attriButeList[0].AttriButeData / 100 < ACControlBase.Temperature_High || attriButeList[0].AttriButeData / 100 > ACControlBase.Temperature_Low) ? attriButeList[0].AttriButeData / 100 : ACControlBase.Temperature_Default;
-                                        switch (attriButeList[0].AttributeId)
+                                        foreach(var attList in attriButeList)
                                         {
-                                            case 0:
-                                                ac.currentLocalTemperature = curTemp;
-                                                ac.LastDateTime = DateTime.Now;
-                                                break;
-
-                                            case 17:
-                                                ac.currentCoolingSetpoint = curTemp;
-                                                ac.LastDateTime = DateTime.Now;
-                                                break;
-
-                                            case 18:
-                                                ac.currentHeatingSetpoint = curTemp;
-                                                ac.LastDateTime = DateTime.Now;
-                                                break;
-
-                                            case 4096:
-                                                ac.currentAutoSetpoint = curTemp;
-                                                ac.LastDateTime = DateTime.Now;
-                                                break;
-
-                                            case 28:
-                                                //姝ゅ睘鎬ф弿杩版亽娓╄澶囨澶勪簬鍝妯″紡
-                                                ac.currentSystemMode = attriButeList[0].AttriButeData;
-                                                ac.LastDateTime = DateTime.Now;
-                                                break;
-
-                                            case 4099:
-                                                var value = Convert.ToString(attriButeList[0].AttriButeData, 2).PadLeft(16, '0');
-                                                var modeStr = value.Substring(value.Length - 5, 5);
-                                                for (int j = 0; j < modeStr.Length; j++)
-                                                {
-                                                    ac.listSupportMode[j] = Convert.ToInt32(modeStr[j]) == 49 ? 1 : 0;
-                                                }
-                                                break;
-
-                                            case 4097:
-                                                //杩囪檻缃戞竻娲楁爣蹇�:42
-                                                ac.CleanStatu = attriButeList[0].AttriButeData == 42;
-                                                break;
+                                            var curTemp = (attList.AttriButeData / 100 < ACControlBase.Temperature_High || attList.AttriButeData / 100 > ACControlBase.Temperature_Low) ? attList.AttriButeData / 100 : ACControlBase.Temperature_Default;
+                                            switch (attList.AttributeId)
+                                            {
+                                                case 0:
+                                                    ac.currentLocalTemperature = curTemp;
+                                                    ac.LastDateTime = DateTime.Now;
+                                                    break;
+                                                case 17:
+                                                    ac.currentCoolingSetpoint = curTemp;
+                                                    ac.LastDateTime = DateTime.Now;
+                                                    break;
+                                                case 18:
+                                                    ac.currentHeatingSetpoint = curTemp;
+                                                    ac.LastDateTime = DateTime.Now;
+                                                    break;
+                                                case 4096:
+                                                    ac.currentAutoSetpoint = curTemp;
+                                                    ac.LastDateTime = DateTime.Now;
+                                                    break;
+                                                case 28:
+                                                    ac.currentSystemMode = attList.AttriButeData;
+                                                    ac.LastDateTime = DateTime.Now;
+                                                    break;
+                                                case 4099:
+                                                    var value = Convert.ToString(attList.AttriButeData, 2).PadLeft(16, '0');
+                                                    var modeStr = value.Substring(value.Length - 5, 5);
+                                                    for (int j = 0; j < modeStr.Length; j++)
+                                                    {
+                                                        ac.listSupportMode[j] = Convert.ToInt32(modeStr[j]) == 49 ? 1 : 0;
+                                                    }
+                                                    break;
+                                                case 4097:
+                                                    //杩囪檻缃戞竻娲楁爣蹇�:42
+                                                    ac.CleanStatu = attList.AttriButeData == 42;
+                                                    break;
+                                            }
                                         }
-
                                         var row = rowLayout.GetChildren(0) as CategoryFunctionRow;
                                         row.SetStatu(ac.currentSystemMode != 0);
                                         row.SetStatuText(deviceUI.GetDeviceStatu());
@@ -309,21 +295,20 @@
                                     {
                                         var ac = deviceUI.CommonDevice as ZigBee.Device.AC;
                                         var attriButeList = common.DeviceStatusReport.AttriBute;
-                                        if (attriButeList == null || attriButeList.Count == 0)
-                                        {
-                                            return;
-                                        }
                                         ac.DeviceStatusReport = common.DeviceStatusReport;
-                                        switch (attriButeList[0].AttributeId)
+                                        foreach(var attList in attriButeList)
                                         {
-                                            case 0:
-                                                ac.currentFanMode = attriButeList[0].AttriButeData;
-                                                ac.LastDateTime = DateTime.Now;
-                                                break;
-                                            case 4096:
-                                                ac.currentFanSwingMode = attriButeList[0].AttriButeData;
-                                                ac.LastDateTime = DateTime.Now;
-                                                break;
+                                            switch (attList.AttributeId)
+                                            {
+                                                case 0:
+                                                    ac.currentFanMode = attList.AttriButeData;
+                                                    ac.LastDateTime = DateTime.Now;
+                                                    break;
+                                                case 4096:
+                                                    ac.currentFanSwingMode = attList.AttriButeData;
+                                                    ac.LastDateTime = DateTime.Now;
+                                                    break;
+                                            }
                                         }
                                         var row = rowLayout.GetChildren(0) as CategoryFunctionRow;
                                         row.SetStatu(ac.currentSystemMode != 0);
@@ -345,10 +330,6 @@
                                     {
                                         var dimmableLight = deviceUI.CommonDevice as DimmableLight;
                                         dimmableLight.DeviceStatusReport = common.DeviceStatusReport;
-                                        if (dimmableLight.DeviceStatusReport.AttriBute == null || dimmableLight.DeviceStatusReport.AttriBute.Count == 0)
-                                        {
-                                            continue;
-                                        }
                                         dimmableLight.OnOffStatus = dimmableLight.DeviceStatusReport.AttriBute[0].AttriButeData;
                                         var row = rowLayout.GetChildren(0) as CategoryFunctionRow;
                                         row.SetStatu(dimmableLight.OnOffStatus == 1);
@@ -359,10 +340,6 @@
                                     {
                                         var dimmableLight = deviceUI.CommonDevice as DimmableLight;
                                         dimmableLight.DeviceStatusReport = common.DeviceStatusReport;
-                                        if (dimmableLight.DeviceStatusReport.AttriBute == null || dimmableLight.DeviceStatusReport.AttriBute.Count == 0)
-                                        {
-                                            continue;
-                                        }
                                         dimmableLight.Level = dimmableLight.DeviceStatusReport.AttriBute[0].AttriButeData;
                                         var row = rowLayout.GetChildren(0) as CategoryFunctionRow;
                                         row.SetStatu(dimmableLight.OnOffStatus == 1);
@@ -1032,7 +1009,7 @@
                                 delBtn.MouseUpEventHandler += delEvent;
                             }
                         }
-                        else if (deviceUI.CommonDevice.Type == ZigBee.Device.DeviceType.AirSwitch)
+                        else if (deviceUI.CommonDevice.Type == DeviceType.AirSwitch)
                         {
                             //绌烘皵寮�鍏�
                             var airSwitch = deviceUI.CommonDevice as ZigBee.Device.AirSwitch;
@@ -1133,7 +1110,7 @@
                             }
 
                         }
-                        else if (deviceUI.CommonDevice.Type == ZigBee.Device.DeviceType.DimmableLight)
+                        else if (deviceUI.CommonDevice.Type == DeviceType.DimmableLight)
                         {
                             //璋冨厜鐏�
                             var dimmableLight = deviceUI.CommonDevice as ZigBee.Device.DimmableLight;
@@ -1233,7 +1210,7 @@
                                 delBtn.MouseUpEventHandler += delEvent;
                             }
                         }
-                        else if (deviceUI.CommonDevice.Type == ZigBee.Device.DeviceType.Thermostat)
+                        else if (deviceUI.CommonDevice.Type == DeviceType.Thermostat)
                         {
                             //绌鸿皟
                             var ac = deviceUI.CommonDevice as ZigBee.Device.AC;
@@ -1335,7 +1312,7 @@
                                 acControl.Show(deviceUI, room);
                             };
                         }
-                        else if (deviceUI.CommonDevice.Type == ZigBee.Device.DeviceType.WindowCoveringDevice)
+                        else if (deviceUI.CommonDevice.Type == DeviceType.WindowCoveringDevice)
                         {
                             //鍗峰笜
                             var rollerShade = deviceUI.CommonDevice as ZigBee.Device.Rollershade;
@@ -1422,7 +1399,7 @@
                                 rollerShadeControl.Show(deviceUI, room);
                             };
                         }
-                        else if(deviceUI.CommonDevice.Type == ZigBee.Device.DeviceType.DoorLock)
+                        else if (deviceUI.CommonDevice.Type == DeviceType.DoorLock)
                         {
                             var deviceTypeRowLayout = new RowLayout()
                             {
@@ -1520,7 +1497,6 @@
                     typeRowLayout.AddChidren(functionTypeIMG);
 
                     functionTypeIMG.ClickBtn.MouseUpEventHandler += ShowSameTypeFunction;
-
 
                     if (deviceType == room.DeviceUIList[0].CommonDevice.Type)
                     {

--
Gitblit v1.8.0