From f500e14c0a994487070380c50c85e0929cbc8e63 Mon Sep 17 00:00:00 2001 From: JLChen <551775569@qq.com> Date: 星期二, 05 一月 2021 10:48:04 +0800 Subject: [PATCH] 2021-01-05 1.更新 --- Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs | 389 +++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 248 insertions(+), 141 deletions(-) diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs index d76b1a7..ad804e0 100644 --- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs +++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Light/UserDeviceToLight.cs @@ -35,6 +35,7 @@ if (readEnergyThead != null) readEnergyThead.Abort (); base.RemoveFromParent (); + MainPage.Loading.Hide (); } /// <summary> /// 鏇存柊鑳芥簮璁惧鏁版嵁 @@ -61,14 +62,16 @@ var btn = (Button)lightRow.GetChildren (j); if (btn.Tag != null) { if (updataType == 10) { - if (btn.Tag.ToString () == DeviceType.LightEnergySocket.ToString () + "_Voltage" || btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Voltage") { + if (btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Voltage") { btn.Text = energy.ToString () + " W"; } - } else if (updataType == 11) { - if (btn.Tag.ToString () == DeviceType.LightEnergySocket.ToString () + "_Electric" || btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Electric") { - btn.Text = ((double)(Convert.ToDouble (energy) / 10)).ToString () + " kw.h"; - } } + ////2020-07-01 瀹㈡埛鎻愬嚭闅愯棌kwh + //else if (updataType == 11) { + // if (btn.Tag.ToString () == DeviceType.LightEnergySwitch.ToString () + "_Electric") { + // btn.Text = ((double)(Convert.ToDouble (energy) / 10)).ToString () + " kw.h"; + // } + //} } } } @@ -91,7 +94,7 @@ if (light.Type == DeviceType.LightDimming || light.Type == DeviceType.LightMixDimming || light.Type == DeviceType.LightDALI) { if ((light as LightDimming).CurrentBrightness > 0) brighingCount++; - } else if (light.Type == DeviceType.LightSwitch || light.Type == DeviceType.LightMixSwitch) + } else if (light.Type == DeviceType.LightSwitch || light.Type == DeviceType.LightMixSwitch || light.Type == DeviceType.LightEnergySwitch) if ((light as LightSwitch).CurrentBrightness == 100) brighingCount++; if (light.Type == DeviceType.LightRGB) @@ -179,7 +182,7 @@ } } //if (!update) { - // Console.WriteLine ("閫�鍑烘洿鏂扮伅鍏�"); + // Utlis.WriteLine ("閫�鍑烘洿鏂扮伅鍏�"); // return; //} Application.RunOnMainThread (() => { @@ -227,8 +230,10 @@ } }); }); - Console.WriteLine ("U1"); + //Utlis.WriteLine ("U1"); } + + private readonly object SendLocker = new object (); bool showTip = true; /// <summary> /// 鎺у埗鎵�鏈夌殑鐏� @@ -236,90 +241,140 @@ /// <param name="b">The blue component.</param> void controlAllLight (byte b) { + if (CommonPage.IsRemote) { + if (!SmartHome.MqttCommon.IsGatewayOnline) { + new Alert ("", "Gateway offline" + ErrorCode.ControlFailure, "Close").Show (); + return; + } + } + showTip = true; MainPage.Loading.Start ("Sending..."); System.Threading.Tasks.Task.Run (() => { - foreach (var room in Room.Lists) { - if (room == null) - continue; - if (string.IsNullOrEmpty (room.Name)) { - 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 [] { + try { + int mSendCount = 0; + foreach (var room in Room.Lists) { + if (room == null) + continue; + if (string.IsNullOrEmpty (room.Name)) { + 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) { + + new System.Threading.Thread (() => { + try { + lock (SendLocker) { + mSendCount++; + } + //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 }); - } - if (showTip) { - Application.RunOnMainThread (() => { - if (returnBytes == null) { - string tipString = Language.StringByID (R.MyInternationalizationString.ControlFailure); - var btnTip = new Button () { - Height = Application.GetRealHeight (140), - Text = common.Name + tipString,// + "..." + controlDeviceIndex.ToString () + @"/" + sceneDeviceCount.ToString (), - BackgroundColor = 0xFFD7D7D7, - }; - MainPage.MainFrameLayout.AddChidren (btnTip); - btnTip.MouseUpEventHandler += (sender, e) => { - btnTip.RemoveFromParent (); - //MainPage.MainFrameLayout.Remove (btnTip); - showTip = false; - }; + } 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 (() => { - System.Threading.Tasks.Task.Run (() => { - System.Threading.Thread.Sleep (3000); - Application.RunOnMainThread (() => { - btnTip.RemoveFromParent (); - //MainPage.MainFrameLayout.Remove (btnTip); - }); - }); + 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); + }); + }); + + + }); + } + } + + //mSendCount--; + } catch { } finally { + lock (SendLocker) { + mSendCount--; + } } - }); + }) { IsBackground = true }.Start (); + + //绛夊緟100ms鍐嶅彂閫佺浜屼釜璁惧鏁版嵁 + System.Threading.Thread.Sleep (100); } + + + + } } - } - Application.RunOnMainThread (() => { - MainPage.Loading.Hide (); - }); + + while (mSendCount > 0) { + System.Threading.Thread.Sleep (100); + } + + + } catch { + Utlis.WriteLine ("controlAllLight catch"); + } finally { + Application.RunOnMainThread (() => { + MainPage.Loading.Hide (); + }); + //Utlis.WriteLine ("controlAllLight Loading.Hide"); + } }); } + /// <summary> /// 閫氳繃璁惧绫诲瀷鏂瑰紡閫夋嫨璁惧 /// </summary> @@ -403,8 +458,14 @@ continue; } var lightListForRoom = room.DeviceList.FindAll ((obj) => { - return obj.Type == DeviceType.LightDimming || obj.Type == DeviceType.LightSwitch || obj.Type == DeviceType.LightRGB - || obj.Type == DeviceType.LightMixSwitch || obj.Type == DeviceType.LightMixDimming || obj.Type == DeviceType.LightDALI; + return obj.Type == DeviceType.LightDimming + || obj.Type == DeviceType.LightSwitch + || obj.Type == DeviceType.LightRGB + || obj.Type == DeviceType.LightMixSwitch + || obj.Type == DeviceType.LightMixDimming + //|| obj.Type == DeviceType.LightEnergySwitch//2020-01-17 鏂板 + //|| obj.Type == DeviceType.LightEnergySocket + || obj.Type == DeviceType.LightDALI; }); if (lightListForRoom == null) { continue; @@ -455,8 +516,8 @@ roomView.AddChidren (btnNumber); Button btnLightIcon = new Button () { - Width = Application.GetRealWidth (100), - Height = Application.GetRealHeight (80), + Width = Application.GetMinRealAverage (100), + Height = Application.GetMinRealAverage (80), Gravity = Gravity.CenterVertical, UnSelectedImagePath = "Item/RH_Lights.png", SelectedImagePath = "Item/RH_LightsSelected.png", @@ -516,8 +577,8 @@ Button downSelectedButton = new Button () { X = Application.GetRealWidth (550), - Height = Application.GetRealHeight (50), - Width = Application.GetRealWidth (55), + Height = Application.GetMinRealAverage (50), + Width = Application.GetMinRealAverage (55), UnSelectedImagePath = "Item/Down.png", SelectedImagePath = "Item/DownSelected.png", Gravity = Gravity.CenterVertical, @@ -535,14 +596,14 @@ var lightList = new List<Common> (); foreach (var room in Room.Lists) { if (room == null) { - Console.WriteLine ("Null is Room"); + Utlis.WriteLine ("Null is Room"); continue; } - Console.WriteLine ("RoomCount" + Room.Lists.Count); + Utlis.WriteLine ("RoomCount" + Room.Lists.Count); - Console.WriteLine (room.Name); + Utlis.WriteLine (room.Name); if (string.IsNullOrEmpty (room.Name)) { - Console.WriteLine ("Null is Room Name"); + Utlis.WriteLine ("Null is Room Name"); continue; } foreach (var common in room.DeviceList) { @@ -552,7 +613,7 @@ } else if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightDALI || common.Type == DeviceType.LightMixDimming) { LightCount++; lightList.Add (common); - } else if (common.Type == DeviceType.LightRGB || common.Type == DeviceType.LightEnergySwitch || common.Type == DeviceType.LightEnergySocket) {//2020-01-17 + } else if (common.Type == DeviceType.LightRGB || common.Type == DeviceType.LightEnergySwitch) {//2020-01-17 LightCount++; lightList.Add (common); } @@ -624,7 +685,7 @@ }; lightView.AddChidren (tempSwitch); - if (common.Type == DeviceType.LightEnergySwitch || common.Type == DeviceType.LightEnergySocket) { + if (common.Type == DeviceType.LightEnergySwitch) { Button btnEnergy = new Button () { Width = Application.GetRealWidth (90), Height = Application.GetRealHeight (30), @@ -637,44 +698,47 @@ }; lightView.AddChidren (btnEnergy); EnergtLightList.Add (common); - - if (common.Type == DeviceType.LightEnergySwitch) { - Button btnElectric = new Button () { - Width = Application.GetRealWidth (200), - Height = Application.GetRealHeight (35), - X = Application.GetRealWidth (320), - Y = tempSwitch.Bottom, - TextAlignment = TextAlignment.CenterRight, - TextColor = SkinStyle.Current.TextColor1, - SelectedTextColor = SkinStyle.Current.TextColor1, - Tag = common.Type.ToString () + "_Electric", - Text = "0 kw.h" - }; - lightView.AddChidren (btnElectric); - } + //2020-07-01 瀹㈡埛鎻愬嚭闅愯棌kwh + //if (common.Type == DeviceType.LightEnergySwitch) { + // Button btnElectric = new Button () { + // Width = Application.GetRealWidth (200), + // Height = Application.GetRealHeight (35), + // X = Application.GetRealWidth (320), + // Y = tempSwitch.Bottom, + // TextAlignment = TextAlignment.CenterRight, + // TextColor = SkinStyle.Current.TextColor1, + // SelectedTextColor = SkinStyle.Current.TextColor1, + // Tag = common.Type.ToString () + "_Electric", + // Text = "0 kw.h" + // }; + // lightView.AddChidren (btnElectric); + //} } tempSwitch.MouseUpEventHandler += (sender3, e3) => { - tempSwitch.IsSelected = !tempSwitch.IsSelected; - if (tempSwitch.IsSelected) { - light.CurrentBrightness = 100; - } else { - light.CurrentBrightness = 0; + //tempSwitch.IsSelected = !tempSwitch.IsSelected; + //if (tempSwitch.IsSelected) { + // light.CurrentBrightness = 100; + //} else { + // light.CurrentBrightness = 0; + //} + int mSetBrightness = tempSwitch.IsSelected ? 0 : 100; + //Control.ControlBytesSend (Command.SetSingleLight, light.SubnetID, light.DeviceID, new byte [] { sendLoopID, (byte)light.CurrentBrightness, light.DelayTimeHeight, light.DelayTimeLow }); + SendControl.SendControlSetSingleLight (light, new byte [] { sendLoopID, (byte)mSetBrightness, light.DelayTimeHeight, light.DelayTimeLow }); + + if (common.Type == DeviceType.LightEnergySwitch) { + new System.Threading.Thread (() => { + Control.ControlBytesSend (Command.ReadAnalogValue, light.SubnetID, light.DeviceID, new byte [] { 10, light.LoopID }, SendCount.Zero); + //2020-07-01 瀹㈡埛鎻愬嚭闅愯棌kwh + //Control.ControlBytesSend (Command.ReadAnalogValue, light.SubnetID, light.DeviceID, new byte [] { 11, light.LoopID }, SendCount.Zero); + }) { IsBackground = true }.Start (); } - Control.ControlBytesSend (Command.SetSingleLight, light.SubnetID, light.DeviceID, new byte [] { sendLoopID, (byte)light.CurrentBrightness, light.DelayTimeHeight, light.DelayTimeLow }); - - new System.Threading.Thread (() => { - Control.ControlBytesSend (Command.ReadAnalogValue, light.SubnetID, light.DeviceID, new byte [] { 10, light.LoopID }, SendCount.Zero); - Control.ControlBytesSend (Command.ReadAnalogValue, light.SubnetID, light.DeviceID, new byte [] { 11, light.LoopID }, SendCount.Zero); - }) { IsBackground = true }.Start (); - }; if (light.CurrentBrightness == 100) { tempSwitch.IsSelected = true; } - } - else if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightDALI || common.Type == DeviceType.LightMixDimming) { + } else if (common.Type == DeviceType.LightDimming || common.Type == DeviceType.LightDALI || common.Type == DeviceType.LightMixDimming) { LightCount++; byte sendLoopID = 0; if (common.Type == DeviceType.LightMixDimming) { @@ -792,23 +856,26 @@ }; tempSwitch.MouseUpEventHandler += (sender3, e3) => { - tempSwitch.IsSelected = !tempSwitch.IsSelected; + //tempSwitch.IsSelected = !tempSwitch.IsSelected; if (light.LastOpenBrightness == 0) { light.LastOpenBrightness = 100; } - if (tempSwitch.IsSelected) { - tempLightSeekBar.Progress = light.LastOpenBrightness; - } else { - tempLightSeekBar.Progress = 0; - } - light.CurrentBrightness = (byte)tempLightSeekBar.Progress; - Control.ControlBytesSend (Command.SetSingleLight, light.SubnetID, light.DeviceID, new byte [] { sendLoopID, light.CurrentBrightness, light.DelayTimeHeight, light.DelayTimeLow }); + //if (tempSwitch.IsSelected) { + // tempLightSeekBar.Progress = light.LastOpenBrightness; + //} else { + // tempLightSeekBar.Progress = 0; + //} + //light.CurrentBrightness = (byte)tempLightSeekBar.Progress; + + int mSetBrightness = tempSwitch.IsSelected ? 0 : light.LastOpenBrightness; + //Control.ControlBytesSend (Command.SetSingleLight, light.SubnetID, light.DeviceID, new byte [] { sendLoopID, light.CurrentBrightness, light.DelayTimeHeight, light.DelayTimeLow }); + SendControl.SendControlSetSingleLight (light, new byte [] { sendLoopID, (byte)mSetBrightness, light.DelayTimeHeight, light.DelayTimeLow }); + }; if (light.CurrentBrightness > 0) { tempSwitch.IsSelected = true; } - } - else if (common.Type == DeviceType.LightRGB) { + } else if (common.Type == DeviceType.LightRGB) { LightCount++; var light = common as LightLogic; var lightView = new FrameLayout () { @@ -934,9 +1001,11 @@ for (int i = 0; i < EnergtLightList.Count; i++) { var c = EnergtLightList [i]; Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 10, c.LoopID }, SendCount.Zero); - if (c.Type == DeviceType.LightEnergySwitch) { - Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 11, c.LoopID }, SendCount.Zero); - } + ////if (c.Type == DeviceType.LightEnergySwitch) { + ////2020-07-01 瀹㈡埛鎻愬嚭闅愯棌kwh + //Control.ControlBytesSend (Command.ReadAnalogValue, c.SubnetID, c.DeviceID, new byte [] { 11, c.LoopID }, SendCount.Zero); + ////} + System.Threading.Thread.Sleep (200); } System.Threading.Thread.Sleep (10000); } catch { @@ -996,22 +1065,35 @@ } #endregion - Console.WriteLine ("L6"); + Utlis.WriteLine ("L6"); } + + static bool IsReadingAll = false; static System.Threading.Thread thread; /// <summary> /// 璇诲彇璁惧鐘舵�� /// </summary> - public static void readAllStatus (bool isRead = false) + /// <param name="isRead"> 鏄惁鎵�鏈夎鍙栵紝涓嶆槸鐨勮瘽鍙鍙栦竴鍒嗛挓鍐呮病鍒锋柊杩囩姸鎬佺殑璁惧</param> + /// <param name="isCheckIsReadingAll">鏄惁鍒ゆ柇璇诲彇涓爣蹇楋紝濡傛灉璇诲彇绾跨▼娌″畬鎴愯繕鍦ㄨ鍙栦腑锛屽氨涓嶅啀璇诲彇</param> + public static void readAllStatus (bool isRead = false, bool isCheckIsReadingAll = false) { + if (isCheckIsReadingAll) { + if (IsReadingAll && !isRead) { + Utlis.WriteLine ("============>IsReadingAll Light璇诲彇涓�"); + return; + } + } +#if DEBUG + Utlis.WriteLine ("============>readAllStatus Light 寮�濮嬭鍙�"); +#endif if (isRead) { foreach (Room room in Room.Lists) { if (room == null) { continue; } var list = room.DeviceList.FindAll ((obj) => { - return (obj.Type == DeviceType.LightDimming || obj.Type == DeviceType.LightSwitch || obj.Type == DeviceType.LightLogic || obj.Type == DeviceType.LightEnergySocket || obj.Type == DeviceType.LightEnergySwitch + return (obj.Type == DeviceType.LightDimming || obj.Type == DeviceType.LightSwitch || obj.Type == DeviceType.LightLogic || obj.Type == DeviceType.LightEnergySwitch || obj.Type == DeviceType.LightMixDimming || obj.Type == DeviceType.LightMixSwitch || obj.Type == DeviceType.FanModule); }); foreach (Common common in list) { @@ -1030,6 +1112,7 @@ } thread = new Thread (() => { try { + IsReadingAll = true; List<string> readList = new List<string> (); foreach (Room room in Room.Lists) { //if (string.IsNullOrEmpty(room.Name)) { @@ -1037,7 +1120,7 @@ //} var list = room.DeviceList.FindAll ((obj) => { return obj.LastUpdateTime.AddMinutes (Common.Time) <= DateTime.Now && (obj.Type == DeviceType.LightDimming || obj.Type == DeviceType.LightSwitch || obj.Type == DeviceType.LightLogic - || obj.Type == DeviceType.LightEnergySwitch || obj.Type == DeviceType.LightEnergySocket || obj.Type == DeviceType.LightMixDimming || obj.Type == DeviceType.LightMixSwitch || obj.Type == DeviceType.FanModule); + || obj.Type == DeviceType.LightEnergySwitch || obj.Type == DeviceType.LightMixDimming || obj.Type == DeviceType.LightMixSwitch || obj.Type == DeviceType.FanModule); }); foreach (Common common in list) { var s = common.Type + "_" + common.SubnetID + "_" + common.DeviceID; @@ -1046,8 +1129,8 @@ continue; } readList.Add (s); - Thread.Sleep (500); - Control.ControlBytesSendHasReturn (Command.ReadLightEquipmentAllLoopBrightness, common.SubnetID, common.DeviceID, new byte [] { }); + Thread.Sleep (200); + Control.ControlBytesSend (Command.ReadLightEquipmentAllLoopBrightness, common.SubnetID, common.DeviceID, new byte [] { }); } var listGRB = room.DeviceList.FindAll ((obj) => { return obj.LastUpdateTime.AddMinutes (Common.Time) <= DateTime.Now && (obj.Type == DeviceType.LightRGB); @@ -1059,15 +1142,39 @@ continue; } readList.Add (s); - Thread.Sleep (500); - Control.ControlBytesSendHasReturn (Command.ReadLogicLoopColor, common.SubnetID, common.DeviceID, new byte [] { common.LoopID }); + Thread.Sleep (200); + Control.ControlBytesSend (Command.ReadLogicLoopColor, common.SubnetID, common.DeviceID, new byte [] { common.LoopID }); } } - } catch { } finally { + + IsReadingAll = false; + } catch { + IsReadingAll = false; + } finally { thread = null; } }); thread.Start (); } + + + ///// <summary> + ///// //2020-02-10 甯﹁繑鍥炵粨鏋滅殑璋冨厜鎺у埗 + ///// </summary> + ///// <param name="mLightCommon"></param> + ///// <param name="sendBytes"></param> + //public static void SendControlSetSingleLight (Common mLightCommon, byte[] sendBytes) + //{ + // MainPage.Loading.Start ("Sending..."); + // System.Threading.Tasks.Task.Run (() => { + // byte [] returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, mLightCommon.SubnetID, mLightCommon.DeviceID, sendBytes); + // Application.RunOnMainThread (() => { + // if (returnBytes == null) { + // new Alert ("", mLightCommon.Name + ErrorCode.ControlFailure, "Close").Show (); + // } + // MainPage.Loading.Hide (); + // }); + // }); + //} } } \ No newline at end of file -- Gitblit v1.8.0