From c1cb2d8c6034a2ee7aa8a5710bba15b14f76cebc Mon Sep 17 00:00:00 2001 From: wjc <1243177876@qq.com> Date: 星期五, 18 八月 2023 18:54:31 +0800 Subject: [PATCH] 2023年08月18日18:54:22 --- HDL_ON/UI/UI2/FuntionControlView/Light/ColorfulInfoPage.cs | 107 +++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 99 insertions(+), 8 deletions(-) diff --git a/HDL_ON/UI/UI2/FuntionControlView/Light/ColorfulInfoPage.cs b/HDL_ON/UI/UI2/FuntionControlView/Light/ColorfulInfoPage.cs index 8b683de..9a24099 100644 --- a/HDL_ON/UI/UI2/FuntionControlView/Light/ColorfulInfoPage.cs +++ b/HDL_ON/UI/UI2/FuntionControlView/Light/ColorfulInfoPage.cs @@ -1,6 +1,7 @@ 锘� using System; using System.Collections.Generic; +using HDL_ON.DriverLayer; using HDL_ON.Entity; using HDL_ON.Stan; using HDL_ON.UI.CSS; @@ -39,6 +40,80 @@ ScrollEnabled = false, }; bodyView.AddChidren(contentView); + + #region 鐐僵寮�鍏� + contentView.AddChidren(new Button + { + Height = Application.GetRealHeight(10), + BackgroundColor = CSS_Color.BackgroundColor, + }); + + var viewSwitch = new FrameLayout() + { + Height = Application.GetRealHeight(50), + BackgroundColor = CSS_Color.MainBackgroundColor, + }; + contentView.AddChidren(viewSwitch); + + var btnSwitchText = new Button() + { + X = Application.GetRealWidth(16), + TextAlignment = TextAlignment.CenterLeft, + TextColor = CSS_Color.FirstLevelTitleColor, + TextSize = CSS_FontSize.SubheadingFontSize, + TextID = StringId.CulorfulTest, + }; + viewSwitch.AddChidren(btnSwitchText); + + var btnColorfulSwitch = new Button() + { + X = Application.GetRealWidth(314), + Gravity = Gravity.CenterVertical, + Width = Application.GetMinRealAverage(48), + Height = Application.GetMinRealAverage(36), + UnSelectedImagePath = "Public/Switch.png", + SelectedImagePath = "Public/SwitchOn.png", + IsSelected = function.GetAttrState(FunctionAttributeKey.Colorful) == "on" + }; + viewSwitch.AddChidren(btnColorfulSwitch); + + btnColorfulSwitch.MouseUpEventHandler = (sender, e) => { + btnColorfulSwitch.IsSelected = !btnColorfulSwitch.IsSelected; + new System.Threading.Thread(() => + { + try + { + var controlColorfulState = btnColorfulSwitch.IsSelected ? "on" : "off"; + function.SetAttrState(FunctionAttributeKey.Colorful, controlColorfulState); + var d = new Dictionary<string, string>(); + d.Add(FunctionAttributeKey.Colorful, controlColorfulState); + if (controlColorfulState == "on") + { + var color = function.GetAttrState(FunctionAttributeKey.ColorfulBegin).Split(","); + var sendColorString = color[0] + "," + color[1] + "," + color[2]; + d.Add(FunctionAttributeKey.ColorfulBegin, sendColorString); + color = function.GetAttrState(FunctionAttributeKey.ColorfulEnd).Split(","); + sendColorString = color[0] + "," + color[1] + "," + color[2]; + d.Add(FunctionAttributeKey.ColorfulEnd, sendColorString); + d.Add(FunctionAttributeKey.ColorfulTime, function.GetAttrState(FunctionAttributeKey.ColorfulTime)); + } + Control.Ins.SendWriteCommand(function, d); + } + catch (Exception ex) + { + MainPage.Log($"鎺у埗鐐僵寮�鍏冲紓甯�:{ex.Message}"); + } + }) + { IsBackground = true }.Start(); + }; + + contentView.AddChidren(new Button + { + Height = Application.GetRealHeight(10), + BackgroundColor = CSS_Color.BackgroundColor, + }); + + #endregion #region 璧峰棰滆壊 var startView = new FrameLayout() @@ -86,9 +161,9 @@ btnStartColor.MouseUpEventHandler = (sender, e) => { Action<uint> action = (color) => { btnStartColor.BackgroundColor = color; - function.SetAttrState(FunctionAttributeKey.ColorfulBegin, color); + //function.SetAttrState(FunctionAttributeKey.ColorfulBegin, color); }; - var rgbView = new ColorfulSettingPage(action); + var rgbView = new ColorfulSettingPage(function, action,true); MainPage.BasePageView.AddChidren(rgbView); rgbView.LoadPage(function.GetAttrState(FunctionAttributeKey.ColorfulBegin)); MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1; @@ -134,7 +209,7 @@ Radius = (uint)Application.GetRealWidth(14), BorderColor = CSS_Color.DividingLineColor, BorderWidth = 1, - BackgroundColor = (uint)(0xFF000000 + lightTemp.GetRGBcolor(function.GetAttrState(FunctionAttributeKey.ColorfulBegin))) + BackgroundColor = (uint)(0xFF000000 + lightTemp.GetRGBcolor(function.GetAttrState(FunctionAttributeKey.ColorfulEnd))) }; endColorView.AddChidren(btnEndColor); @@ -145,7 +220,7 @@ btnEndColor.BackgroundColor = color; function.SetAttrState(FunctionAttributeKey.ColorfulEnd, color); }; - var rgbView = new ColorfulSettingPage(action); + var rgbView = new ColorfulSettingPage(function, action,false); MainPage.BasePageView.AddChidren(rgbView); rgbView.LoadPage(function.GetAttrState(FunctionAttributeKey.ColorfulEnd)); MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1; @@ -155,7 +230,7 @@ #endregion - #region 宸ヤ綔鏃堕暱 + #region 鐐僵鍛ㄦ湡 var workHoursView = new FrameLayout() { Height = Application.GetRealHeight(50), @@ -196,6 +271,13 @@ }; workHoursView.AddChidren(btnWorkHours); + var time = Convert.ToInt32( function.GetAttrState(FunctionAttributeKey.ColorfulTime)); + + + btnWorkHours.Text = time/ 360 + Language.StringByID(StringId.h); + btnWorkHours.Text += time / 60 + Language.StringByID(StringId.m); + btnWorkHours.Text += time % 60 + Language.StringByID(StringId.s); + var waitPage = new Loading(); this.AddChidren(waitPage); @@ -210,9 +292,20 @@ { LoadEditDialog(() => { + if(hour == 0 && minute == 0 && second == 0) + { + new PublicAssmebly().TipMsg(StringId.Tip, StringId.TimeInvalid); + return; + } btnWorkHours.Text = hour + "鏃�"; btnWorkHours.Text += minute + "鍒�"; btnWorkHours.Text += second + "绉�"; + new System.Threading.Thread(() => { + var d = new Dictionary<string, string>(); + function.SetAttrState(FunctionAttributeKey.ColorfulTime, (hour * 360 + minute * 60 + second).ToString()); + d.Add(FunctionAttributeKey.ColorfulTime, (hour * 360 + minute * 60 + second).ToString()); + Control.Ins.SendWriteCommand(function, d); + }) { IsBackground = true }.Start(); }); }); } @@ -229,8 +322,6 @@ btnWorkHours.MouseUpEventHandler = eventHandler; workHoursView.MouseUpEventHandler = eventHandler; btnWorkHoursRight.MouseUpEventHandler = eventHandler; - - #endregion @@ -307,7 +398,7 @@ Height = Application.GetRealHeight(210), Radius = (uint)Application.GetRealWidth(12), }; - for (int i = 0; i <= 23; i += 1) + for (int i = 0; i <= 15; i += 1) { item1.Add(i+Language.StringByID(StringId.h)); } -- Gitblit v1.8.0