From fb49279fd0e36e1ed2bd7332eecee9f963c13649 Mon Sep 17 00:00:00 2001
From: wei <kaede@kaededeMacBook-Air.local>
Date: 星期日, 20 十二月 2020 19:33:29 +0800
Subject: [PATCH] 20201220-1

---
 HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs |  177 ++++++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 132 insertions(+), 45 deletions(-)

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs
old mode 100755
new mode 100644
index 1339b70..4928915
--- a/HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs
+++ b/HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs
@@ -1,5 +1,4 @@
 锘縰sing System;
-using HDL_ON.DriverLayer;
 using HDL_ON.Entity;
 using Shared;
 
@@ -7,8 +6,6 @@
 {
     public partial class RollingShutterPage
     {
-        bool inControl = false;
-
         /// <summary>
         /// 鏇存柊绐楀笜
         /// </summary>
@@ -17,6 +14,8 @@
         {
             Application.RunOnMainThread(() => {
                 if (bodyView == null)
+                    return;
+                if (bodyView.onControl)
                     return;
                 if (uCurtain.functionType == bodyView.curtain.functionType && uCurtain.sid == bodyView.curtain.sid)
                 {
@@ -38,13 +37,79 @@
                         bodyView.btnCurtainClose.IsSelected = true;
                         bodyView.btnCurtainStop.IsSelected = false;
                     }
-                    if ((DateTime.Now - uCurtain.refreshTime).TotalMilliseconds > 300 && !bodyView.inControl)
+                    try
                     {
-                        bodyView.controlBar.Progress = bodyView.curtainSeekBar.Progress = Convert.ToInt32(uCurtain.percent);
+                        if (!bodyView.onCurtainAnimation)
+                        {
+                            bodyView.CurtainAnimation(Convert.ToInt32(uCurtain.trait_percent.curValue.ToString()));
+                        }
                     }
+                    catch { }
                 }
             });
         }
+
+        /// <summary>
+        /// 姝e湪鎵ц绐楀笜鍔ㄧ敾
+        /// </summary>
+        bool onCurtainAnimation = false;
+        /// <summary>
+        /// 绐楀笜鍔ㄧ敾
+        /// </summary>
+        /// <param name="progress"></param>
+        void CurtainAnimation(int progress)
+        {
+            onCurtainAnimation = true;
+            //杩愯鏂瑰悜 鎵撳紑锛堝姞杩涘害锛夛細鍏抽棴锛堝噺杩涘害锛�
+            bool runningDirection = progress > curtainSeekBar.Progress;
+            int curBarProgress = curtainSeekBar.Progress;
+            new System.Threading.Thread(() =>
+            {
+                try
+                {
+                    while (progress != curBarProgress && onCurtainAnimation)
+                    {
+                        Application.RunOnMainThread(() =>
+                        {
+                            if (runningDirection)
+                            {
+                                if (curtainSeekBar.Progress + 10 > progress)
+                                {
+                                    curtainSeekBar.Progress = progress;
+                                }
+                                else
+                                {
+                                    curtainSeekBar.Progress = curtainSeekBar.Progress + 10;
+                                }
+                            }
+                            else
+                            {
+                                if (curtainSeekBar.Progress - 10 < progress)
+                                {
+                                    curtainSeekBar.Progress = progress;
+                                }
+                                else
+                                {
+                                    curtainSeekBar.Progress = curtainSeekBar.Progress - 10;
+                                }
+                            }
+                            curBarProgress = curtainSeekBar.Progress;
+                        });
+                        System.Threading.Thread.Sleep(100);
+                    }
+                }
+                catch { }
+                finally
+                {
+                    new System.Threading.Thread(() => {
+                        System.Threading.Thread.Sleep(3000);
+                        onCurtainAnimation = false;
+                    })
+                    { IsBackground = true, Priority = System.Threading.ThreadPriority.Lowest }.Start();
+                }
+            }).Start();
+        }
+
 
         /// <summary>
         /// 鍔犺浇浜嬩欢鍒楄〃
@@ -59,7 +124,7 @@
             {
                 btnFunctionName.Text = btnFunctionName_Out.Text = curtain.name;
                 btnFromFloor_Out.Text = btnFromFoorAndRoom.Text = curtain.GetRoomListName();
-                curtain.SaveFunctionData(true);
+                //curtain.SaveFunctionData(true);
             };
         }
         /// <summary>
