From 002a3f2e9d2f9579c01f88af12bd8a320003569f Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期二, 31 三月 2020 08:57:19 +0800
Subject: [PATCH] 20200331

---
 HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs |  155 +++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 137 insertions(+), 18 deletions(-)

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs
index db73b20..1513d35 100644
--- a/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs
+++ b/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs
@@ -1,10 +1,46 @@
 锘縰sing System;
 using HDL_ON.Entity;
+using Shared;
 
 namespace HDL_ON.UI
 {
     public partial class MotorCurtainPage
     {
+        /// <summary>
+        /// 鏇存柊绐楀笜
+        /// </summary>
+        /// <param name="uCurtain"></param>
+        public static void UpdataState(Curtain uCurtain)
+        {
+            Application.RunOnMainThread(() => {
+                if (bodyView == null)
+                    return;
+                if (uCurtain.functionType == bodyView.curtain.functionType && uCurtain.sid == bodyView.curtain.sid)
+                {
+                    if (uCurtain.on_off == "stop")
+                    {
+                        bodyView.btnCurtainOpen.IsSelected = true;
+                        bodyView.btnCurtainClose.IsSelected = false;
+                        bodyView.btnCurtainStop.IsSelected = false;
+                    }
+                    else if (uCurtain.on_off == "on")
+                    {
+                        bodyView.btnCurtainOpen.IsSelected = true;
+                        bodyView.btnCurtainClose.IsSelected = false;
+                        bodyView.btnCurtainStop.IsSelected = false;
+                    }
+                    else if (uCurtain.on_off == "off")
+                    {
+                        bodyView.btnCurtainOpen.IsSelected = false;
+                        bodyView.btnCurtainClose.IsSelected = true;
+                        bodyView.btnCurtainStop.IsSelected = false;
+                    }
+                    bodyView.controlBar.Progress = bodyView.curtainSeekBar.Progress = Convert.ToInt32(uCurtain.openLevel);
+
+                }
+            });
+        }
+
         /// <summary>
         /// 鍔犺浇浜嬩欢鍒楄〃
         /// </summary>
@@ -15,8 +51,8 @@
 
             //鍥為��鍒锋柊淇℃伅浜嬩欢
             actionRefresh = () => {
-                btnFunctionName.Text = btnFunctionName_Out.Text = function.name;
-                btnFromFloor_Out.Text = btnFromFoorAndRoom.Text = function.GetRoomListName();
+                btnFunctionName.Text = btnFunctionName_Out.Text = curtain.name;
+                btnFromFloor_Out.Text = btnFromFoorAndRoom.Text = curtain.GetRoomListName();
             };
         }
         /// <summary>
@@ -25,36 +61,119 @@
         void LoadCollectionEvent()
         {
             btnCollection.MouseUpEventHandler += (sender, e) => {
-                btnCollection.IsSelected = function.collection = btnCollection_Out.IsSelected = !btnCollection.IsSelected;
+                btnCollection.IsSelected = curtain.collection = btnCollection_Out.IsSelected = !btnCollection.IsSelected;
                 DB_ResidenceData.residenceData.SaveResidenceData();
             };
         }
 
         /// <summary>
-        /// 鍔犺浇绐楀笜寮�鍏冲仠鎸夐挳鎺у埗浜嬩欢
+        /// 鍔犺浇绐楀笜鎺у埗浜嬩欢
         /// </summary>
         void LoadEvent_ControlEvent()
         {
-            btnCurtainClose.MouseDownEventHandler += (sender, e) => {
+            btnCurtainClose.MouseUpEventHandler = (sender, e) => {
                 btnCurtainClose.IsSelected = true;
-            };
-            btnCurtainClose.MouseUpEventHandler += (sender, e) => {
-                btnCurtainClose.IsSelected = false;
-            };
-
-            btnCurtainStop.MouseDownEventHandler += (sender, e) => {
-                btnCurtainStop.IsSelected = true;
-            };
-            btnCurtainStop.MouseUpEventHandler += (sender, e) => {
                 btnCurtainStop.IsSelected = false;
+                btnCurtainOpen.IsSelected = false;
+                curtain.on_off = "off";
+                curtain.openLevel = 0;
+                Control.Send(CommandType_A.write, curtain);
             };
 
-            btnCurtainOpen.MouseDownEventHandler += (sender, e) => {
-                btnCurtainOpen.IsSelected = true;
-            };
-            btnCurtainOpen.MouseUpEventHandler += (sender, e) => {
+            btnCurtainStop.MouseDownEventHandler = (sender, e) => {
+                btnCurtainStop.IsSelected = true;
+                btnCurtainClose.IsSelected = false;
                 btnCurtainOpen.IsSelected = false;
             };
+            btnCurtainStop.MouseUpEventHandler = (sender, e) => {
+                btnCurtainOpen.IsSelected = true;
+                btnCurtainClose.IsSelected = false;
+                btnCurtainStop.IsSelected = false;
+                curtain.on_off = "stop";
+                Control.Send(CommandType_A.write, curtain);
+            };
+
+            btnCurtainOpen.MouseUpEventHandler = (sender, e) => {
+                btnCurtainOpen.IsSelected = true;
+                btnCurtainClose.IsSelected = false;
+                btnCurtainStop.IsSelected = false;
+                curtain.on_off = "on";
+                curtain.openLevel = 100;
+                Control.Send(CommandType_A.write, curtain);
+            };
+
+            DateTime delayTime = DateTime.MinValue;
+
+            btnMinusSignIcon.MouseDownEventHandler = (sender, e) => {
+                if (curtain.openLevel > 1)
+                {
+                    curtain.openLevel--;
+                    controlBar.Progress = curtain.openLevel;
+                    delayTime = DateTime.Now;
+                    new System.Threading.Thread(() => {
+                        while(delayTime != DateTime.MaxValue)
+                        {
+                            System.Threading.Thread.Sleep(100);
+                            if((DateTime.Now - delayTime).TotalSeconds > 1)
+                            {
+                                if (curtain.openLevel < 1)
+                                {
+                                    break;
+                                }
+                                curtain.openLevel--;
+                                Application.RunOnMainThread(() => {
+                                    controlBar.Progress = curtain.openLevel;
+                                });
+                            }
+                        }
+                    }) { IsBackground = true }.Start();
+                }
+            };
+            btnMinusSignIcon.MouseUpEventHandler = (sender, e) => {
+                delayTime = DateTime.MaxValue;
+                Control.Send(CommandType_A.write, curtain);
+            };
+
+            btnPlusSgnIcon.MouseDownEventHandler = (sender, e) => {
+                if (curtain.openLevel > 1)
+                {
+                    curtain.openLevel++;
+                    controlBar.Progress = curtain.openLevel;
+                    delayTime = DateTime.Now;
+                    new System.Threading.Thread(() => {
+                        while (delayTime != DateTime.MaxValue)
+                        {
+                            System.Threading.Thread.Sleep(100);
+                            if ((DateTime.Now - delayTime).TotalSeconds > 1)
+                            {
+                                if (curtain.openLevel > 99)
+                                {
+                                    break;
+                                }
+                                curtain.openLevel++;
+                                Application.RunOnMainThread(() => {
+                                    controlBar.Progress = curtain.openLevel;
+                                });
+                            }
+                        }
+                    })
+                    { IsBackground = true }.Start();
+                }
+            };
+            btnPlusSgnIcon.MouseUpEventHandler = (sender, e) => {
+                delayTime = DateTime.MaxValue;
+                Control.Send(CommandType_A.write, curtain);
+            };
+
+            curtainSeekBar.OnProgressChangedEvent = (sender, e) =>
+            {
+                if ((DateTime.Now - delayTime).TotalMilliseconds > 300)
+                {
+                    delayTime = DateTime.Now;
+                    curtain.openLevel = e;
+                    Control.Send(CommandType_A.write, curtain);
+                }
+            };
 
         }
     }

--
Gitblit v1.8.0