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/Fan/UserDeviceToFan.cs | 181 +++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 166 insertions(+), 15 deletions(-) diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Fan/UserDeviceToFan.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Fan/UserDeviceToFan.cs index 045c17f..fe07496 100644 --- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Fan/UserDeviceToFan.cs +++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Fan/UserDeviceToFan.cs @@ -92,7 +92,7 @@ #region 鏄剧ず int devcieCount = 0; foreach (var room in Room.Lists) { - if (string.IsNullOrEmpty(room.Name)) { + if (string.IsNullOrEmpty (room.Name)) { continue; } foreach (var common in room.DeviceList) { @@ -140,13 +140,38 @@ }; fanView.AddChidren (tempSiwtch); tempSiwtch.MouseUpEventHandler += (sender3, e3) => { - tempSiwtch.IsSelected = !tempSiwtch.IsSelected; - if (tempSiwtch.IsSelected) { - fanModule.Switch = fanModule.WindSpeed; - } else { - fanModule.Switch = 0; - } - Control.ControlBytesSend (Command.SetSingleLight, fanModule.SubnetID, fanModule.DeviceID, new byte [] { fanModule.LoopID, fanModule.Switch }); + //tempSiwtch.IsSelected = !tempSiwtch.IsSelected; + //if (tempSiwtch.IsSelected) { + // fanModule.Switch = fanModule.WindSpeed; + //} else { + // fanModule.Switch = 0; + //} + //Control.ControlBytesSend (Command.SetSingleLight, fanModule.SubnetID, fanModule.DeviceID, new byte [] { fanModule.LoopID, fanModule.Switch }); + + //2020-02-10 + MainPage.Loading.Start ("Sending..."); + //tempSiwtch.IsSelected = !tempSiwtch.IsSelected; + //if (tempSiwtch.IsSelected) { + // fanModule.Switch = fanModule.WindSpeed; + //} else { + // fanModule.Switch = 0; + //} + + if (fanModule.WindSpeed == 0) fanModule.WindSpeed = 1; + + int mSetSwitch = tempSiwtch.IsSelected ? 0 : fanModule.WindSpeed; + + System.Threading.Tasks.Task.Run (() => { + byte [] returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, fanModule.SubnetID, fanModule.DeviceID, new byte [] { fanModule.LoopID, (byte)mSetSwitch }); + Application.RunOnMainThread (() => { + if (returnBytes == null) { + //string tipString = Language.StringByID (R.MyInternationalizationString.ControlFailure); + new Alert ("", fanModule.Name + ErrorCode.ControlFailure, "Close").Show (); + + } + MainPage.Loading.Hide (); + }); + }); }; Button btnViewNull = new Button () { @@ -202,7 +227,7 @@ Application.RunOnMainThread (() => { int brighingCount = 0; foreach (var room in Room.Lists) { - if (string.IsNullOrEmpty(room.Name)) { + if (string.IsNullOrEmpty (room.Name)) { continue; } foreach (var light in room.DeviceList) { @@ -217,10 +242,13 @@ }); #endregion - if (curView == null || curView.bodyScrolView.Decelerating) { - return; - } + //if (curView == null || curView.bodyScrolView.Decelerating) { + // return; + //} Application.RunOnMainThread (() => { + if (curView == null || curView.bodyScrolView.Decelerating) { + return; + } for (int i = 0; i < curView.bodyScrolView.ChildrenCount; i++) { if (curView.bodyScrolView.GetChildren (i).GetType () == typeof (FrameLayout)) { var lightRow = (FrameLayout)curView.bodyScrolView.GetChildren (i); @@ -244,8 +272,14 @@ void ControlAllFan (bool open) { + if (CommonPage.IsRemote) { + if (!SmartHome.MqttCommon.IsGatewayOnline) { + new Alert ("", "Gateway offline" + ErrorCode.ControlFailure, "Close").Show (); + return; + } + } MainPage.Loading.Start ("Sending..."); - + bool showTip = true; System.Threading.Tasks.Task.Run (() => { foreach (var room in Room.Lists) { if (room == null) @@ -253,12 +287,48 @@ if (string.IsNullOrEmpty (room.Name)) { continue; } + foreach (var fanD in room.DeviceList) { + //2020-02-10 + byte [] returnBytes = null; if (fanD.Type == DeviceType.FanModule) { if (open) { - Control.ControlBytesSend (Command.SetSingleLight, fanD.SubnetID, fanD.DeviceID, new byte [] { fanD.LoopID, (fanD as FanModule).WindSpeed }); + + if ((fanD as FanModule).WindSpeed == 0) (fanD as FanModule).WindSpeed = 1; + + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, fanD.SubnetID, fanD.DeviceID, new byte [] { fanD.LoopID, (fanD as FanModule).WindSpeed }); } else { - Control.ControlBytesSend (Command.SetSingleLight, fanD.SubnetID, fanD.DeviceID, new byte [] { fanD.LoopID, 0 }); + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, fanD.SubnetID, fanD.DeviceID, new byte [] { fanD.LoopID, 0 }); + } + + + if (showTip) { + if (returnBytes == null) { + Application.RunOnMainThread (() => { + + string tipString = Language.StringByID (R.MyInternationalizationString.ControlFailure); + var btnTip = new Button () { + Height = Application.GetRealHeight (140), + Text = fanD.Name + tipString,// + "..." + controlDeviceIndex.ToString () + @"/" + sceneDeviceCount.ToString (), + 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); + }); + }); + + }); + } } } } @@ -268,5 +338,86 @@ }); }); } + + void ControlAllFanNew (bool open) + { + if (CommonPage.IsRemote) { + if (!SmartHome.MqttCommon.IsGatewayOnline) { + new Alert ("", "Gateway offline" + ErrorCode.ControlFailure, "Close").Show (); + return; + } + } + MainPage.Loading.Start ("Sending..."); + bool showTip = true; + System.Threading.Tasks.Task.Run (() => { + int mSendCount = 0; + + foreach (var room in Room.Lists) { + if (room == null) + continue; + if (string.IsNullOrEmpty (room.Name)) { + continue; + } + + foreach (var fanD in room.DeviceList) { + //2020-02-10 + byte [] returnBytes = null; + if (fanD.Type == DeviceType.FanModule) { + System.Threading.Tasks.Task.Run (() => { + mSendCount++; + if (open) { + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, fanD.SubnetID, fanD.DeviceID, new byte [] { fanD.LoopID, (fanD as FanModule).WindSpeed }); + } else { + returnBytes = Control.ControlBytesSendHasReturn (Command.SetSingleLight, fanD.SubnetID, fanD.DeviceID, new byte [] { fanD.LoopID, 0 }); + } + + + if (showTip) { + if (returnBytes == null) { + Application.RunOnMainThread (() => { + + string tipString = Language.StringByID (R.MyInternationalizationString.ControlFailure); + var btnTip = new Button () { + Height = Application.GetRealHeight (140), + Text = fanD.Name + tipString,// + "..." + controlDeviceIndex.ToString () + @"/" + sceneDeviceCount.ToString (), + 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--; + }); + + //绛夊緟100ms鍐嶅彂閫佺浜屼釜璁惧鏁版嵁 + System.Threading.Thread.Sleep (100); + + } + } + } + + while (mSendCount > 0) { + System.Threading.Thread.Sleep (100); + } + + Application.RunOnMainThread (() => { + MainPage.Loading.Hide (); + }); + }); + } } } \ No newline at end of file -- Gitblit v1.8.0