From 9137222ece9b978eb97b5598f2eee6e070bcf9d6 Mon Sep 17 00:00:00 2001
From: JLChen <551775569@qq.com>
Date: 星期五, 28 二月 2020 15:22:16 +0800
Subject: [PATCH] 2020-02-28 更新

---
 Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs |  142 +++++++++++++++++++++++++++-------------------
 1 files changed, 83 insertions(+), 59 deletions(-)

diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs
index 5944f0a..d92a07e 100644
--- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs
+++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs
@@ -249,6 +249,7 @@
 
             System.Threading.Tasks.Task.Run (() => {
                 try {
+                    int mSendCount = 0;
                     foreach (var room in Room.Lists) {
                         if (room == null)
                             continue;
@@ -256,78 +257,100 @@
                             continue;
                         }
                         foreach (var common in room.DeviceList) {
+
                             byte [] returnBytes = null;
                             if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightSwitch || common.Type == DeviceType.LightRGB || common.Type == DeviceType.LightEnergySwitch
                                 || common.Type == DeviceType.LightMixDimming || common.Type == DeviceType.LightMixSwitch || common.Type == DeviceType.LightDALI) {
-                                if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightDALI) {
-                                    var light = (LightDimming)common;
-                                    if (b == 100) {
-                                        if (light.LastOpenBrightness == 0) {
-                                            returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
-                                        } else
-                                            returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, light.LastOpenBrightness, light.DelayTimeHeight, light.DelayTimeLow });
-                                    } else
-                                        returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
-                                } else if (common.Type == DeviceType.LightSwitch || common.Type == DeviceType.LightEnergySwitch) {
-                                    returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { common.LoopID, b, ((LightSwitch)common).DelayTimeHeight, ((LightSwitch)common).DelayTimeLow });
-                                } else if (common.Type == DeviceType.LightRGB) {
-                                    var light = (LightLogic)common;
-                                    byte b2 = b;
-                                    if (b2 == 100) {
-                                        if (light.LastOpenBrightness != 0) {
-                                            b2 = light.LastOpenBrightness;
-                                        }
-                                    }
-                                    returnBytes = Control.ControlBytesSendHasReturn (Command.SetLogicLoopColor, common.SubnetID, common.DeviceID, new byte [] {
+
+                               new System.Threading.Thread (() => {
+                                   mSendCount++;
+
+                                   if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightDALI) {
+                                       var light = (LightDimming)common;
+                                       if (b == 100) {
+                                           if (light.LastOpenBrightness == 0) {
+                                               returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
+                                           } else
+                                               returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, light.LastOpenBrightness, light.DelayTimeHeight, light.DelayTimeLow });
+                                       } else
+                                           returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.LoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
+                                   } else if (common.Type == DeviceType.LightSwitch || common.Type == DeviceType.LightEnergySwitch) {
+                                       returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { common.LoopID, b, ((LightSwitch)common).DelayTimeHeight, ((LightSwitch)common).DelayTimeLow });
+                                   } else if (common.Type == DeviceType.LightRGB) {
+                                       var light = (LightLogic)common;
+                                       byte b2 = b;
+                                       if (b2 == 100) {
+                                           if (light.LastOpenBrightness != 0) {
+                                               b2 = light.LastOpenBrightness;
+                                           }
+                                       }
+                                       returnBytes = Control.ControlBytesSendHasReturn (Command.SetLogicLoopColor, common.SubnetID, common.DeviceID, new byte [] {
                                      common.LoopID, b2, 254, light.CustomDelayTimeOpen,light.CustomDelayTimeClose,
                                     3,light.RStatus,light.GStatus,light.BStatus,0,0});
-                                } else if (common.Type == DeviceType.LightMixDimming) {
-                                    var light = (LightMixDimming)common;
-                                    if (b == 100) {
-                                        if (light.LastOpenBrightness == 0) {
-                                            returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
-                                        } else
-                                            returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, light.LastOpenBrightness, light.DelayTimeHeight, light.DelayTimeLow });
-                                    } else
-                                        returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
-                                } else if (common.Type == DeviceType.LightMixSwitch) {
-                                    var light = (LightMixSwitch)common;
-                                    returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
-                                } else {
-                                    continue;
-                                }
-                                if (showTip) {
-                                    if (returnBytes == null) {
-                                        Application.RunOnMainThread (() => {
+                                   } else if (common.Type == DeviceType.LightMixDimming) {
+                                       var light = (LightMixDimming)common;
+                                       if (b == 100) {
+                                           if (light.LastOpenBrightness == 0) {
+                                               returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
+                                           } else
+                                               returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, light.LastOpenBrightness, light.DelayTimeHeight, light.DelayTimeLow });
+                                       } else
+                                           returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
+                                   } else if (common.Type == DeviceType.LightMixSwitch) {
+                                       var light = (LightMixSwitch)common;
+                                       returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, common.SubnetID, common.DeviceID, new byte [] { light.PhysicsLoopID, b, light.DelayTimeHeight, light.DelayTimeLow });
+                                   } else {
+                                       returnBytes = new byte [] { 0x00 };
+                                   }
+                                   if (showTip) {
+                                       if (returnBytes == null) {
+                                           Application.RunOnMainThread (() => {
 
-                                            var btnTip = new Button () {
-                                                Height = Application.GetRealHeight (140),
-                                                Text = common.Name + ErrorCode.ControlFailure,
-                                                BackgroundColor = 0xFFD7D7D7,
-                                            };
-                                            MainPage.MainFrameLayout.AddChidren (btnTip);
-                                            btnTip.MouseUpEventHandler += (sender, e) => {
-                                                btnTip.RemoveFromParent ();
-                                                //MainPage.MainFrameLayout.Remove (btnTip);
-                                                //showTip = false;
-                                            };
+                                               var btnTip = new Button () {
+                                                   Height = Application.GetRealHeight (140),
+                                                   Text = common.Name + ErrorCode.ControlFailure,
+                                                   BackgroundColor = 0xFFD7D7D7,
+                                               };
+                                               MainPage.MainFrameLayout.AddChidren (btnTip);
+                                               btnTip.MouseUpEventHandler += (sender, e) => {
+                                                   btnTip.RemoveFromParent ();
+                                                   //MainPage.MainFrameLayout.Remove (btnTip);
+                                                   //showTip = false;
+                                               };
 
 
-                                            System.Threading.Tasks.Task.Run (() => {
-                                                System.Threading.Thread.Sleep (3000);
-                                                Application.RunOnMainThread (() => {
-                                                    btnTip.RemoveFromParent ();
-                                                    //MainPage.MainFrameLayout.Remove (btnTip);
-                                                });
-                                            });
+                                               System.Threading.Tasks.Task.Run (() => {
+                                                   System.Threading.Thread.Sleep (3000);
+                                                   Application.RunOnMainThread (() => {
+                                                       btnTip.RemoveFromParent ();
+                                                       //MainPage.MainFrameLayout.Remove (btnTip);
+                                                   });
+                                               });
 
 
-                                        });
-                                    }
-                                }
+                                           });
+                                       }
+                                   }
+
+                                   mSendCount--;
+                               }) { IsBackground = true }.Start();
+
+                                //绛夊緟100ms鍐嶅彂閫佺浜屼釜璁惧鏁版嵁
+                                System.Threading.Thread.Sleep (100);
                             }
+
+
+
+
                         }
                     }
+
+
+                    while (mSendCount > 0) {
+                        System.Threading.Thread.Sleep (100);
+                    }
+
+
                 } catch {
                     Console.WriteLine ("controlAllLight catch");
                 } finally {
@@ -338,6 +361,7 @@
                 }
             });
         }
+
         /// <summary>
         /// 閫氳繃璁惧绫诲瀷鏂瑰紡閫夋嫨璁惧
         /// </summary>

--
Gitblit v1.8.0