From 43b0d5870d528f23ecd6aeceb6cfd4325188b46f Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 01 七月 2021 15:50:43 +0800
Subject: [PATCH] Revert "1"

---
 HDL_ON/UI/UI2/1-HomePage/HomePage.cs |  233 +++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 206 insertions(+), 27 deletions(-)

diff --git a/HDL_ON/UI/UI2/1-HomePage/HomePage.cs b/HDL_ON/UI/UI2/1-HomePage/HomePage.cs
index f2f00ae..d58d0ec 100644
--- a/HDL_ON/UI/UI2/1-HomePage/HomePage.cs
+++ b/HDL_ON/UI/UI2/1-HomePage/HomePage.cs
@@ -35,13 +35,21 @@
         /// </summary>
         FrameLayout environmentalView;
         /// <summary>
-        /// 褰撳墠娓╁害淇℃伅
+        /// 褰撳墠娓╁害淇℃伅-瀹ゅ
         /// </summary>
         TextButton btnTempValues;
         /// <summary>
-        /// 褰撳墠婀垮害淇℃伅
+        /// 褰撳墠婀垮害淇℃伅-瀹ゅ
         /// </summary>
         TextButton btnHumidityValues;
+        /// <summary>
+        /// 褰撳墠娓╁害淇℃伅-瀹ゅ唴
+        /// </summary>
+        TextButton btnIndoorTempValues;
+        /// <summary>
+        /// 褰撳墠婀垮害淇℃伅-瀹ゅ唴
+        /// </summary>
+        TextButton btnIndoorHumiValues;
         /// <summary>
         /// 褰撳墠pm2.5鐘舵��
         /// </summary>
