From d4811b7d34b45ff6b21b97f11da128b5572ec526 Mon Sep 17 00:00:00 2001 From: wei <kaede@kaededeMacBook-Air.local> Date: 星期三, 03 三月 2021 16:03:03 +0800 Subject: [PATCH] 20210303-1 --- HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs | 361 +++++++++++++++++++++++++++++---------------------- 1 files changed, 206 insertions(+), 155 deletions(-) diff --git a/HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs b/HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs index 70ba7eb..2fce988 100644 --- a/HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs +++ b/HDL_ON/UI/UI2/FuntionControlView/Curtain/RollingShutterPageBLL.cs @@ -12,38 +12,91 @@ /// <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.on_off == "stop") + var percentString = uCurtain.GetAttrState(FunctionAttributeKey.Percent); + int percent = 0; + int.TryParse(percentString, out percent); + bodyView.btnCurtainOpen.IsSelected = percent > 0; + bodyView.btnCurtainClose.IsSelected = percent == 0; + try { - bodyView.btnCurtainOpen.IsSelected = true; - bodyView.btnCurtainClose.IsSelected = false; - bodyView.btnCurtainStop.IsSelected = false; + if (!bodyView.onCurtainAnimation) + { + bodyView.CurtainAnimation(Convert.ToInt32(uCurtain.trait_percent.curValue.ToString())); + } } - 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; - } - if ((DateTime.Now - uCurtain.refreshTime).TotalMilliseconds > 300) - { - bodyView.controlBar.Progress = bodyView.curtainSeekBar.Progress = Convert.ToInt32(uCurtain.openLevel); - } - - + 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> /// 鍔犺浇浜嬩欢鍒楄〃 @@ -54,9 +107,11 @@ LoadCollectionEvent(); //鍥為��鍒锋柊淇℃伅浜嬩欢 - actionRefresh = () => { + actionRefresh = () => + { btnFunctionName.Text = btnFunctionName_Out.Text = curtain.name; btnFromFloor_Out.Text = btnFromFoorAndRoom.Text = curtain.GetRoomListName(); + //curtain.SaveFunctionData(true); }; } /// <summary> @@ -64,9 +119,10 @@ /// </summary> void LoadCollectionEvent() { - btnCollection.MouseUpEventHandler += (sender, e) => { - btnCollection.IsSelected = curtain.collection = btnCollection_Out.IsSelected = !btnCollection.IsSelected; - DB_ResidenceData.residenceData.SaveResidenceData(); + btnCollection.MouseUpEventHandler += (sender, e) => + { + btnCollection.IsSelected = curtain.collect = btnCollection_Out.IsSelected = !btnCollection.IsSelected; + curtain.CollectFunction(); }; } @@ -75,153 +131,148 @@ /// </summary> void LoadEvent_ControlEvent() { - btnCurtainClose.MouseUpEventHandler = (sender, e) => { - btnCurtainClose.IsSelected = true; - btnCurtainStop.IsSelected = false; - btnCurtainOpen.IsSelected = false; - curtain.on_off = "off"; - curtain.openLevel = 0; - //Control.Send(CommandType_A.write, curtain); + btnCurtainClose.MouseUpEventHandler = (sender, e) => + { + //new System.Threading.Thread(() => { + // System.Threading.Thread.Sleep(2000); + // Application.RunOnMainThread(() => { + // btnCurtainClose.IsSelected = false; + // }); + //}) + //{ IsBackground = true }.Start(); + 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.on_off.ToString()); - Control.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.MouseUpEventHandler = (sender, e) => + { + new System.Threading.Thread(() => { + System.Threading.Thread.Sleep(2000); + Application.RunOnMainThread(() => { + btnCurtainStop.IsSelected = false; + }); + }) + { IsBackground = true }.Start(); + curtain.trait_on_off.curValue = "stop"; + System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>(); + d.Add(FunctionAttributeKey.OnOff, curtain.trait_on_off.curValue.ToString()); + DriverLayer.Control.Ins.SendWriteCommand(curtain, d); + onCurtainAnimation = false; + }; + + btnCurtainOpen.MouseUpEventHandler = (sender, e) => + { + //new System.Threading.Thread(() => { + // System.Threading.Thread.Sleep(2000); + // Application.RunOnMainThread(() => { + // btnCurtainOpen.IsSelected = false; + // }); + //}) + //{ IsBackground = true }.Start(); + 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(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(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(FunctionAttributeKey.Percent, curtain.percent.ToString()); + DriverLayer.Control.Ins.SendWriteCommand(curtain, d); + }; + + + btnCurtainStop.MouseDownEventHandler = (sender, e) => + { btnCurtainStop.IsSelected = true; + }; + btnCurtainOpen.MouseDownEventHandler = (sender, e) => + { + btnCurtainOpen.IsSelected = true; btnCurtainClose.IsSelected = false; + }; + btnCurtainClose.MouseDownEventHandler = (sender, e) => + { + btnCurtainClose.IsSelected = true; 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); - System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>(); - d.Add("on_off", curtain.on_off.ToString()); - Control.SendWriteCommand(curtain, d); - }; - 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); - System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>(); - d.Add("on_off", curtain.on_off.ToString()); - Control.SendWriteCommand(curtain, d); - }; - DateTime delayTime = DateTime.MinValue; - - btnMinusSignIcon.MouseLongEventHandler = (sender, e) => { - //if (curtain.openLevel > 1) - //{ - // curtain.openLevel--; - // controlBar.Progress = curtainSeekBar.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.MinValue; - //Control.Send(CommandType_A.write, curtain); - curtain.openLevel--; - System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>(); - d.Add("openLevel", curtain.openLevel.ToString()); - Control.SendWriteCommand(curtain, d); - }; - - btnPlusSgnIcon.MouseLongEventHandler = (sender, e) => { - //if (curtain.openLevel > 1) - //{ - // curtain.openLevel++; - // controlBar.Progress = curtainSeekBar.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.MinValue; - //Control.Send(CommandType_A.write, curtain); - curtain.openLevel++; - System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>(); - d.Add("openLevel", curtain.openLevel.ToString()); - Control.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.openLevel = e; - //Control.Send(CommandType_A.write, curtain); - System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>(); - d.Add("openLevel", curtain.openLevel.ToString()); - Control.SendWriteCommand(curtain, d); - curtain.refreshTime = 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(FunctionAttributeKey.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.openLevel = e; - //Control.Send(CommandType_A.write, curtain); - System.Collections.Generic.Dictionary<string, string> d = new System.Collections.Generic.Dictionary<string, string>(); - d.Add("openLevel", curtain.openLevel.ToString()); - Control.SendWriteCommand(curtain, d); - curtain.refreshTime = 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()); + DriverLayer.Control.Ins.SendWriteCommand(curtain, d); }) { IsBackground = true }.Start(); }; -- Gitblit v1.8.0