From 7167334c0e89dd84827d59e726123d14776e3a09 Mon Sep 17 00:00:00 2001 From: 陈嘉乐 <cjl@hdlchina.com.cn> Date: 星期二, 16 六月 2020 11:14:13 +0800 Subject: [PATCH] 2020-06-16-1 --- HDL_ON/UI/UI2/2-Classification/FunctionControlZone.cs | 165 ++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 104 insertions(+), 61 deletions(-) diff --git a/HDL_ON/UI/UI2/2-Classification/FunctionControlZone.cs b/HDL_ON/UI/UI2/2-Classification/FunctionControlZone.cs index df3bb2f..51f9129 100644 --- a/HDL_ON/UI/UI2/2-Classification/FunctionControlZone.cs +++ b/HDL_ON/UI/UI2/2-Classification/FunctionControlZone.cs @@ -29,6 +29,10 @@ #region 鍖哄煙鍙橀噺 Function function; + /// <summary> + /// 鏄惁鍦ㄨ皟鍏� + /// </summary> + bool onDimmerBar; #endregion public FunctionControlZone(Function func) { @@ -55,14 +59,42 @@ LoadDiv(); - if (function.functionCategory != FunctionType.Curtain)//绐楀笜娌℃湁寮�鍏虫寜閽� + if (function.functionCategory == FunctionCategory.Curtain || function.functionCategory == FunctionCategory.Scene)//绐楀笜娌℃湁寮�鍏虫寜閽� + { + switch (function.functionCategory) + { + case FunctionCategory.Curtain: + btnIcon.UnSelectedImagePath = "FunctionIcon/Curtain/CurtainThinIcon.png"; + CurtainFragment(); + break; + case FunctionCategory.Scene: + btnIcon.UnSelectedImagePath = "FunctionIcon/Scene/SceneIcon.png"; + if ((function as Scene).sceneType == SceneType.MovieScene) + { + var movieIcon = new Button() + { + X = Application.GetRealWidth(52), + Y = Application.GetRealHeight(14), + Width = Application.GetRealWidth(16), + Height = Application.GetRealWidth(16), + UnSelectedImagePath = "FunctionIcon/Scene/MovieMark.png", + }; + bodyDiv.AddChidren(movieIcon); + btnName.X = Application.GetRealWidth(52 + 16); + } + //鍔犺浇鍦烘櫙鎺у埗浜嬩欢 + LoadEvent_ControlScene(); + break; + } + } + else { #region 鍔犺浇寮�鍏虫寜閽� /// <summary> /// 寮�鍏虫寜閽� /// </summary> Button btnSwitch; - if (function.functionType == "RGB" || function.functionType == "Dimmer") + if (function.functionType == FunctionType.RGB || function.functionType == FunctionType.Dimmer) { btnSwitch = new Button() { @@ -72,7 +104,8 @@ Height = Application.GetMinRealAverage(32), UnSelectedImagePath = "Public/PowerClose.png", SelectedImagePath = "Public/PowerOpen.png", - Tag = function.functionType + "_Switch_" + function.sid + IsSelected = function.on_off == "on", + Tag = function.functionType + "_Switch_" + function.sid, }; bodyDiv.AddChidren(btnSwitch); } @@ -86,58 +119,64 @@ Height = Application.GetMinRealAverage(32), UnSelectedImagePath = "Public/PowerClose.png", SelectedImagePath = "Public/PowerOpen.png", - Tag = function.functionType + "_Switch_" + function.sid + IsSelected = function.on_off == "on", + Tag = function.functionType + "_Switch_" + function.sid, }; bodyDiv.AddChidren(btnSwitch); } //鍔犺浇寮�鍏虫寜閽簨浠� - LoadEvent_LightSwitch(btnSwitch); + LoadEvent_SwitchFunction(btnSwitch); switch (function.functionCategory) { - case FunctionType.AC: - btnIcon.UnSelectedImagePath = "FunctionIcon/AC/AcThinIcon.png"; - AcDiv(); + case FunctionCategory.Thermostat: + switch (function.functionType) + { + case FunctionType.AC: + btnIcon.UnSelectedImagePath = "FunctionIcon/AC/AcThinIcon.png"; + LoadLastStatesButton(); + break; + case FunctionType.FloorHeating: + btnIcon.UnSelectedImagePath = "FunctionIcon/FloorHeating/FloorHeatingThinIcon.png"; + LoadLastStatesButton(); + break; + } break; - case FunctionType.Light: + case FunctionCategory.Light: btnIcon.UnSelectedImagePath = "FunctionIcon/Light/LightThinIcon.png"; - btnSwitch.IsSelected = (function as Light).on_off == 1; + btnSwitch.IsSelected = function.on_off == "on"; LoadLightControl(); break; - case FunctionType.FloorHeating: - btnIcon.UnSelectedImagePath = "FunctionIcon/FloorHeating/FloorHeatingThinIcon.png"; - FloorHeatingDiv(); - break; - case FunctionType.Scene: - btnIcon.UnSelectedImagePath = "FunctionIcon/Scene/SceneIcon.png"; - if ((function as Scene).sceneType == SceneType.MovieScene) + case FunctionCategory.SwitchDevice: + switch (function.functionType) { - var movieIcon = new Button() - { - X = Application.GetRealWidth(52), - Y = Application.GetRealHeight(14), - Width = Application.GetRealWidth(16), - Height = Application.GetRealWidth(16), - UnSelectedImagePath = "FunctionIcon/Scene/MovieMark.png", - }; - bodyDiv.AddChidren(movieIcon); - - btnName.X = movieIcon.Right; + case FunctionType.Socket: + btnIcon.UnSelectedImagePath = "FunctionIcon/Socket/SocketThinIcon.png"; + break; } + btnSwitch.IsSelected = function.on_off == "on"; + break; + case FunctionCategory.Electrical: + switch (function.functionType) + { + case FunctionType.Fan: + btnIcon.UnSelectedImagePath = "FunctionIcon/Electrical/FanThinIcon.png"; + break; + } + btnSwitch.IsSelected = function.on_off == "on"; break; } + + #endregion } - else + + if (function.functionCategory != FunctionCategory.Scene) { - btnIcon.UnSelectedImagePath = "FunctionIcon/Curtain/CurtainThinIcon.png"; - CurtainFragment(); - + LoadEvent_DivSkipEvent(); } - - LoadEvent_DivSkipEvent(); - LoadCollectionEvent(); + LoadEvent_FunctionCollection(); } /// <summary> @@ -149,14 +188,14 @@ { X = Application.GetRealWidth(10), Y = Application.GetRealHeight(15), - Width = Application.GetMinRealAverage(32), - Height = Application.GetMinRealAverage(32), + Width = Application.GetRealWidth(32), + Height = Application.GetRealWidth(32), }; bodyDiv.AddChidren(btnIcon); btnName = new Button() { - X = btnIcon.Right + Application.GetRealWidth(8), + X = Application.GetRealWidth(8 +10 + 32), Y = Application.GetRealHeight(10), Width = Application.GetRealWidth(200), Height = Application.GetRealHeight(24), @@ -169,8 +208,8 @@ btnFromFloor = new Button() { - X = btnIcon.Right + Application.GetRealWidth(8), - Y = btnName.Bottom, + X = Application.GetRealWidth(8 + 10 + 32), + Y = Application.GetRealHeight(10 + 24), Width = Application.GetRealWidth(200), Height = Application.GetRealHeight(18), Text = function.GetRoomListName(), @@ -201,8 +240,8 @@ { switch (function.functionType) { - case "Dimmer": - case "RGB": + case FunctionType.Dimmer: + case FunctionType.RGB: #region Dimmer var btnDimmerMinValues = new Button() { @@ -219,14 +258,14 @@ var dimmerControlBar = new DiyImageSeekBar() { - X = btnDimmerMinValues.Right, + X = Application.GetRealWidth(14+ 22), Y = Application.GetRealHeight(68),//91,璁捐鏁版嵁 Width = Application.GetRealWidth(180), Height = Application.GetRealHeight(54), SeekBarViewHeight = Application.GetRealHeight(8), ThumbImagePath = "Public/ThumbImage.png", ThumbImageHeight = Application.GetRealHeight(54), - ProgressBarColor = CSS_Color.AuxiliaryColor1, + ProgressBarColor = (function as Light).on_off == "on" ? CSS_Color.AuxiliaryColor1 : CSS_Color.PromptingColor2, ProgressTextColor = CSS_Color.FirstLevelTitleColor, ProgressTextSize = CSS_FontSize.PromptFontSize_FirstLevel, MaxValue = 100, @@ -237,7 +276,7 @@ var btnDimmerMaxValues = new Button() { - X = dimmerControlBar.Right, + X = Application.GetRealWidth(14 + 22+180), Y = Application.GetRealHeight(85), Width = Application.GetRealWidth(35), Height = Application.GetRealHeight(21), @@ -268,6 +307,7 @@ Height = Application.GetMinRealAverage(32), UnSelectedImagePath = "FunctionIcon/Curtain/CurtainCloseIcon.png", SelectedImagePath = "FunctionIcon/Curtain/CurtainCloseOnIcon.png", + Tag = function.functionType + "_off_" + function.sid }; bodyDiv.AddChidren(btnCurtainClose); @@ -290,30 +330,33 @@ Height = Application.GetMinRealAverage(32), UnSelectedImagePath = "FunctionIcon/Curtain/CurtainOpenIcon.png", SelectedImagePath = "FunctionIcon/Curtain/CurtainOpenOnIcon.png", + Tag = function.functionType + "_on_" + function.sid }; bodyDiv.AddChidren(btnCurtainOpen); - - - + LoadEvent_ControlCurtain(btnCurtainStop, btnCurtainOpen, btnCurtainClose, function as Curtain); #endregion } - /// <summary> - /// 鍔犺浇绌鸿皟鍔熻兘鎺у埗鍗$墖 + /// 鍔犺浇鍔熻兘鐘舵�佷俊鎭寜閽� /// </summary> - void AcDiv() + void LoadLastStatesButton() { - #region AC - #endregion + var btnLastStates = new Button() + { + X = Application.GetRealWidth(10 + 32 + 8), + Y = Application.GetRealHeight(10 + 24 + 18), + Width = Application.GetRealWidth(200), + Height = Application.GetRealHeight(18), + Text = function.lastState, + TextAlignment = TextAlignment.CenterLeft, + SelectedTextColor = CSS_Color.PromptingColor1, + TextColor = 0x00000000, + TextSize = CSS_FontSize.PromptFontSize_SecondaryLevel, + Tag = function.functionType + "_laststates_" + function.sid, + IsSelected = function.on_off == "on" + }; + bodyDiv.AddChidren(btnLastStates); } - /// <summary> - /// 鍔犺浇鍦扮儹鍔熻兘鎺у埗鍗$墖 - /// </summary> - void FloorHeatingDiv() - { - #region 鍦扮儹 - #endregion - } } } -- Gitblit v1.8.0