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