@@ -81,99 +146,121 @@
         {
             btnCurtainClose.MouseUpEventHandler = (sender, e) =>
             {
+                btnCurtainOpen.IsSelected = false;
                 btnCurtainClose.IsSelected = true;
                 btnCurtainStop.IsSelected = false;
-                btnCurtainOpen.IsSelected = false;
                 curtain.trait_on_off.curValue = "off";
-                curtain.percent = 0;
-                //Control.Send(CommandType_A.write, curtain);
+                curtain.percent = 100;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("on_off", curtain.trait_on_off.curValue.ToString());
-                Control.Ins.SendWriteCommand(curtain, d);
+                d.Add(FunctionAttributeKey.OnOff, curtain.trait_on_off.curValue.ToString());
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
+                CurtainAnimation(curtain.percent);
             };
 
-            //btnCurtainStop.MouseDownEventHandler = (sender, e) =>
-            //{
-            //    btnCurtainStop.IsSelected = true;
-            //    btnCurtainClose.IsSelected = false;
-            //    btnCurtainOpen.IsSelected = false;
-            //};
             btnCurtainStop.MouseUpEventHandler = (sender, e) =>
             {
                 btnCurtainStop.IsSelected = true;
                 btnCurtainClose.IsSelected = false;
                 btnCurtainOpen.IsSelected = false;
                 curtain.trait_on_off.curValue = "stop";
-                //Control.Send(CommandType_A.write, curtain);
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("on_off", curtain.trait_on_off.curValue.ToString());
-                Control.Ins.SendWriteCommand(curtain, d);
+                d.Add(FunctionAttributeKey.OnOff, curtain.trait_on_off.curValue.ToString());
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
+                onCurtainAnimation = false;
             };
 
             btnCurtainOpen.MouseUpEventHandler = (sender, e) =>
             {
-                btnCurtainOpen.IsSelected = true;
                 btnCurtainClose.IsSelected = false;
                 btnCurtainStop.IsSelected = false;
+                btnCurtainOpen.IsSelected = true;
                 curtain.trait_on_off.curValue = "on";
-                curtain.percent = 100;
-                //Control.Send(CommandType_A.write, curtain);
+                curtain.percent = 0;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("on_off", curtain.trait_on_off.curValue.ToString());
-                Control.Ins.SendWriteCommand(curtain, d);
+                d.Add(FunctionAttributeKey.OnOff, curtain.trait_on_off.curValue.ToString());
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
+                CurtainAnimation(curtain.percent);
             };
-
 
             btnMinusSignIcon.MouseUpEventHandler = (sender, e) =>
             {
                 curtain.percent--;
+                controlBar.Progress = curtain.percent;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("percent", curtain.percent.ToString());
-                Control.Ins.SendWriteCommand(curtain, d);
+                d.Add(FunctionAttributeKey.Percent, curtain.percent.ToString());
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
             };
 
             btnPlusSgnIcon.MouseUpEventHandler = (sender, e) =>
             {
                 curtain.percent++;
+                controlBar.Progress = curtain.percent;
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("percent", curtain.percent.ToString());
-                Control.Ins.SendWriteCommand(curtain, d);
+                d.Add(FunctionAttributeKey.Percent, curtain.percent.ToString());
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
             };
-            curtainSeekBar.OnStartTrackingTouchEvent = (sender, e) =>
-            {
-                inControl = true;
-            };
+
+            //curtainSeekBar.OnProgressChangedEvent = (sender, e) =>
+            //{
+            //    controlBar.Progress = curtainSeekBar.Progress;
+            //    new System.Threading.Thread(() =>
+            //    {
+            //        if (controlBar.Progress == 0 || controlBar.Progress == 100 || (DateTime.Now - curtain.refreshTime).TotalMilliseconds > 300)
+            //        {
+            //            curtain.percent = e;
+            //            curtain.refreshTime = DateTime.Now;
+            //            System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+            //            d.Add("percent", curtain.percent.ToString());
+            //            Control.SendWriteCommand(curtain, d);
+            //        }
+            //    })
+            //    { IsBackground = true }.Start();
+            //};
             curtainSeekBar.OnStopTrackingTouchEvent = (sender, e) =>
             {
-                inControl = false;
+                controlBar.Progress = curtainSeekBar.Progress;
                 new System.Threading.Thread(() =>
                 {
                     curtain.percent = e;
-                    System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                    d.Add("percent", curtain.percent.ToString());
-                    Control.Ins.SendWriteCommand(curtain, d);
                     curtain.refreshTime = DateTime.Now;
+                    System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+                    d.Add(FunctionAttributeKey.Percent, curtain.percent.ToString());
+                    DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
                 })
                 { IsBackground = true }.Start();
             };
 
-            controlBar.OnStartTrackingTouchEvent = (sender, e) =>
-            {
-                inControl = true;
-            };
+            //controlBar.OnProgressChangedEvent = (sender, e) =>
+            //{
+            //    curtainSeekBar.Progress = controlBar.Progress;
+            //    new System.Threading.Thread(() =>
+            //    {
+            //        if (controlBar.Progress == 0 || controlBar.Progress == 100 || (DateTime.Now - curtain.refreshTime).TotalMilliseconds > 300)
+            //        {
+            //            curtain.percent = e;
+            //            curtain.refreshTime = DateTime.Now;
+            //            System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
+            //            d.Add("percent", curtain.percent.ToString());
+            //            Control.SendWriteCommand(curtain, d);
+            //        }
+            //    })
+            //    { IsBackground = true }.Start();
+            //};
+
             controlBar.OnStopTrackingTouchEvent = (sender, e) =>
             {
-                inControl = false;
+                curtainSeekBar.Progress = controlBar.Progress;
                 new System.Threading.Thread(() =>
                 {
                     curtain.percent = e;
+                    curtain.refreshTime = DateTime.Now;
                     System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
                     d.Add("percent", curtain.percent.ToString());
-                    Control.Ins.SendWriteCommand(curtain, d);
-                    curtain.refreshTime = DateTime.Now;
+                    DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
                 })
                 { IsBackground = true }.Start();
             };
+
         }
     }
 }

--
Gitblit v1.8.0