From 5eeafe3af80bfd88306bd8ad9e76c8f4b51ca35f Mon Sep 17 00:00:00 2001
From: hxb <hxb@hdlchina.com.cn>
Date: 星期四, 17 十二月 2020 14:16:20 +0800
Subject: [PATCH] 增加本地发送的重发机制

---
 HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs |  131 +++++++++++++++++++++++++------------------
 1 files changed, 77 insertions(+), 54 deletions(-)

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs
index c962b0c..428a93c 100644
--- a/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs
+++ b/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs
@@ -17,19 +17,19 @@
                     return;
                 if (uCurtain.functionType == bodyView.curtain.functionType && uCurtain.sid == bodyView.curtain.sid)
                 {
-                    if (uCurtain.trait_on_off.value.ToString() == "stop")
+                    if (uCurtain.trait_on_off.curValue.ToString() == "stop")
+                    {
+                        bodyView.btnCurtainOpen.IsSelected = false;
+                        bodyView.btnCurtainClose.IsSelected = false;
+                        bodyView.btnCurtainStop.IsSelected = true;
+                    }
+                    else if (uCurtain.trait_on_off.curValue.ToString() == "on")
                     {
                         bodyView.btnCurtainOpen.IsSelected = true;
                         bodyView.btnCurtainClose.IsSelected = false;
                         bodyView.btnCurtainStop.IsSelected = false;
                     }
-                    else if (uCurtain.trait_on_off.value.ToString() == "on")
-                    {
-                        bodyView.btnCurtainOpen.IsSelected = true;
-                        bodyView.btnCurtainClose.IsSelected = false;
-                        bodyView.btnCurtainStop.IsSelected = false;
-                    }
-                    else if (uCurtain.trait_on_off.value.ToString() == "off")
+                    else if (uCurtain.trait_on_off.curValue.ToString() == "off")
                     {
                         bodyView.btnCurtainOpen.IsSelected = false;
                         bodyView.btnCurtainClose.IsSelected = true;
@@ -58,6 +58,7 @@
             {
                 btnFunctionName.Text = btnFunctionName_Out.Text = curtain.name;
                 btnFromFloor_Out.Text = btnFromFoorAndRoom.Text = curtain.GetRoomListName();
+                //curtain.SaveFunctionData(true);
             };
         }
         /// <summary>
@@ -67,8 +68,8 @@
         {
             btnCollection.MouseUpEventHandler += (sender, e) =>
             {
-                btnCollection.IsSelected = curtain.collection = btnCollection_Out.IsSelected = !btnCollection.IsSelected;
-                curtain.SaveFunctionData();
+                btnCollection.IsSelected = curtain.collect = btnCollection_Out.IsSelected = !btnCollection.IsSelected;
+                curtain.SaveFunctionData(true);
             };
         }
 
@@ -82,28 +83,31 @@
                 btnCurtainClose.IsSelected = true;
                 btnCurtainStop.IsSelected = false;
                 btnCurtainOpen.IsSelected = false;
-                curtain.trait_on_off.value = "off";
+                curtain.trait_on_off.curValue = "off";
                 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.value.ToString());
-                Control.SendWriteCommand(curtain, d);
+                d.Add("on_off", curtain.trait_on_off.curValue.ToString());
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
             };
 
-            btnCurtainStop.MouseDownEventHandler = (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;
                 btnCurtainStop.IsSelected = true;
                 btnCurtainClose.IsSelected = false;
                 btnCurtainOpen.IsSelected = false;
-            };
-            btnCurtainStop.MouseUpEventHandler = (sender, e) =>
-            {
-                btnCurtainOpen.IsSelected = true;
-                btnCurtainClose.IsSelected = false;
-                btnCurtainStop.IsSelected = false;
-                curtain.trait_on_off.value = "stop";
+                curtain.trait_on_off.curValue = "stop";
                 System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>();
-                d.Add("on_off", curtain.trait_on_off.value.ToString());
-                Control.SendWriteCommand(curtain, d);
+                d.Add("on_off", curtain.trait_on_off.curValue.ToString());
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
             };
 
             btnCurtainOpen.MouseUpEventHandler = (sender, e) =>
@@ -111,69 +115,88 @@
                 btnCurtainOpen.IsSelected = true;
                 btnCurtainClose.IsSelected = false;
                 btnCurtainStop.IsSelected = false;
-                curtain.trait_on_off.value = "on";
+                curtain.trait_on_off.curValue = "on";
                 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.value.ToString());
-                Control.SendWriteCommand(curtain, d);
+                d.Add("on_off", curtain.trait_on_off.curValue.ToString());
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
             };
-
-            DateTime delayTime = DateTime.MinValue;
 
             btnMinusSignIcon.MouseUpEventHandler = (sender, e) =>
             {
-                delayTime = DateTime.MinValue;
                 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.SendWriteCommand(curtain, d);
-                //Control.Send(CommandType_A.write, curtain);
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
             };
 
             btnPlusSgnIcon.MouseUpEventHandler = (sender, e) =>
             {
-                delayTime = DateTime.MinValue;
                 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.SendWriteCommand(curtain, d);
+                DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
             };
 
-            curtainSeekBar.OnProgressChangedEvent = (sender, e) =>
+            //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) =>
             {
                 controlBar.Progress = curtainSeekBar.Progress;
                 new System.Threading.Thread(() =>
                 {
-                    if ((DateTime.Now - delayTime).TotalMilliseconds > 300)
-                    {
-                        delayTime = DateTime.Now;
-                        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);
-                    }
+                    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());
+                    DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
                 })
                 { IsBackground = true }.Start();
             };
 
-            controlBar.OnProgressChangedEvent = (sender, e) =>
+            //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) =>
             {
                 curtainSeekBar.Progress = controlBar.Progress;
                 new System.Threading.Thread(() =>
                 {
-                    MainPage.Log(delayTime.ToLongTimeString());
-                    if ((DateTime.Now - delayTime).TotalMilliseconds > 300)
-                    {
-                        delayTime = DateTime.Now;
-                        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);
-                    }
+                    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());
+                    DriverLayer.Control.Ins.SendWriteCommand(curtain, d);
                 })
                 { IsBackground = true }.Start();
             };

--
Gitblit v1.8.0