From 965290476c027deb96891cde1095d9a100581a6b Mon Sep 17 00:00:00 2001 From: JLChen <551775569@qq.com> Date: 星期四, 20 二月 2020 09:13:32 +0800 Subject: [PATCH] 2020-02-20 1.优化更新。 --- Crabtree/SmartHome/UI/SimpleControl/Phone/Curtain/UserDeviceToCurtains.cs | 97 ++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 85 insertions(+), 12 deletions(-) diff --git a/Crabtree/SmartHome/UI/SimpleControl/Phone/Curtain/UserDeviceToCurtains.cs b/Crabtree/SmartHome/UI/SimpleControl/Phone/Curtain/UserDeviceToCurtains.cs index 22af010..99ffe19 100644 --- a/Crabtree/SmartHome/UI/SimpleControl/Phone/Curtain/UserDeviceToCurtains.cs +++ b/Crabtree/SmartHome/UI/SimpleControl/Phone/Curtain/UserDeviceToCurtains.cs @@ -185,22 +185,26 @@ curtainView.AddChidren (btnCloseCurtain); btnCloseCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainmodel.SubnetID, curtainmodel.DeviceID, new byte [] { curtainmodel.LoopID, 2 }); + + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainmodel.SubnetID, curtainmodel.DeviceID, new byte [] { curtainmodel.LoopID, 2 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtainmodel, new byte [] { curtainmodel.LoopID, 2 }); }; btnCloseCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; }; btnOpenCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainmodel.SubnetID, curtainmodel.DeviceID, new byte [] { curtainmodel.LoopID, 1 }); + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainmodel.SubnetID, curtainmodel.DeviceID, new byte [] { curtainmodel.LoopID, 1 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtainmodel, new byte [] { curtainmodel.LoopID, 1 }); }; btnOpenCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; }; btnStopCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainmodel.SubnetID, curtainmodel.DeviceID, new byte [] { curtainmodel.LoopID, 0 }); + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainmodel.SubnetID, curtainmodel.DeviceID, new byte [] { curtainmodel.LoopID, 0 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtainmodel, new byte [] { curtainmodel.LoopID, 0 }); }; btnStopCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; @@ -287,22 +291,25 @@ curtainView.AddChidren (btnCloseCurtain); btnCloseCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainroller.SubnetID, curtainroller.DeviceID, new byte [] { 1, 2 }); + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainroller.SubnetID, curtainroller.DeviceID, new byte [] { 1, 2 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtainroller, new byte [] { 1, 2 }); }; btnCloseCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; }; btnOpenCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainroller.SubnetID, curtainroller.DeviceID, new byte [] { 1, 1 }); + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainroller.SubnetID, curtainroller.DeviceID, new byte [] { 1, 1 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtainroller, new byte [] { 1, 1 }); }; btnOpenCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; }; btnStopCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainroller.SubnetID, curtainroller.DeviceID, new byte [] { 1, 0 }); + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtainroller.SubnetID, curtainroller.DeviceID, new byte [] { 1, 0 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtainroller, new byte [] { 1, 0 }); }; btnStopCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; @@ -388,22 +395,25 @@ curtainView.AddChidren (btnCloseCurtain); btnCloseCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtaintrietex.SubnetID, curtaintrietex.DeviceID, new byte [] { 1, 2 }); + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtaintrietex.SubnetID, curtaintrietex.DeviceID, new byte [] { 1, 2 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtaintrietex, new byte [] { 1, 2 }); }; btnCloseCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; }; btnOpenCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtaintrietex.SubnetID, curtaintrietex.DeviceID, new byte [] { 1, 1 }); + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtaintrietex.SubnetID, curtaintrietex.DeviceID, new byte [] { 1, 1 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtaintrietex, new byte [] { 1, 1 }); }; btnOpenCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; }; btnStopCurtain.MouseDownEventHandler += (sender3, e3) => { - Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtaintrietex.SubnetID, curtaintrietex.DeviceID, new byte [] { 1, 0 }); + //Control.ControlBytesSend (Command.UpdataCurtainModelStutas, curtaintrietex.SubnetID, curtaintrietex.DeviceID, new byte [] { 1, 0 }); (sender3 as Button).IsSelected = true; + SendControlUpdataCurtain (curtaintrietex, new byte [] { 1, 0 }); }; btnStopCurtain.MouseUpEventHandler += (sender3, e3) => { (sender3 as Button).IsSelected = false; @@ -450,12 +460,21 @@ } } + bool showTip = true; /// <summary> /// 鎺у埗鎵�鏈夌獥甯� /// </summary> /// <param name="status">1锛氬紑锛�2锛氬叧.</param> void controlAllCurtain (byte status) { + 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) @@ -464,18 +483,72 @@ continue; } foreach (var common in room.DeviceList) { + //2020-02-10 + byte [] returnBytes = null; if (common.Type == DeviceType.CurtainModel) { var curtainmodel = common as CurtainModel; - Control.ControlBytesSendHasReturn (Command.UpdataCurtainModelStutas, curtainmodel.SubnetID, curtainmodel.DeviceID, new byte [] { curtainmodel.LoopID, status }); + returnBytes = Control.ControlBytesSendHasReturn (Command.UpdataCurtainModelStutas, curtainmodel.SubnetID, curtainmodel.DeviceID, new byte [] { curtainmodel.LoopID, status }); } else if (common.Type == DeviceType.CurtainRoller) { var curtainroller = common as CurtainRoller; - Control.ControlBytesSendHasReturn (Command.UpdataCurtainModelStutas, curtainroller.SubnetID, curtainroller.DeviceID, new byte [] { curtainroller.LoopID, status }); + returnBytes = Control.ControlBytesSendHasReturn (Command.UpdataCurtainModelStutas, curtainroller.SubnetID, curtainroller.DeviceID, new byte [] { curtainroller.LoopID, status }); } else if (common.Type == DeviceType.CurtainTrietex) { var curtaintrietex = common as CurtainTrietex; - Control.ControlBytesSendHasReturn (Command.UpdataCurtainModelStutas, curtaintrietex.SubnetID, curtaintrietex.DeviceID, new byte [] { curtaintrietex.LoopID, status }); + returnBytes = Control.ControlBytesSendHasReturn (Command.UpdataCurtainModelStutas, curtaintrietex.SubnetID, curtaintrietex.DeviceID, new byte [] { curtaintrietex.LoopID, status }); + } else { + continue; + } + + if (showTip) { + if (returnBytes == null) { + Application.RunOnMainThread (() => { + + string tipString = ErrorCode.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 (); + showTip = false; + }; + + System.Threading.Tasks.Task.Run (() => { + System.Threading.Thread.Sleep (3000); + Application.RunOnMainThread (() => { + btnTip.RemoveFromParent (); + }); + }); + + }); + } } } } + + Application.RunOnMainThread (() => { + MainPage.Loading.Hide (); + }); + }); + } + + /// <summary> + /// //2020-02-10 甯﹁繑鍥炵粨鏋滅殑淇敼绐楀笜鐘舵�� + /// </summary> + /// <param name="mLightCommon"></param> + /// <param name="sendBytes"></param> + public static void SendControlUpdataCurtain (Common mCurtainCommon, byte [] sendBytes) + { + MainPage.Loading.Start ("Sending..."); + System.Threading.Tasks.Task.Run (() => { + byte [] returnBytes = Control.ControlBytesSendHasReturn (Command.UpdataCurtainModelStutas, mCurtainCommon.SubnetID, mCurtainCommon.DeviceID, sendBytes); + Application.RunOnMainThread (() => { + if (returnBytes == null) { + new Alert ("", mCurtainCommon.Name + ErrorCode.ControlFailure, "Close").Show (); + } + MainPage.Loading.Hide (); + }); }); } -- Gitblit v1.8.0