From efcffde735fa65ae34bae0bcc86313b74ed0e36c Mon Sep 17 00:00:00 2001 From: wxr <464027401@qq.com> Date: 星期一, 20 五月 2024 13:47:38 +0800 Subject: [PATCH] 优化离线数据 --- HDL_ON/UI/UI2/1-HomePage/HomePageBLL.cs | 197 +++++++++++++++++++++++++------------------------ 1 files changed, 101 insertions(+), 96 deletions(-) diff --git a/HDL_ON/UI/UI2/1-HomePage/HomePageBLL.cs b/HDL_ON/UI/UI2/1-HomePage/HomePageBLL.cs index 564dd00..d47510b 100644 --- a/HDL_ON/UI/UI2/1-HomePage/HomePageBLL.cs +++ b/HDL_ON/UI/UI2/1-HomePage/HomePageBLL.cs @@ -33,7 +33,7 @@ } if (btn.Tag.ToString() == function.sid) { - if (function.online) + if (function.isOnline()) { btn.UnSelectedImagePath = "Collection/Functionbg.png"; btn.IsSelected = false; @@ -46,7 +46,7 @@ } else if (btn.Tag.ToString() == "OnlineTag") { - btn.Visible = !function.online; + btn.Visible = !function.isOnline(); } } } @@ -238,6 +238,25 @@ } /// <summary> + /// 鏇存柊鍔熻兘缁勬帶涓婚〉 + /// </summary> + public static void RefreshGroupControlView() + { + if (bodyView != null) + { + + if (FunctionList.List.groupControls.Count == 0) + { + bodyView.loadNavView(); + bodyView.contentView.PageIndex = 0; + } + bodyView.LoadGroupControlFunctionControlZone(); + } + } + + + + /// <summary> /// 鏇存柊杩炴帴鐘舵�佸浘鏍� /// </summary> void CheckLinkStatus() @@ -250,15 +269,15 @@ if (!Control.Ins.GatewayOnline_Local && !Control.Ins.GatewayOnline_Cloud) { - bodyView.btnLinkStateTip.BackgroundColor = CSS.CSS_Color.LinkTipFail; - bodyView.btnLinkStateTip.TextID = StringId.NetworkAnomaly; - bodyView.environmentalView.Y = Application.GetRealHeight(8) + btnResidenceName.Bottom; + bodyView.divLinkStateTip.Visible = true; } + //else if () + //{ + // bodyView.divLinkStateTip.Visible = true; + //} else { - bodyView.btnLinkStateTip.BackgroundColor = 0x00000000; - bodyView.btnLinkStateTip.Text = ""; - bodyView.environmentalView.Y = Application.GetRealHeight(1) + btnResidenceName.Bottom; + bodyView.divLinkStateTip.Visible = false; } } @@ -269,9 +288,15 @@ { Application.RunOnMainThread(() => { - if (bodyView != null) + try { - bodyView.CheckLinkStatus(); + if (bodyView != null) + { + bodyView.CheckLinkStatus(); + } + }catch(Exception ex) + { + MainPage.Log($"LoadEvent_CheckLinkStatus : {ex.Message}"); } }); } @@ -319,66 +344,24 @@ /// </summary> void LoadEvent_ChangeShowedFunctionType() { - btnChangeFunction.MouseUpEventHandler = (sender, e) => + + if (DB_ResidenceData.Instance.HomeGateway.isSupportGroupControl && FunctionList.List.groupControls.Count>0) { - - btnChangeFunction.IsSelected = true; - btnChangeFunction.TextSize = CSS.CSS_FontSize.HeadlineFontSize; - btnChangeFunction.IsBold = true; - btnChangeScene.TextSize = CSS.CSS_FontSize.TextFontSize; - btnChangeScene.IsSelected = false; - btnChangeScene.IsBold = false; - CurShowTypeIsFunction = true; - contentView.PageIndex = 0; - }; - //var client = new BlufiClient(); - //client.PostPackageLengthLimit = 128; - //client.RequestDeviceScan(); - //client.RequestDeviceStatus(); - //client.BlufiDelegate.Blufi_DidReceiveDeviceScanResponse(); - - - btnChangeScene.MouseUpEventHandler = (sender, e) => - { - btnChangeScene.IsSelected = true; - btnChangeScene.TextSize = CSS.CSS_FontSize.HeadlineFontSize; - btnChangeScene.IsBold = true; - btnChangeFunction.TextSize = CSS.CSS_FontSize.TextFontSize; - btnChangeFunction.IsSelected = false; - btnChangeFunction.IsBold = false; - CurShowTypeIsFunction = false; - contentView.PageIndex = 1; - }; - - contentView.PageChange = (sender, e) => - { - if (contentView.PageIndex == 0) - { - btnChangeFunction.IsSelected = true; - btnChangeFunction.TextSize = CSS.CSS_FontSize.HeadlineFontSize; - btnChangeFunction.IsBold = true; - btnChangeScene.TextSize = CSS.CSS_FontSize.TextFontSize; - btnChangeScene.IsSelected = false; - btnChangeScene.IsBold = false; - } - else - { - btnChangeScene.IsSelected = true; - btnChangeScene.TextSize = CSS.CSS_FontSize.HeadlineFontSize; - btnChangeScene.IsBold = true; - btnChangeFunction.TextSize = CSS.CSS_FontSize.TextFontSize; - btnChangeFunction.IsSelected = false; - btnChangeFunction.IsBold = false; - } - }; + } } + + object lockObj = new object(); /// <summary> /// 鏇存柊鏄剧ず鐘舵�� /// </summary> public static void UpdataFunctionStates(Function function) { + if(bodyView == null) + { + return; + } Application.RunOnMainThread(() => { try @@ -447,12 +430,28 @@ } } } - else if(function.spk == SPK.SensorHelp) + else if (function.spk == SPK.SensorHelp) { var tempStatus = function.attributes.Find((sta) => sta.key == FunctionAttributeKey.AlarmStatus); - if(tempStatus != null) + if (tempStatus != null) { state = tempStatus.curValue.ToString() == "alarm"; + } + } + else if (function.spk == SPK.SensorPir || function.spk == SPK.SensorPirHold) + { + var tempStatus = function.attributes.Find((sta) => sta.key == "people_status"); + if (tempStatus != null) + { + state = tempStatus.curValue.ToString() == "true"; + } + } + else if (function.spk == SPK.SensorDryContact || function.spk == SPK.SensorDryContact2) + { + var tempStatus = function.attributes.Find((sta) => sta.key == "contact_status"); + if (tempStatus != null) + { + state = tempStatus.curValue.ToString() == "open"; } } else @@ -569,7 +568,7 @@ { btnSwitch.MouseUpEventHandler = (sender, e) => { - if (!function.online)//绂荤嚎涓嶅厑璁告搷浣� + if (!function.isOnline())//绂荤嚎涓嶅厑璁告搷浣� { new Tip() { @@ -589,6 +588,7 @@ btnSwitch.IsSelected = !btnSwitch.IsSelected; }); } + function.trait_on_off.curValue = btnSwitch.IsSelected ? "on" : "off"; Dictionary<string, string> d = new Dictionary<string, string>(); if (function.spk == SPK.LightDimming || function.spk == SPK.LightRGB) @@ -613,6 +613,11 @@ // } // Control.Ins.SendWriteCommand(function, d); //} + else if (function.spk == SPK.GroupControl) + { + d.Add("on_off", function.trait_on_off.curValue.ToString()); + (function as GroupControl).Control(d); + } else { d.Add("on_off", function.trait_on_off.curValue.ToString()); @@ -632,7 +637,7 @@ { btnSwitch.MouseUpEventHandler = (sender, e) => { - if (!function.online)//绂荤嚎涓嶅厑璁告搷浣� + if (!function.isOnline())//绂荤嚎涓嶅厑璁告搷浣� { new Tip() { @@ -676,16 +681,16 @@ { btnClose.MouseUpEventHandler = (sender, e) => { - if (!curtain.online)//绂荤嚎涓嶅厑璁告搷浣� - { - new Tip() - { - CloseTime = 1, - Text = Language.StringByID(StringId.DeviceOfflineCannotOption), - Direction = AMPopTipDirection.None, - }.Show(MainPage.BaseView); - return; - } + //if (!curtain.isOnline())//绂荤嚎涓嶅厑璁告搷浣� + //{ + // new Tip() + // { + // CloseTime = 1, + // Text = Language.StringByID(StringId.DeviceOfflineCannotOption), + // Direction = AMPopTipDirection.None, + // }.Show(MainPage.BaseView); + // return; + //} btnClose.IsSelected = true; curtain.trait_on_off.curValue = "off"; curtain.SetAttrState(FunctionAttributeKey.Percent, 0); @@ -693,23 +698,23 @@ d.Add(FunctionAttributeKey.OnOff, curtain.trait_on_off.curValue.ToString()); Control.Ins.SendWriteCommand(curtain, d); }; - btnOpen.MouseUpEventHandler = (sender, e) => { - if (!curtain.online)//绂荤嚎涓嶅厑璁告搷浣� - { - new Tip() - { - CloseTime = 1, - Text = Language.StringByID(StringId.DeviceOfflineCannotOption), - Direction = AMPopTipDirection.None, - }.Show(MainPage.BaseView); - return; - } + //if (!curtain.isOnline())//绂荤嚎涓嶅厑璁告搷浣� + //{ + // new Tip() + // { + // CloseTime = 1, + // Text = Language.StringByID(StringId.DeviceOfflineCannotOption), + // Direction = AMPopTipDirection.None, + // }.Show(MainPage.BaseView); + // return; + //} btnOpen.IsSelected = true; + Dictionary<string, string> d = new Dictionary<string, string>(); + curtain.trait_on_off.curValue = "on"; curtain.SetAttrState(FunctionAttributeKey.Percent, 100); - Dictionary<string, string> d = new Dictionary<string, string>(); d.Add(FunctionAttributeKey.OnOff, curtain.trait_on_off.curValue.ToString()); Control.Ins.SendWriteCommand(curtain, d); }; @@ -726,7 +731,7 @@ }; btnUp.MouseUpEventHandler = (sender, e) => { - if (!function.online)//绂荤嚎涓嶅厑璁告搷浣� + if (!function.isOnline())//绂荤嚎涓嶅厑璁告搷浣� { new Tip() { @@ -757,7 +762,7 @@ }; btnDown.MouseUpEventHandler = (sender, e) => { - if (!function.online)//绂荤嚎涓嶅厑璁告搷浣� + if (!function.isOnline())//绂荤嚎涓嶅厑璁告搷浣� { new Tip() { @@ -802,9 +807,9 @@ skipPage.LoadPage(backAction); MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1; }; - btnMsgBg.MouseUpEventHandler = eventHandler; - btnMsgTime.MouseUpEventHandler = eventHandler; - btnMsg.MouseUpEventHandler = eventHandler; + //btnMsgBg.MouseUpEventHandler = eventHandler; + //btnMsgTime.MouseUpEventHandler = eventHandler; + //btnMsg.MouseUpEventHandler = eventHandler; btnMsgIcon.MouseUpEventHandler = eventHandler; } @@ -889,8 +894,8 @@ void ShowMesBtnState(PushMessageInfo pushMessageInfo, bool allRead) { if (bodyView == null) return; - btnMsg.Text = pushMessageInfo.messageTitle + ": " + pushMessageInfo.messageContent; - btnMsgTime.Text = GetUnixToDateTime(pushMessageInfo.createTime); + //btnMsg.Text = pushMessageInfo.messageTitle + ": " + pushMessageInfo.messageContent; + //btnMsgTime.Text = GetUnixToDateTime(pushMessageInfo.createTime); btnMsgIcon.IsSelected = !allRead; } @@ -900,8 +905,8 @@ void ResetMesBtnRead() { if (bodyView == null) return; - btnMsg.Text = "..."; - btnMsgTime.Text = "00:00"; + //btnMsg.Text = "..."; + //btnMsgTime.Text = "00:00"; btnMsgIcon.IsSelected = false; } -- Gitblit v1.8.0