From 0ee75b88cfe03e46289de0de96e8ed4580c797d3 Mon Sep 17 00:00:00 2001 From: wxr <464027401@qq.com> Date: 星期二, 27 九月 2022 14:04:21 +0800 Subject: [PATCH] Merge branch 'Dev-Branch' into dev--wxr --- HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs | 359 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 343 insertions(+), 16 deletions(-) diff --git a/HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs b/HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs index 3914880..511af3b 100644 --- a/HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs +++ b/HDL_ON/UI/UI2/2-Classification/ClassificationPage.cs @@ -1,8 +1,12 @@ 锘縰sing System; using System.Collections.Generic; +using HDL_ON.DAL.Server; +using HDL_ON.DriverLayer; using HDL_ON.Entity; using HDL_ON.UI; using HDL_ON.UI.CSS; +using Newtonsoft.Json; +using Newtonsoft.Json.Linq; using Shared; namespace HDL_ON.UI @@ -645,8 +649,6 @@ var lastY2 = Application.GetRealWidth(16); var functionContentViewHeight = Application.GetRealWidth(16); - var functionCategoryCount = 0; - foreach (var item in DB_ResidenceData.Instance.functionTypeList) { int functionCount = 0; @@ -678,6 +680,8 @@ #endregion break; case ShowFunction.DoorLock: + functionCount = FunctionList.List.GetDoorLockList().Count; + functionOnCount = 1; break; case ShowFunction.Electric: #region 鐢靛櫒 @@ -730,15 +734,18 @@ // functionCount = 1; //} break; + case ShowFunction.Acst: + functionCount = FunctionList.List.GetAcstParentList().Count; + functionOnCount = FunctionList.List.GetAcstParentList().FindAll((obj) => obj.trait_on_off.curValue.ToString() == "on").Count; + break; + } - if(functionCount == 0) + if (functionCount == 0) { continue; } - - functionCategoryCount++; FrameLayout functionView = new FrameLayout() { @@ -789,6 +796,7 @@ if (item != ShowFunction.Environmental && item != ShowFunction.Sensor && item != ShowFunction.VideoIntercom && item != ShowFunction.SecurityMonitoring && item != ShowFunction.FreshAir && item != ShowFunction.Music && item != ShowFunction.EnergyMonitoring && item != ShowFunction.SecurityCenter + && item != ShowFunction.Acst && functionCount != 0) { Button btnFunctionCount = new Button() @@ -934,6 +942,11 @@ break; case ShowFunction.DoorLock: btnName.TextID = StringId.DoorLock; + btnFunctionViewBg.MouseUpEventHandler = (sende, e) => + { + var form = new DoorLockListPage(); + form.AddForm(FunctionList.List.GetDoorLockList()); + }; break; case ShowFunction.Electric: #region 鐢靛櫒 @@ -960,7 +973,8 @@ case ShowFunction.EnergyMonitoring: #region 鑳芥簮鐩戞祴 btnName.TextID = StringId.EnergyMonitoring; - btnFunctionViewBg.MouseUpEventHandler = (sender, e) => { + btnFunctionViewBg.MouseUpEventHandler = (sender, e) => + { var skipView = new EnergyMainPage(); MainPage.BasePageView.AddChidren(skipView); skipView.LoadPage(); @@ -1047,11 +1061,59 @@ MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1; }; break; + case ShowFunction.Acst: + btnName.TextID = StringId.Acst; + + Button btnJMLogo = new Button() + { + Y = specialList.Contains(index) ? Application.GetRealWidth(147) : Application.GetRealWidth(104), + UnSelectedImagePath = "FunctionIcon/Acst/LvJianLogo.png", + Width = Application.GetRealWidth(105), + Height = Application.GetRealWidth(57), + }; + functionView.AddChidren(btnJMLogo); + + Button btnAcstPower = new Button() + { + X = Application.GetRealWidth(120), + Y = specialList.Contains(index) ? Application.GetRealWidth(160) : Application.GetRealWidth(117), + Width = Application.GetRealWidth(32), + Height = Application.GetRealWidth(32), + SelectedImagePath = "Public/PowerOpen.png", + UnSelectedImagePath = "Public/PowerClose.png", + IsSelected = functionOnCount > 0, + Tag = item + "_AllControl", + }; + functionView.AddChidren(btnAcstPower); + btnAcstPower.MouseUpEventHandler = (sender, e) => + { + btnAcstPower.IsSelected = !btnAcstPower.IsSelected; + string onoff = btnAcstPower.IsSelected ? "on" : "off"; + Dictionary<string, string> d = new Dictionary<string, string>(); + d.Add(FunctionAttributeKey.OnOff, onoff); + + foreach (var temp in FunctionList.List.GetAcstParentList()) + { + Control.Ins.SendWriteCommand(temp, d); + } + }; + + + btnFunctionViewBg.MouseUpEventHandler = (sender, e) => + { + var page = new AcstParentPage(); + MainPage.BasePageView.AddChidren(page); + page.LoadPage(); + MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1; + }; + break; + } //鐣岄潰璺宠浆--闊充箰璺宠浆鑷繁鐨勭晫闈�--鐜璺宠浆鑷繁鐨勭晫闈� - if (item != ShowFunction.Music && item != ShowFunction.Environmental && item != ShowFunction.SecurityMonitoring - && ShowFunction.EnergyMonitoring!= item && ShowFunction.VideoIntercom != item && ShowFunction.SecurityCenter != item) + if (item != ShowFunction.Music && item != ShowFunction.Environmental && item != ShowFunction.SecurityMonitoring && item != ShowFunction.DoorLock + && ShowFunction.EnergyMonitoring != item && ShowFunction.VideoIntercom != item && ShowFunction.SecurityCenter != item + && ShowFunction.Acst != item) { btnFunctionViewBg.MouseUpEventHandler = (sender, e) => { @@ -1064,16 +1126,281 @@ index++; } - //if (functionCategoryCount > 4) + + //鍏変紡鏁版嵁 + if (FunctionList.List.InverterList().Count > 0) { - //functionContentView.Height = functionContentViewHeight;// Application.GetRealWidth((240 * (functionCategoryCount / 2))); - s1View.Height = s2View.Height = functionContentView.Height = functionContentViewHeight+ Application.GetRealWidth(40); + FrameLayout inverterListView = new FrameLayout() + { + Height = Application.GetRealHeight(204), + Radius = (uint)Application.GetRealWidth(6), + BackgroundColor = CSS_Color.MainBackgroundColor, + Tag = "inverterList_View", + Y = index % 2 == 1 ? lastY2 : lastY1 + }; + if (index % 2 == 1) + { + lastY2 += inverterListView.Height + Application.GetRealWidth(16); + } + else + { + lastY1 += inverterListView.Height + Application.GetRealWidth(16); + } + + if (index % 2 == 0) + { + s1View.AddChidren(inverterListView); + } + else + { + s2View.AddChidren(inverterListView); + } + functionContentViewHeight = inverterListView.Bottom; + + + Button btnName = new Button() + { + X = Application.GetRealWidth(16), + Y = Application.GetRealHeight(16),//14),// + Width = Application.GetRealWidth(140), + Height = Application.GetRealHeight(20), + TextColor = CSS_Color.FirstLevelTitleColor, + TextSize = CSS_FontSize.TextFontSize, + TextAlignment = TextAlignment.CenterLeft, + IsMoreLines = true, + TextID = StringId.PhotovoltaicEnergyStorage, + IsBold = true, + }; + inverterListView.AddChidren(btnName); + + + Button btnFunctionCount = new Button() + { + X = Application.GetRealWidth(17) + Application.GetRealWidth(7 * FunctionList.List.InverterList().Count.ToString().Length), + Y = btnName.Bottom, + Width = Application.GetRealWidth(120), + Height = Application.GetRealHeight(24), + TextColor = CSS_Color.PromptingColor1, + TextSize = CSS_FontSize.PromptFontSize_FirstLevel, + TextAlignment = TextAlignment.CenterLeft, + Text = "/" + FunctionList.List.InverterList().Count, + }; + inverterListView.AddChidren(btnFunctionCount); + Button btnOpenCount = new Button() + { + X = Application.GetRealWidth(16), + Y = btnName.Bottom, + Width = Application.GetRealWidth(14 * FunctionList.List.InverterList().Count.ToString().Length), + Height = Application.GetRealHeight(24), + TextColor = CSS_Color.MainColor, + TextSize = CSS_FontSize.PromptFontSize_FirstLevel, + TextAlignment = TextAlignment.CenterLeft, + Text = FunctionList.List.InverterList().FindAll((temp)=>temp.trait_on_off.curValue.ToString() == "on").Count.ToString(), + Tag = "inverter_onCount", + BorderWidth = 0, + }; + inverterListView.AddChidren(btnOpenCount); + + //Button btnWorkStatus = new Button() + //{ + // Y = Application.GetRealHeight(24), + // Width = Application.GetRealWidth(148), + // Height = Application.GetRealHeight(18), + // TextAlignment = TextAlignment.CenterRight, + // TextColor = 0xFF0BAF31, + // TextID = StringId.NormalOperation, + // TextSize = CSS_FontSize.TextFontSize + //}; + //inverterListView.AddChidren(btnWorkStatus); + + Button btnWorkingMode = new Button() + { + X = Application.GetRealWidth(16), + Y = btnOpenCount.Bottom + Application.GetRealHeight(5),// + Application.GetRealHeight(16), + Width = Application.GetRealWidth(148), + Height = Application.GetRealHeight(18), + TextColor = CSS_Color.FirstLevelTitleColor, + TextSize = CSS_FontSize.PromptFontSize_FirstLevel, + TextID = StringId.WorkingMode, + TextAlignment = TextAlignment.CenterLeft, + }; + inverterListView.AddChidren(btnWorkingMode); + + Button btnPowerTenerationToday = new Button() + { + X = Application.GetRealWidth(16), + Y = btnWorkingMode.Bottom + Application.GetRealHeight(5), + Width = Application.GetRealWidth(148), + Height = Application.GetRealHeight(21), + TextColor = CSS_Color.FirstLevelTitleColor, + TextSize = CSS_FontSize.PromptFontSize_FirstLevel, + TextID = StringId.PowerTenerationToday, + TextAlignment = TextAlignment.CenterLeft, + }; + inverterListView.AddChidren(btnPowerTenerationToday); + + + Button btnCurrentPowerGeneration = new Button() + { + X = Application.GetRealWidth(16), + Y = btnPowerTenerationToday.Bottom + Application.GetRealHeight(5), + Width = Application.GetRealWidth(148), + Height = Application.GetRealHeight(21), + TextColor = CSS_Color.FirstLevelTitleColor, + TextSize = CSS_FontSize.PromptFontSize_FirstLevel, + TextID = StringId.CurrentPowerGeneration, + TextAlignment = TextAlignment.CenterLeft, + }; + inverterListView.AddChidren(btnCurrentPowerGeneration); + + Button btnBatterySOC = new Button() + { + X = Application.GetRealWidth(16), + Y = btnCurrentPowerGeneration.Bottom, + Width = Application.GetRealWidth(148), + Height = Application.GetRealHeight(18), + TextColor = CSS_Color.FirstLevelTitleColor, + TextSize = CSS_FontSize.PromptFontSize_FirstLevel, + TextID = StringId.BatterySOC, + TextAlignment = TextAlignment.CenterLeft, + }; + //inverterListView.AddChidren(btnBatterySOC); + + //Button btnOperationDataTotalData = new Button() + //{ + // X = Application.GetRealWidth(16), + // Y = btnBatterySOC.Bottom + Application.GetRealHeight(16), + // Width = Application.GetRealWidth(148), + // Height = Application.GetRealHeight(18), + // TextColor = CSS_Color.FirstLevelTitleColor, + // TextSize = CSS_FontSize.PromptFontSize_FirstLevel, + // TextID = StringId.OperationDataTotalData, + // TextAlignment = TextAlignment.CenterLeft, + //}; + //inverterListView.AddChidren(btnOperationDataTotalData); + + var clickButton = new Button(); + inverterListView.AddChidren(clickButton); + + clickButton.MouseUpEventHandler = (sender2, e2) => + { + var h5BasePage = new FrameLayout() { + BackgroundColor = CSS_Color.MainBackgroundColor, + }; + +//#if __Android__ + //閫傞厤瀹夊崜娌夋蹈寮忓鑸爮 + h5BasePage.Y = Application.GetRealHeight(20); + h5BasePage.Height = Application.GetRealHeight(646); +//#endif + MainPage.BasePageView.AddChidren(h5BasePage); + MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1; + + h5BasePage.AddChidren(Inverter.Ins.H5Page);//000 + string lz = "zh"; + if (Language.CurrentLanguage != "Chinese") + { + lz = "en"; + } + string url = $"h5/index.html?homeId={DB_ResidenceData.Instance.CurrentRegion.id}&token={UserInfo.Current.AccessToken}&refresh_token={UserInfo.Current.RefreshToken}&url={HttpUtil.GlobalRequestHttpsHost}&lang={lz}"; + Inverter.Ins.ShowWebviewFormUrl(url); + Inverter.Ins.H5Page.JSToNativeAction = (dictionary) => + { + JObject jObj = JObject.Parse(Newtonsoft.Json.JsonConvert.SerializeObject(dictionary)); + + if (!jObj.ContainsKey("method") || !jObj.ContainsKey("data")) + { + return; + } + if (jObj["method"].ToString() == "control" && jObj["data"].Type == JTokenType.Object) + {//鎺у埗 + var data = JObject.FromObject(jObj["data"]); + + if (!data.ContainsKey("sid") || !data.ContainsKey("on_off")) + { + return; + } + var function = new Function(); + function.sid = data["sid"].ToString(); + var inObj = FunctionList.List.InverterList().Find((obj) => obj.sid == function.sid); + if (inObj == null) + { + return; + } + function.deviceId = inObj.deviceId; + //function.spk = inObj.spk; + + var status = new Dictionary<string, string>() { ["on_off"] = data["on_off"].ToString() }; + Control.Ins.SendWriteCommand(function, status); + } + else if (jObj["method"].ToString() == "back") + { + Application.RunOnMainThread(() => + { + h5BasePage.RemoveFromParent(); + }); + refreshInverterInfo(btnPowerTenerationToday, btnWorkingMode, btnCurrentPowerGeneration, btnBatterySOC); + } + else if(jObj["method"].ToString() == "setPageIndex") + { + var data = jObj["data"].ToString(); + Inverter.Ins.PageIndex = data.ToString(); + } + }; + + + + }; + + refreshInverterInfo(btnPowerTenerationToday, btnWorkingMode, btnCurrentPowerGeneration, btnBatterySOC); + + index++; } -#endregion + s1View.Height = s2View.Height = functionContentView.Height = functionContentViewHeight + Application.GetRealWidth(40); + + #endregion } - #region 鍒囨崲妤煎眰 + void refreshInverterInfo(Button btnPowerTenerationToday, Button btnWorkingMode, Button btnCurrentPowerGeneration, Button btnBatterySOC) + { + new System.Threading.Thread(() => + { + var http = new HttpServerRequest(); + var pack = http.GetInverterStatisticsInfo(); + if (pack != null) + { + if(pack.Data == null) + { + return; + } + var info = JsonConvert.DeserializeObject<StatisticsInfo>(pack.Data?.ToString()); + if (info == null) + { + return; + } + try + { + Application.RunOnMainThread(() => + { + btnPowerTenerationToday.Text = Language.StringByID(StringId.PowerTenerationToday).Replace("----", info.totalElectricityPvToday); + btnWorkingMode.Text = Language.StringByID(StringId.WorkingMode).Replace("----", info.workMode); + btnCurrentPowerGeneration.Text = Language.StringByID(StringId.CurrentPowerGeneration).Replace("----", info.powerPvNow); + btnBatterySOC.Text = Language.StringByID(StringId.BatterySOC).Replace("--", info.batterySoc); + }); + } + catch (Exception ex) + { + MainPage.Log($"鑾峰彇瀹跺涵鍏変紡缁熻鏁版嵁寮傚父锛歿ex.Message}"); + } + } + + + }) + { IsBackground = true }.Start(); + } + +#region 鍒囨崲妤煎眰 /// <summary> /// 妤煎眰鏄剧ず鍒囨崲 /// </summary> @@ -1169,7 +1496,7 @@ foreach (var floor in chooseList) { - if (!string.IsNullOrEmpty( floor.roomId))// != Language.StringByID(StringId.All)) + if (!string.IsNullOrEmpty( floor.roomId)) { //---鍒嗗壊绾� contentView.AddChidren(new Button() @@ -1230,6 +1557,6 @@ { } - #endregion +#endregion } -} \ No newline at end of file +} -- Gitblit v1.8.0