From 7232642ff48a7fbde2018cde652f3e771fa58025 Mon Sep 17 00:00:00 2001 From: wei <kaede@kaededeMacBook-Air.local> Date: 星期三, 27 一月 2021 14:32:55 +0800 Subject: [PATCH] 20200127-英文版处理 --- HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs | 172 +++++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 117 insertions(+), 55 deletions(-) diff --git a/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs old mode 100755 new mode 100644 index 428a93c..533498c --- a/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs +++ b/HDL_ON/UI/UI2/FuntionControlView/Curtain/MotorCurtainPageBLL.cs @@ -12,10 +12,12 @@ /// <param name="uCurtain"></param> public static void UpdataState(Curtain uCurtain) { - Application.RunOnMainThread(() => { + Application.RunOnMainThread((Action)(() => { if (bodyView == null) return; - if (uCurtain.functionType == bodyView.curtain.functionType && uCurtain.sid == bodyView.curtain.sid) + if (bodyView.onControl) + return; + if (uCurtain.spk == bodyView.curtain.spk && uCurtain.sid == bodyView.curtain.sid) { if (uCurtain.trait_on_off.curValue.ToString() == "stop") { @@ -35,15 +37,79 @@ bodyView.btnCurtainClose.IsSelected = true; bodyView.btnCurtainStop.IsSelected = false; } - if ((DateTime.Now - uCurtain.refreshTime).TotalMilliseconds > 300) + 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> /// 鍔犺浇浜嬩欢鍒楄〃 @@ -69,7 +135,7 @@ btnCollection.MouseUpEventHandler += (sender, e) => { btnCollection.IsSelected = curtain.collect = btnCollection_Out.IsSelected = !btnCollection.IsSelected; - curtain.SaveFunctionData(true); + curtain.CollectFunction(); }; } @@ -81,64 +147,60 @@ btnCurtainClose.MouseUpEventHandler = (sender, e) => { btnCurtainClose.IsSelected = true; - btnCurtainStop.IsSelected = false; btnCurtainOpen.IsSelected = false; + btnCurtainStop.IsSelected = false; curtain.trait_on_off.curValue = "off"; - curtain.percent = 0; + 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()); + 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) => { - //btnCurtainOpen.IsSelected = true; - //btnCurtainClose.IsSelected = false; - //btnCurtainStop.IsSelected = false; + btnCurtainStop.IsSelected = true; btnCurtainClose.IsSelected = false; btnCurtainOpen.IsSelected = false; 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.curValue.ToString()); + 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; + 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()); + 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()); - DriverLayer.Control.Ins.SendWriteCommand(curtain, d); - }; + //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(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()); - 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(FunctionAttributeKey.Percent, curtain.percent.ToString()); + // DriverLayer.Control.Ins.SendWriteCommand(curtain, d); + //}; //curtainSeekBar.OnProgressChangedEvent = (sender, e) => //{ @@ -158,13 +220,13 @@ //}; curtainSeekBar.OnStopTrackingTouchEvent = (sender, e) => { - controlBar.Progress = curtainSeekBar.Progress; + //controlBar.Progress = curtainSeekBar.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()); + d.Add(FunctionAttributeKey.Percent, curtain.percent.ToString()); DriverLayer.Control.Ins.SendWriteCommand(curtain, d); }) { IsBackground = true }.Start(); @@ -187,19 +249,19 @@ // { IsBackground = true }.Start(); //}; - controlBar.OnStopTrackingTouchEvent = (sender, e) => - { - 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()); - DriverLayer.Control.Ins.SendWriteCommand(curtain, d); - }) - { IsBackground = true }.Start(); - }; + //controlBar.OnStopTrackingTouchEvent = (sender, e) => + //{ + // 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()); + // DriverLayer.Control.Ins.SendWriteCommand(curtain, d); + // }) + // { IsBackground = true }.Start(); + //}; } } -- Gitblit v1.8.0