@@ -113,6 +121,7 @@
 
         public void LoadPage()
         {
+            MainPage.CurPageIndex = 0;
             try
             {
                 this.BeginHeaderRefreshingAction = () =>
@@ -152,7 +161,7 @@
                 topView.AddChidren(btnLinkStateTip);
                 //鏇存柊閾炬帴鐘舵�乮con棰滆壊
                 CheckLinkStatus();//2020-12-22
-                //LoadEvent_CheckLinkStatus();
+                
 
                 btnResidenceName = new Button()
                 {
@@ -163,7 +172,7 @@
                     TextColor = CSS_Color.MainBackgroundColor,
                     TextSize = CSS_FontSize.EmphasisFontSize_FirstLevel,
                     TextAlignment = TextAlignment.CenterLeft,
-                    Text = DB_ResidenceData.Instance.CurrentRegion.Name,
+                    Text = DB_ResidenceData.Instance.CurrentRegion.homeName,
                     IsBold = true
                 };
                 topView.AddChidren(btnResidenceName);
@@ -183,9 +192,27 @@
                 };
                 topView.AddChidren(environmentalView);
                 #region 鐜鏁版嵁
+                var tempSensorList = FunctionList.List.GetEnvirSensorsList().FindAll((obj) => obj.spk == SPK.SensorTemperature);
+                var humiSensorList = FunctionList.List.GetEnvirSensorsList().FindAll((obj) => obj.spk == SPK.SensorHumidity);
+
+                var btnEnvirValuesTitle = new Button() {
+                    X = Application.GetRealWidth(12),
+                    Gravity = Gravity.CenterVertical,
+                    TextColor = CSS_Color.MainBackgroundColor,
+                    TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
+                    TextID = StringId.Outdoor,
+                    TextAlignment = TextAlignment.CenterLeft,
+                };
+                if (tempSensorList.Count > 0 || humiSensorList.Count > 0)
+                {
+                    btnEnvirValuesTitle.TextID = StringId.InOutdoor;
+                }
+                btnEnvirValuesTitle.Width = Application.GetRealWidth(8) + btnEnvirValuesTitle.GetTextWidth();
+                environmentalView.AddChidren(btnEnvirValuesTitle);
+
                 Button btnTempIcon = new Button()
                 {
-                    X = Application.GetRealWidth(12),
+                    X = btnEnvirValuesTitle.Right,
                     Gravity = Gravity.CenterVertical,
                     Width = Application.GetMinRealAverage(16),
                     Height = Application.GetMinRealAverage(16),
@@ -196,18 +223,45 @@
                 btnTempValues = new TextButton()
                 {
                     X = btnTempIcon.Right + Application.GetRealWidth(4),
-                    Width = Application.GetRealWidth(30),
                     Gravity = Gravity.CenterVertical,
                     TextColor = CSS_Color.MainBackgroundColor,
                     TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
                     Text = MainPage.cityInfo.temperature + "掳",
                     TextAlignment = TextAlignment.CenterLeft,
                 };
+                btnTempValues.Width = btnTempValues.GetTextWidth();
                 environmentalView.AddChidren(btnTempValues);
+
+                btnIndoorTempValues = new TextButton()
+                {
+                    X = btnTempValues.Right,
+                    Gravity = Gravity.CenterVertical,
+                    TextColor = CSS_Color.MainBackgroundColor,
+                    TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
+                    TextAlignment = TextAlignment.CenterLeft,
+                    Text = ""
+                };
+                if (tempSensorList.Count > 0)
+                {
+                    btnIndoorTempValues.Text = "/--掳";
+                    double tempTotalValues = 0;
+                    foreach (var temp in tempSensorList)
+                    {
+                        double tempValue = 0;
+                        double.TryParse(temp.GetAttrState(FunctionAttributeKey.Value), out tempValue);
+                        tempTotalValues += tempValue;
+                    }
+                    if (tempTotalValues > 0)
+                    {
+                        btnIndoorTempValues.Text = "/" + tempTotalValues + "掳";
+                    }
+                }
+                btnIndoorTempValues.Width = btnIndoorTempValues.GetTextWidth();
+                environmentalView.AddChidren(btnIndoorTempValues);
 
                 Button btnHumidityIcon = new Button()
                 {
-                    X = btnTempValues.Right + Application.GetRealWidth(2),
+                    X = btnIndoorTempValues.Right + Application.GetRealWidth(8),
                     Gravity = Gravity.CenterVertical,
                     Width = Application.GetMinRealAverage(16),
                     Height = Application.GetMinRealAverage(16),
@@ -218,18 +272,45 @@
                 btnHumidityValues = new TextButton()
                 {
                     X = btnHumidityIcon.Right + Application.GetRealWidth(4),
-                    Width = Application.GetRealWidth(30),
                     Gravity = Gravity.CenterVertical,
                     TextColor = CSS_Color.MainBackgroundColor,
                     TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
                     Text = MainPage.cityInfo.humidity + "%",
                     TextAlignment = TextAlignment.CenterLeft,
                 };
+                btnHumidityValues.Width = btnHumidityValues.GetTextWidth();
                 environmentalView.AddChidren(btnHumidityValues);
+
+                btnIndoorHumiValues = new TextButton()
+                {
+                    X = btnHumidityValues.Right,
+                    Gravity = Gravity.CenterVertical,
+                    TextColor = CSS_Color.MainBackgroundColor,
+                    TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
+                    TextAlignment = TextAlignment.CenterLeft,
+                    Text = ""
+                };
+                if (tempSensorList.Count > 0)
+                {
+                    btnIndoorHumiValues.Text = "/--%";
+                    double humiTotalValues = 0;
+                    foreach (var humi in humiSensorList)
+                    {
+                        double humiValue = 0;
+                        double.TryParse(humi.GetAttrState(FunctionAttributeKey.Value), out humiValue);
+                        humiTotalValues += humiValue;
+                    }
+                    if (humiTotalValues > 0)
+                    {
+                        btnIndoorHumiValues.Text = "/" + humiTotalValues + "%";
+                    }
+                }
+                btnIndoorHumiValues.Width = btnIndoorHumiValues.GetTextWidth();
+                environmentalView.AddChidren(btnIndoorHumiValues);
 
                 Button btnPm25Icon = new Button()
                 {
-                    X = btnHumidityValues.Right + Application.GetRealWidth(2),
+                    X = btnIndoorHumiValues.Right + Application.GetRealWidth(4),
                     Gravity = Gravity.CenterVertical,
                     Width = Application.GetMinRealAverage(16),
                     Height = Application.GetMinRealAverage(16),
@@ -240,13 +321,13 @@
                 btnPm25Values = new TextButton()
                 {
                     X = btnPm25Icon.Right + Application.GetRealWidth(4),
-                    Width = Application.GetRealWidth(130),
                     Gravity = Gravity.CenterVertical,
                     TextColor = CSS_Color.MainBackgroundColor,
                     TextSize = CSS_FontSize.PromptFontSize_FirstLevel,
                     Text = MainPage.cityInfo.pm25,
                     TextAlignment = TextAlignment.CenterLeft,
                 };
+                btnPm25Values.Width = btnPm25Values.GetTextWidth();
                 environmentalView.AddChidren(btnPm25Values);
                 #endregion
 
@@ -380,6 +461,90 @@
                 MainPage.Log($"HomePage LoadPage Error : {ex.Message}");
             }
 
+
+#if DEBUG
+            //FunctionList.List.Functions.Add(new Function() { spk = SPK.PjtIr, name = "娴嬭瘯鎶曞奖浠�",
+            //                            attributes = new List<FunctionAttributes>() {
+            //                                new FunctionAttributes(){ key = "on_off",curValue= "on",state = "on" },
+            //                                new FunctionAttributes(){ key = "computer",value = new List<string>(){"鐢佃剳" } },
+            //                                new FunctionAttributes(){ key = "video",value = new List<string>(){"瑙嗛" } },
+            //                                new FunctionAttributes(){ key = "source",value = new List<string>(){"淇″彿婧�" } },
+            //                                new FunctionAttributes(){ key = "zoom+",value = new List<string>(){"鍙樼劍+" } },
+            //                                new FunctionAttributes(){ key = "zoom-",value = new List<string>(){"鍙樼劍-" } },
+            //                                new FunctionAttributes(){ key = "page+",value = new List<string>(){"鐢婚潰+" } },
+            //                                new FunctionAttributes(){ key = "page-",value = new List<string>(){"鐢婚潰-" } },
+            //                                new FunctionAttributes(){ key = "menu",value = new List<string>(){"鑿滃崟" } },
+            //                                new FunctionAttributes(){ key = "ok",value = new List<string>(){"纭" } },
+            //                                new FunctionAttributes(){ key = "up",value = new List<string>(){"涓�" } },
+            //                                new FunctionAttributes(){ key = "left",value = new List<string>(){"宸�" } },
+            //                                new FunctionAttributes(){ key = "right",value = new List<string>(){"鍙�" } },
+            //                                new FunctionAttributes(){ key = "down",value = new List<string>(){"涓�" } },
+            //                                new FunctionAttributes(){ key = "exit",value = new List<string>(){"閫�鍑�" } },
+            //                                new FunctionAttributes(){ key = "volume+",value = new List<string>(){"闊抽噺+" } },
+            //                                new FunctionAttributes(){ key = "volume-",value = new List<string>(){"闊抽噺-" } },
+            //                                new FunctionAttributes(){ key = "mute",value = new List<string>(){"闈欓煶" } },
+            //                                new FunctionAttributes(){ key = "auto",value = new List<string>(){"鑷姩" } },
+            //                                new FunctionAttributes(){ key = "pause",value = new List<string>(){"鏆傚仠" } },
+            //                            }
+            //});
+
+            //FunctionList.List.Functions.Add(new Function()
+            //{
+            //    spk = SPK.StbIr,
+            //    name = "娴嬭瘯鏈洪《鐩�",
+            //    attributes = new List<FunctionAttributes>() {
+            //                                new FunctionAttributes(){ key = "on_off",curValue= "on",state = "on" },
+            //                                new FunctionAttributes(){ key = "computer",value = new List<string>(){"鐢佃剳" } },
+            //                                new FunctionAttributes(){ key = "video",value = new List<string>(){"瑙嗛" } },
+            //                                new FunctionAttributes(){ key = "source",value = new List<string>(){"淇″彿婧�" } },
+            //                                new FunctionAttributes(){ key = "zoom+",value = new List<string>(){"鍙樼劍+" } },
+            //                                new FunctionAttributes(){ key = "zoom-",value = new List<string>(){"鍙樼劍-" } },
+            //                                new FunctionAttributes(){ key = "page+",value = new List<string>(){"鐢婚潰+" } },
+            //                                new FunctionAttributes(){ key = "page-",value = new List<string>(){"鐢婚潰-" } },
+            //                                new FunctionAttributes(){ key = "menu",value = new List<string>(){"鑿滃崟" } },
+            //                                new FunctionAttributes(){ key = "ok",value = new List<string>(){"纭" } },
+            //                                new FunctionAttributes(){ key = "up",value = new List<string>(){"涓�" } },
+            //                                new FunctionAttributes(){ key = "left",value = new List<string>(){"宸�" } },
+            //                                new FunctionAttributes(){ key = "right",value = new List<string>(){"鍙�" } },
+            //                                new FunctionAttributes(){ key = "down",value = new List<string>(){"涓�" } },
+            //                                new FunctionAttributes(){ key = "exit",value = new List<string>(){"閫�鍑�" } },
+            //                                new FunctionAttributes(){ key = "volume+",value = new List<string>(){"闊抽噺+" } },
+            //                                new FunctionAttributes(){ key = "volume-",value = new List<string>(){"闊抽噺-" } },
+            //                                new FunctionAttributes(){ key = "mute",value = new List<string>(){"闈欓煶" } },
+            //                                new FunctionAttributes(){ key = "auto",value = new List<string>(){"鑷姩" } },
+            //                                new FunctionAttributes(){ key = "pause",value = new List<string>(){"鏆傚仠" } },
+            //                            }
+            //});
+
+            //FunctionList.List.Functions.Add(new Function()
+            //{
+            //    spk = SPK.TvIr,
+            //    name = "娴嬭瘯鐢佃",
+            //    attributes = new List<FunctionAttributes>() {
+            //                                new FunctionAttributes(){ key = "on_off",curValue= "on",state = "on" },
+            //                                new FunctionAttributes(){ key = "computer",value = new List<string>(){"鐢佃剳" } },
+            //                                new FunctionAttributes(){ key = "video",value = new List<string>(){"瑙嗛" } },
+            //                                new FunctionAttributes(){ key = "source",value = new List<string>(){"淇″彿婧�" } },
+            //                                new FunctionAttributes(){ key = "zoom+",value = new List<string>(){"鍙樼劍+" } },
+            //                                new FunctionAttributes(){ key = "zoom-",value = new List<string>(){"鍙樼劍-" } },
+            //                                new FunctionAttributes(){ key = "page+",value = new List<string>(){"鐢婚潰+" } },
+            //                                new FunctionAttributes(){ key = "page-",value = new List<string>(){"鐢婚潰-" } },
+            //                                new FunctionAttributes(){ key = "menu",value = new List<string>(){"鑿滃崟" } },
+            //                                new FunctionAttributes(){ key = "ok",value = new List<string>(){"纭" } },
+            //                                new FunctionAttributes(){ key = "up",value = new List<string>(){"涓�" } },
+            //                                new FunctionAttributes(){ key = "left",value = new List<string>(){"宸�" } },
+            //                                new FunctionAttributes(){ key = "right",value = new List<string>(){"鍙�" } },
+            //                                new FunctionAttributes(){ key = "down",value = new List<string>(){"涓�" } },
+            //                                new FunctionAttributes(){ key = "exit",value = new List<string>(){"閫�鍑�" } },
+            //                                new FunctionAttributes(){ key = "volume+",value = new List<string>(){"闊抽噺+" } },
+            //                                new FunctionAttributes(){ key = "volume-",value = new List<string>(){"闊抽噺-" } },
+            //                                new FunctionAttributes(){ key = "mute",value = new List<string>(){"闈欓煶" } },
+            //                                new FunctionAttributes(){ key = "auto",value = new List<string>(){"鑷姩" } },
+            //                                new FunctionAttributes(){ key = "pause",value = new List<string>(){"鏆傚仠" } },
+            //                            }
+            //});
+#endif
+
         }
         /// <summary>
         /// 鍔犺浇鍐呭鍖哄煙
@@ -466,12 +631,18 @@
             try
             {
                 int index = 0;
-                foreach (var function in FunctionList.List.GetDeviceFunctionList())
+                var list = FunctionList.List.GetDeviceFunctionList();
+                foreach (var function in list)
                 {
                     //闊充箰妯″潡鏈変富浠庡叧绯伙紝闇�瑕佺壒娈婂鐞�
                     if (function.Spk_Prefix == FunctionCategory.Music)
                     {
-                        var music = function as Music.A31MusicModel;
+                        //var music = function as Music.A31MusicModel;
+                        var music = Music.A31MusicModel.A31MusicModelList.Find((obj) => obj.sid == function.sid);
+                        if (music == null)
+                        {
+                            continue;
+                        }
                         if (music.ServerClientType == -1)
                         {
                             continue;
@@ -671,6 +842,11 @@
                 };
                 view.AddChidren(btnIcon);
 
+
+                btnIcon.UnSelectedImagePath = $"FunctionIcon/Icon/HomeIcon/{function.IconName}_blue.png";
+                btnIcon.SelectedImagePath = $"FunctionIcon/Icon/HomeIcon/{function.IconName}_white.png";
+
+
                 Button btnName;
                 btnName = new Button()
                 {
@@ -731,12 +907,12 @@
                     SelectedImagePath = "Collection/CollectionWhiteIcon.png",
                     UnSelectedImagePath = "Collection/CollectionIcon.png",
                 };
-                //view.AddChidren(btnCollection);
+                view.AddChidren(btnCollection);
                 //2020-12-16 濡傛灉鏄垚鍛橀殣钘忔敹钘忓姛鑳�
-                if (!DB_ResidenceData.Instance.CurrentRegion.IsOthreShare)
-                {
-                    view.AddChidren(btnCollection);
-                }
+                //if (!DB_ResidenceData.Instance.CurrentRegion.isOtherShare)
+                //{
+                //    view.AddChidren(btnCollection);
+                //}
 
                 LoadEvent_FunctionCollection(btnCollection, function);
                 if (//SPK.CurtainSpkList().Contains(function.spk))
@@ -772,14 +948,17 @@
                     LoadEvent_ControlCurtain(function, btnCurtainClose, btnCurtainOpen);
                 }
 
-                else if (function.spk == SPK.ElectricTV || function.spk == SPK.TvIr)
+                else if (function.spk == SPK.ElectricTV || function.spk == SPK.TvIr || function.spk == SPK.TvXmIr
+                    || function.spk == SPK.StbIr || function.spk == SPK.PjtIr)
                 {
-                    btnIcon.UnSelectedImagePath = "FunctionIcon/Electrical/TVIcon.png";
+                    //btnIcon.UnSelectedImagePath = $"FunctionIcon/Icon/HomeIcon/{function.IconName}_blue.png";
+                    //btnIcon.SelectedImagePath = $"FunctionIcon/Icon/HomeIcon/{function.IconName}_white.png";
+
                     Button btnPower;
                     btnPower = new Button()
                     {
                         X = Application.GetRealWidth(131),
-                        Y = Application.GetRealHeight(70),
+                        Y = Application.GetRealHeight(80),
                         Width = Application.GetRealWidth(32),
                         Height = Application.GetRealWidth(32),
                         UnSelectedImagePath = "Public/PowerClose.png",
@@ -959,7 +1138,7 @@
                 btnIcon.MouseUpEventHandler = skipControlPageEvent;
                 btnState.MouseUpEventHandler = skipControlPageEvent;
                 //鐢佃涓嶉渶瑕佹洿鏂扮姸鎬�
-                if(function.spk!= SPK.ElectricTV)
+                if(function.spk!= SPK.ElectricTV && function.spk != SPK.StbIr && function.spk != SPK.PjtIr)
                 {
                     UpdataFunctionStates(function);
                 }
@@ -1005,7 +1184,7 @@
                     Width = Application.GetRealWidth(32),
                     UnSelectedImagePath = "Public/FuncInfoSetIcon_white.png",
                 };
-                if (!DB_ResidenceData.Instance.CurrentRegion.IsOthreShare)
+                if (!DB_ResidenceData.Instance.CurrentRegion.isOtherShare)
                 {
                     view.AddChidren(btnSettingIcon);
                 }
@@ -1050,12 +1229,12 @@
                     SelectedImagePath = "Collection/CollectionWhiteIcon.png",
                     UnSelectedImagePath = "Collection/CollectionIcon.png",
                 };
-                //view.AddChidren(btnCollection);
+                view.AddChidren(btnCollection);
                 //2020-12-16 濡傛灉鏄垚鍛橀殣钘忔敹钘忓姛鑳�
-                if (!DB_ResidenceData.Instance.CurrentRegion.IsOthreShare)
-                {
-                    view.AddChidren(btnCollection);
-                }
+                //if (!DB_ResidenceData.Instance.CurrentRegion.isOtherShare)
+                //{
+                //    view.AddChidren(btnCollection);
+                //}
 
                 LoadEvent_SceneCollection(btnCollection, scene);
 

--
Gitblit v1.8.0