From 38df05b600e7a41106f710a3e4287e37fbf35d03 Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期四, 27 十月 2022 09:10:34 +0800
Subject: [PATCH] 备份

---
 HDL_ON/UI/UI2/FuntionControlView/Acst/AcstParentPage.cs |  662 ++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 582 insertions(+), 80 deletions(-)

diff --git a/HDL_ON/UI/UI2/FuntionControlView/Acst/AcstParentPage.cs b/HDL_ON/UI/UI2/FuntionControlView/Acst/AcstParentPage.cs
index 1f6ad58..774698a 100644
--- a/HDL_ON/UI/UI2/FuntionControlView/Acst/AcstParentPage.cs
+++ b/HDL_ON/UI/UI2/FuntionControlView/Acst/AcstParentPage.cs
@@ -1,5 +1,6 @@
 锘縰sing System;
 using System.Collections.Generic;
+using HDL_ON.DriverLayer;
 using HDL_ON.Entity;
 using Shared;
 
@@ -32,12 +33,18 @@
         SensorDiyView sensorDiyView_Tvoc;
         SensorDiyView sensorDiyView_EleDay;
         SensorDiyView sensorDiyView_EleMonth;
-        SensorDiyView sensorDiyView_EleTotal;
+        SensorDiyView sensorDiyView_EleActivePower;
         #endregion
         /// <summary>
         /// 瀛愭帶鍖哄煙鍒楄〃
         /// </summary>
         Dictionary<string, AcstSubControlView> subViewList;
+
+
+        Button btnWorkSceneControl;
+
+        Button btnModeControl;
+        Button btnPowerControl;
 
 
         public override void RemoveFromParent()
@@ -82,7 +89,7 @@
             };
         }
         /// <summary>
-        /// 浼犳劅鍣ㄣ�佽�楃數閲忕粍浠�
+        /// 鏇存柊涓绘帶鏁版嵁淇℃伅
         /// </summary>
         public static void UpdateAcstParentInfo(Function temp)
         {
@@ -90,23 +97,73 @@
             {
                 return;
             }
-            if (basePage.sensorDiyView_Temp != null)
-                basePage.sensorDiyView_Temp.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.room_temp.ToString()).curValue.ToString());
-            if (basePage.sensorDiyView_Humi != null)
-                basePage.sensorDiyView_Humi.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.room_humidity.ToString()).curValue.ToString());
-            if (basePage.sensorDiyView_Pm25 != null)
-                basePage.sensorDiyView_Pm25.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.pm25.ToString()).curValue.ToString());
-            if (basePage.sensorDiyView_Co2 != null)
-                basePage.sensorDiyView_Co2.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.co2.ToString()).curValue.ToString());
-            if (basePage.sensorDiyView_Tvoc != null)
-                basePage.sensorDiyView_Tvoc.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.tvoc.ToString()).curValue.ToString());
-            if (basePage.sensorDiyView_EleDay != null)
-                basePage.sensorDiyView_EleDay.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.day_electricity.ToString()).curValue.ToString());
-            if (basePage.sensorDiyView_EleMonth != null)
-                basePage.sensorDiyView_EleMonth.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.month_electricity.ToString()).curValue.ToString());
-            if (basePage.sensorDiyView_EleTotal != null)
-                basePage.sensorDiyView_EleTotal.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.total_electricity.ToString()).curValue.ToString());
+            Application.RunOnMainThread(() =>
+            {
+                if (basePage.sensorDiyView_Temp != null)
+                    basePage.sensorDiyView_Temp.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.room_temp.ToString()).state);
+                if (basePage.sensorDiyView_Humi != null)
+                    basePage.sensorDiyView_Humi.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.room_humidity.ToString()).state);
+                if (basePage.sensorDiyView_Pm25 != null)
+                    basePage.sensorDiyView_Pm25.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.pm25.ToString()).state);
+                if (basePage.sensorDiyView_Co2 != null)
+                    basePage.sensorDiyView_Co2.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.co2.ToString()).state);
+                if (basePage.sensorDiyView_Tvoc != null)
+                    basePage.sensorDiyView_Tvoc.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.tvoc.ToString()).state);
+                if (basePage.sensorDiyView_EleDay != null)
+                    basePage.sensorDiyView_EleDay.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.day_electricity.ToString()).state);
+                if (basePage.sensorDiyView_EleMonth != null)
+                    basePage.sensorDiyView_EleMonth.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.month_electricity.ToString()).state);
+                if (basePage.sensorDiyView_EleActivePower != null)
+                    basePage.sensorDiyView_EleActivePower.UpdateValue(temp.GetAttribute(AcstParent_AttrEnum.active_power.ToString()).state);
+
+
+
+                switch (temp.GetAttrState("mode"))
+                {
+                    case "cool"://鍒跺喎
+                        basePage.btnModeControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/ModeCoolIcon2.png";
+                        basePage.btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/ModeCoolIcon2.png";
+                        break;
+                    case "heat"://鍒剁儹
+                        basePage.btnModeControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/ModeHeatIcon2.png";
+                        basePage.btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/ModeHeatIcon2.png";
+                        break;
+                    case "fan"://閫氶
+                        basePage.btnModeControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/ModeFanIcon2.png";
+                        basePage.btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/ModeFanIcon2.png";
+                        break;
+                    case "dry"://闄ゆ箍
+                        basePage.btnModeControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/ModeDeHumiIcon2.png";
+                        basePage.btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/ModeDeHumiIcon2.png";
+                        break;
+                    case "humidity"://鍔犳箍
+                        basePage.btnModeControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/ModeHumiIcon2.png";
+                        basePage.btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/ModeHumiIcon2.png";
+                        break;
+                    case "heat_humidity"://鍒剁儹鍔犳箍
+                        basePage.btnModeControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/ModeHeatHumiIcon2.png";
+                        basePage.btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/ModeHeatHumiIcon2.png";
+                        break;
+                }
+                switch (temp.GetAttrState("scene"))
+                {
+                    case "at_home"://鍦ㄥ
+                        basePage.btnWorkSceneControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/SceneAtHome2.png";
+                        basePage.btnWorkSceneControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/SceneAtHome2.png";
+                        break;
+                    case "leave_home"://绂诲
+                        basePage.btnWorkSceneControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/SceneAwayHomeIcon2.png";
+                        basePage.btnWorkSceneControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/SceneAwayHomeIcon2.png";
+                        break;
+                    case "sleep"://鐫$湢
+                        basePage.btnWorkSceneControl.UnSelectedImagePath = "FunctionIcon/Acst/grey/SceneSleepIcon2.png";
+                        basePage.btnWorkSceneControl.SelectedImagePath = $"FunctionIcon/Acst/{basePage.imageFolder}/SceneSleepIcon2.png";
+                        break;
+                }
+                basePage.btnModeControl.IsSelected = basePage.btnWorkSceneControl.IsSelected = basePage.btnPowerControl.IsSelected = temp.trait_on_off.state == "on";
+            });
         }
+
 
         /// <summary>
         /// 鏇存柊瀛愭帶淇℃伅
@@ -123,7 +180,7 @@
                 if(view!= null)
                 {
                     view.btnSubHumidityValues.Text = temp.GetAttrState(AcstSub_AttrEnum.room_humidity.ToString()) + "%";
-                    view.btnSubTempValues.Text = temp.GetAttrState(AcstSub_AttrEnum.room_humidity.ToString()) + "%";
+                    view.btnSubTempValues.Text = temp.GetAttrState(AcstSub_AttrEnum.room_temp.ToString()) + "掳";
                     view.btnSubPower.IsSelected = temp.GetAttrState(AcstSub_AttrEnum.on_off.ToString()) == "on";
                 }
             });
@@ -132,22 +189,39 @@
         public void LoadPage()
         {
             var curTime = DateTime.Now;
-            string helloText = "涓婂崍濂�";
+            string helloText = "涓婂崍濂�"; 
+            if (Language.CurrentLanguage != "Chinese")
+            {
+                helloText = "Good morning";
+            }
             if (curTime.Hour >= 8 && curTime.Hour < 12)
             {
                 helloText = "涓婂崍濂�";
+                if (Language.CurrentLanguage != "Chinese")
+                {
+                    helloText = "Good morning";
+                }
                 curColor = CSS.CSS_Color.MainColor;
                 imageFolder = "blue";
             }
             else if (curTime.Hour >= 12 && curTime.Hour < 18)
             {
                 helloText = "涓嬪崍濂�";
+                if (Language.CurrentLanguage != "Chinese")
+                {
+                    helloText = "Good afternoon";
+                }
                 curColor = 0xFFE7914F;
                 imageFolder = "orange";
             }
             else
             {
                 helloText = "鏅氫笂濂�";
+                if (Language.CurrentLanguage != "Chinese")
+                {
+                    helloText = "Good evening";
+                }
+                
                 curColor = 0xFF9175F3;
                 imageFolder = "purple";
             }
@@ -155,8 +229,7 @@
             #region 澶撮儴淇℃伅鍖哄煙
             FrameLayout topView = new FrameLayout()
             {
-                Height = Application.GetRealHeight(181),
-                BackgroundColor = 0xFFb0eafa,
+                Height = Application.GetRealHeight(180),
                 BackgroundImagePath = $"FunctionIcon/Acst/{imageFolder}/TopViewBg.png",
             };
             bodyView.AddChidren(topView);
@@ -172,13 +245,16 @@
             Button btnBackIcon = new Button()
             {
                 X = Application.GetRealWidth(16),
-                Width = Application.GetRealWidth(40),
-                Height = Application.GetRealWidth(28),
-                UnSelectedImagePath = "Public/BackIcon.png",
+                Width = Application.GetRealWidth(12),
+                Height = Application.GetRealHeight(20),
+                UnSelectedImagePath = "FunctionIcon/Acst/BackIcon.png",
             };
             backView.AddChidren(btnBackIcon);
 
-            btnBackIcon.MouseUpEventHandler = (sender, e) => {
+            Button btnBackClick = new Button();
+            backView.AddChidren(btnBackClick);
+
+            btnBackClick.MouseUpEventHandler = (sender, e) => {
                 this.RemoveFromParent();
             };
 
@@ -195,7 +271,7 @@
             };
             topView.AddChidren(btnHelloText);
 
-            
+
             btnOutdoorTemp = new Button()
             {
                 X = Application.GetRealWidth(25),
@@ -303,12 +379,12 @@
             #region 浼犳劅鍣ㄦ暟鎹�
             int sensorCount = 0;
             var tempObj = function.GetAttribute(AcstParent_AttrEnum.room_temp.ToString());
-            if(tempObj!= null)
+            if (tempObj != null)
             {
                 sensorCount++;
             }
             var humiObj = function.GetAttribute(AcstParent_AttrEnum.room_humidity.ToString());
-            if(humiObj != null)
+            if (humiObj != null)
             {
                 sensorCount++;
             }
@@ -333,33 +409,40 @@
                 Width = Application.GetRealWidth(60 * sensorCount),
                 Gravity = Gravity.Center,
             };
-            infoContentView.AddChidren(sensorListView);
-
+            if (sensorCount > 0)
+            {
+                infoContentView.AddChidren(sensorListView);
+            }
 
             if (tempObj != null)
             {
-                sensorDiyView_Temp = new SensorDiyView(sensorListView, curColor, tempObj.curValue.ToString() + "掳", "娓╁害");
+                sensorDiyView_Temp = new SensorDiyView(sensorListView, curColor, tempObj.state == "" ? "--" : tempObj.state, "掳", Language.StringByID(StringId.Temp));
             }
             if (humiObj != null)
             {
-                sensorDiyView_Humi = new SensorDiyView(sensorListView, curColor, humiObj.curValue.ToString() + "%", "婀垮害");
+                sensorDiyView_Humi = new SensorDiyView(sensorListView, curColor, humiObj.state == "" ? "--" : humiObj.state, "%", Language.StringByID(StringId.Humidity));
             }
             if (pm25Obj != null)
             {
-                sensorDiyView_Pm25 = new SensorDiyView(sensorListView, curColor, pm25Obj.curValue.ToString(), "PM2.5");
+                sensorDiyView_Pm25 = new SensorDiyView(sensorListView, curColor, pm25Obj.state == "" ? "--" : pm25Obj.state, "", "PM2.5");
             }
             if (co2Obj != null)
             {
-                sensorDiyView_Co2 = new SensorDiyView(sensorListView, curColor, co2Obj.curValue.ToString(), "CO2");
+                sensorDiyView_Co2 = new SensorDiyView(sensorListView, curColor, co2Obj.state == "" ? "--" : co2Obj.state, "", "CO2");
             }
             if (tvocObj != null)
             {
-                sensorDiyView_Tvoc = new SensorDiyView(sensorListView, curColor, tvocObj.curValue.ToString(), "TVOC");
+                sensorDiyView_Tvoc = new SensorDiyView(sensorListView, curColor, tvocObj.state == "" ? "--" : tvocObj.state, "", "TVOC");
             }
             #endregion
 
             #region 鑳借�楁暟鎹�
             int energyCount = 0;
+            var totalObj = function.GetAttribute(AcstParent_AttrEnum.active_power.ToString());
+            if (totalObj != null)
+            {
+                energyCount++;
+            }
             var dayObj = function.GetAttribute(AcstParent_AttrEnum.day_electricity.ToString());
             if (dayObj != null)
             {
@@ -370,31 +453,45 @@
             {
                 energyCount++;
             }
-            var totalObj = function.GetAttribute(AcstParent_AttrEnum.total_electricity.ToString());
-            if (totalObj != null)
-            {
-                energyCount++;
-            }
-
             var energyListView = new HorizontalScrolViewLayout()
             {
-                Width = Application.GetRealWidth(60 * energyCount),
+                Width = Application.GetRealWidth(100 * energyCount),
                 Gravity = Gravity.Center,
                 Visible = false,
             };
-            infoContentView.AddChidren(energyListView);
-            if (dayObj != null)
+            if (energyCount > 0)
             {
-                sensorDiyView_EleDay = new SensorDiyView(energyListView, curColor, dayObj.curValue.ToString(), "浠婃棩鑰楃數");
-            }
-            if (monthObj != null)
-            {
-                sensorDiyView_EleMonth = new SensorDiyView(energyListView, curColor, monthObj.curValue.ToString(), "鏈湀鑰楃數");
+                infoContentView.AddChidren(energyListView);
             }
             if (totalObj != null)
             {
-                sensorDiyView_EleTotal = new SensorDiyView(energyListView, curColor, totalObj.curValue.ToString(), "鎬昏�楃數閲�");
+                string text = "鐢ㄧ數鍔熺巼";
+                if (Language.CurrentLanguage != "Chinese")
+                {
+                    text = "Power";
+                }
+
+                sensorDiyView_EleActivePower = new SensorDiyView(energyListView, curColor, totalObj.state == "" ? "--" : totalObj.state , "KW", text, 100);
             }
+            if (dayObj != null)
+            {
+                string text = "浠婃棩鑰楃數";
+                if (Language.CurrentLanguage != "Chinese")
+                {
+                    text = "Power of today";
+                }
+                sensorDiyView_EleDay = new SensorDiyView(energyListView, curColor, dayObj.state == "" ? "--" : dayObj.state , "KW", text,100);
+            }
+            if (monthObj != null)
+            {
+                string text = "鏈湀鑰楃數";
+                if (Language.CurrentLanguage != "Chinese")
+                {
+                    text = "Power of month";
+                }
+                sensorDiyView_EleMonth = new SensorDiyView(energyListView, curColor, monthObj.state == "" ? "--" : monthObj.state , "KWh", text, 100);
+            }
+
 
             var btnChangeClick = new Button();
             infoView.AddChidren(btnChangeClick);
@@ -414,8 +511,10 @@
                     energyListView.Visible = false;
                 }
             };
-            btnChangeClick.MouseUpEventHandler = changeInfoEvent;
-
+            if (sensorCount > 0 && energyCount > 0)
+            {
+                btnChangeClick.MouseUpEventHandler = changeInfoEvent;
+            }
 
             #endregion
 
@@ -440,8 +539,18 @@
                 SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/CollectionIcon.png",
             };
             subTitleView.AddChidren(btnCollection);
+            //鏀惰棌
+            btnCollection.MouseUpEventHandler = (sender, e) => {
+                function.collect = !function.collect;
+                btnCollection.IsSelected = function.collect;
 
-            var btnTitleText = new Button()
+                //var http = new DAL.Server.HttpServerRequest();
+                //http.CollectDevice(function.deviceId);
+                function.CollectFunction();
+
+            };
+
+            var btnTitleText2 = new Button()
             {
                 X = btnCollection.Right,
                 Text = "鎴戠殑瀹跺涵",
@@ -451,7 +560,11 @@
                 IsBold = true,
                 Height = Application.GetRealHeight(54),
             };
-            subTitleView.AddChidren(btnTitleText);
+            subTitleView.AddChidren(btnTitleText2);
+            if(Language.CurrentLanguage != "Chinese")
+            {
+                btnTitleText2.Text = "My Home";
+            }
 
             int subFunctionCount = 0;
 
@@ -484,7 +597,7 @@
 
                 subViewList.Add(sub.sid, subFunctionView);
 
-
+                Control.Ins.SendReadCommand(sub);
 
                 subFunctionCount++;
             }
@@ -505,19 +618,24 @@
             };
             this.AddChidren(bottomView);
 
-            var btnModeControl = new Button()
+            btnModeControl = new Button()
             {
                 X = Application.GetRealWidth(89),
                 Gravity = Gravity.CenterVertical,
                 Width = Application.GetRealWidth(38),
                 Height = Application.GetRealWidth(38),
-                UnSelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/ModeCoolIcon2.png",
+                UnSelectedImagePath = "FunctionIcon/Acst/grey/ModeCoolIcon2.png",
                 SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/ModeCoolIcon2.png",
                 TextAlignment = TextAlignment.Center,
+                IsSelected = function.trait_on_off.state == "on"
             };
             bottomView.AddChidren(btnModeControl);
-            btnModeControl.MouseUpEventHandler = (sender, e) =>
+            btnModeControl.MouseUpEventHandler = (sender3, e3) =>
             {
+                if(function.trait_on_off.state == "off")
+                {
+                    return;
+                }
                 Dialog dialog = new Dialog();
 
                 var dialogView = new FrameLayout();
@@ -529,8 +647,8 @@
                 var dialogContentView = new FrameLayout() {
                     X = Application.GetRealWidth(34),
                     Y = Application.GetRealHeight(291),
-                    Width = Application.GetRealWidth(144),
-                    Height = Application.GetRealHeight(291),
+                    Width = Application.GetRealWidth(148),
+                    Height = Application.GetRealHeight(319),
                     BackgroundImagePath = "FunctionIcon/Acst/BgChooseMode.png",
                 };
                 dialogView.AddChidren(dialogContentView);
@@ -546,7 +664,7 @@
                 {
                     X = Application.GetRealWidth(16),
                     Width = Application.GetRealWidth(100),
-                    Text = "閫夋嫨妯″紡",
+                    TextID = StringId.SelectScene,
                     TextSize = 16,
                     TextColor = CSS.CSS_Color.FirstLevelTitleColor,
                     IsBold = true,
@@ -554,36 +672,377 @@
                 };
                 titleView.AddChidren(btnTitleText);
 
+                #region 鍒跺喎
+                var coolView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = titleView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(coolView);
+                coolView.AddChidren(new Button
+                {
+                    Width = Application.GetRealWidth(112),
+                    Gravity = Gravity.CenterHorizontal,
+                    Height = 1,
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton coolIconButton = new IconButton("FunctionIcon/Acst/grey/ModeCoolIcon.png", $"FunctionIcon/Acst/{imageFolder}/ModeCoolIcon.png",
+                    Language.StringByID(StringId.Cool),curColor, function.GetAttrState(AcstParent_AttrEnum.mode.ToString()) == "cool");
+                coolIconButton.Click(()=> {
+                    dialog.Close();
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/ModeCoolIcon2.png";
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add(AcstParent_AttrEnum.mode.ToString(), AcstParent_Attr_ModeValueEnum.cool.ToString());
+                        Control.Ins.SendWriteCommand(function, d);
+                    }) { IsBackground = true }.Start();
+                });
+                coolView.AddChidren(coolIconButton);
+                #endregion
 
 
+                #region 鍒剁儹
+                var heatView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = coolView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(heatView);
+                heatView.AddChidren(new Button
+                {
+                    Width = Application.GetRealWidth(112),
+                    Gravity = Gravity.CenterHorizontal,
+                    Height = 1,
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton heatIconButton = new IconButton("FunctionIcon/Acst/grey/ModeHeatIcon.png", $"FunctionIcon/Acst/{imageFolder}/ModeHeatIcon.png",
+                    Language.StringByID(StringId.Heat), curColor, function.GetAttrState(AcstParent_AttrEnum.mode.ToString()) == "heat");
+                heatIconButton.Click(() => {
+                    dialog.Close();
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/ModeHeatIcon2.png";
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add("mode", "heat");
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+                heatView.AddChidren(heatIconButton);
+                #endregion 
 
+                #region 闄ゆ箍
+                var dehumiView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = heatView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(dehumiView);
+                dehumiView.AddChidren(new Button
+                {
+                    Width = Application.GetRealWidth(112),
+                    Gravity = Gravity.CenterHorizontal,
+                    Height = 1,
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton dehumiIconButton = new IconButton("FunctionIcon/Acst/grey/ModeDeHumiIcon.png", $"FunctionIcon/Acst/{imageFolder}/ModeDeHumiIcon.png",
+                    Language.StringByID(StringId.Humidity), curColor, function.GetAttrState(AcstParent_AttrEnum.mode.ToString()) == AcstParent_Attr_ModeValueEnum.dry.ToString());
+                dehumiIconButton.Click(() => {
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/ModeDeHumiIcon2.png";
+                    dialog.Close();
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add("mode", AcstParent_Attr_ModeValueEnum.dry.ToString());
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+                dehumiView.AddChidren(dehumiIconButton);
+                #endregion 
+
+                #region 閫氶
+                var fanView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = dehumiView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(fanView);
+                fanView.AddChidren(new Button
+                {
+                    Width = Application.GetRealWidth(112),
+                    Gravity = Gravity.CenterHorizontal,
+                    Height = 1,
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton fanIconButton = new IconButton("FunctionIcon/Acst/grey/ModeFanIcon.png", $"FunctionIcon/Acst/{imageFolder}/ModeFanIcon.png",
+                    Language.StringByID(StringId.Ventilated), curColor, function.GetAttrState(AcstParent_AttrEnum.mode.ToString()) == AcstParent_Attr_ModeValueEnum.fan.ToString());
+                fanIconButton.Click(() => {
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/ModeFanIcon2.png";
+                    dialog.Close();
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add("mode", AcstParent_Attr_ModeValueEnum.fan.ToString());
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+                fanView.AddChidren(fanIconButton);
+                #endregion 
+
+                #region 鍒剁儹闄ゆ箍
+                var heatHumiView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = fanView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(heatHumiView);
+                heatHumiView.AddChidren(new Button
+                {
+                    Gravity = Gravity.CenterHorizontal,
+                    Width = Application.GetRealWidth(112),
+                    Height = 1,
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton heatHumiIconButton = new IconButton("FunctionIcon/Acst/grey/ModeHeatHumiIcon.png", $"FunctionIcon/Acst/{imageFolder}/ModeHeatHumiIcon.png",
+                    Language.StringByID(StringId.HeatingAndDehumidification), curColor, function.GetAttrState(AcstParent_AttrEnum.mode.ToString()) == AcstParent_Attr_ModeValueEnum.heat_humidity.ToString());
+                heatHumiIconButton.Click(() => {
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/ModeHeatHumiIcon2.png";
+                    dialog.Close();
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add("mode", AcstParent_Attr_ModeValueEnum.heat_humidity.ToString());
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+                heatHumiView.AddChidren(heatHumiIconButton);
+                #endregion 
+
+                #region 鍔犳箍
+                var humiView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = heatHumiView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(humiView);
+                humiView.AddChidren(new Button
+                {
+                    Width = Application.GetRealWidth(112),
+                    Gravity = Gravity.CenterHorizontal,
+                    Height = 1,
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton humiIconButton = new IconButton("FunctionIcon/Acst/grey/ModeHumiIcon.png", $"FunctionIcon/Acst/{imageFolder}/ModeHumiIcon.png",
+                    Language.StringByID(StringId.Humidification), curColor, function.GetAttrState(AcstParent_AttrEnum.mode.ToString()) == AcstParent_Attr_ModeValueEnum.humidity.ToString());
+                humiIconButton.Click(() => {
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/ModeHumiIcon2.png";
+                    dialog.Close();
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add("mode", AcstParent_Attr_ModeValueEnum.humidity.ToString());
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+                humiView.AddChidren(humiIconButton);
+                #endregion 
 
                 dialog.Show();
             };
 
-            var btnPowerControl = new Button()
+            btnPowerControl = new Button()
             {
                 Gravity = Gravity.Center,
                 Width = Application.GetRealWidth(38),
                 Height = Application.GetRealWidth(38),
                 UnSelectedImagePath = "FunctionIcon/Acst/grey/PowerOffIcon.png",
-                SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/PowerOnIcon.png",
+                SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/PowerIcon.png",
                 TextAlignment = TextAlignment.Center,
+                IsSelected = function.trait_on_off.state == "on"
             };
             bottomView.AddChidren(btnPowerControl);
+            btnPowerControl.MouseUpEventHandler = (sender, e) =>
+            {
+                string msg = btnPowerControl.IsSelected ? "纭畾鍏抽棴鎬诲紑鍏冲悧锛�" : "纭畾鎵撳紑鎬诲紑鍏冲悧锛�";
+                new PublicAssmebly().TipOptionMsg(StringId.Tip, msg, () =>
+                {
+                    btnPowerControl.IsSelected = !btnPowerControl.IsSelected;
+
+                    new System.Threading.Thread(() =>
+                    {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add(FunctionAttributeKey.OnOff, btnPowerControl.IsSelected ? "on" : "off");
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+            };
 
 
-            var btnWorkSceneControl = new Button()
+            btnWorkSceneControl = new Button()
             {
                 Gravity = Gravity.CenterVertical,
                 X = Application.GetRealWidth(249),
                 Width = Application.GetRealWidth(38),
                 Height = Application.GetRealWidth(38),
-                UnSelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/SceneSleepIcon2.png",
+                UnSelectedImagePath = "FunctionIcon/Acst/grey/SceneSleepIcon2.png",
                 SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/SceneSleepIcon2.png",
                 TextAlignment = TextAlignment.Center,
+                IsSelected = function.trait_on_off.state == "on"
             };
             bottomView.AddChidren(btnWorkSceneControl);
+
+
+            btnWorkSceneControl.MouseUpEventHandler = (sender2, e2) =>
+            {
+                if (function.trait_on_off.state == "off")
+                {
+                    return;
+                }
+                Dialog dialog = new Dialog();
+
+                var dialogView = new FrameLayout();
+                dialog.AddChidren(dialogView);
+                dialogView.MouseUpEventHandler = (sender, e) => {
+                    dialog.Close();
+                };
+
+                var dialogContentView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(194),
+                    Y = Application.GetRealHeight(419),
+                    Width = Application.GetRealWidth(148),
+                    Height = Application.GetRealHeight(191),
+                    BackgroundImagePath = "FunctionIcon/Acst/BgChooseScene.png",
+                };
+                dialogView.AddChidren(dialogContentView);
+
+                var titleView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = Application.GetRealHeight(3),
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(titleView);
+                var btnTitleText = new Button()
+                {
+                    X = Application.GetRealWidth(16),
+                    Width = Application.GetRealWidth(100),
+                    TextID = StringId.SelectScene,
+                    TextSize = 16,
+                    TextColor = CSS.CSS_Color.FirstLevelTitleColor,
+                    IsBold = true,
+                    TextAlignment = TextAlignment.CenterLeft,
+                };
+                titleView.AddChidren(btnTitleText);
+
+                #region 鍦ㄥ
+                var atHomeView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = titleView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(atHomeView);
+                atHomeView.AddChidren(new Button
+                {
+                    Width = Application.GetRealWidth(112),
+                    Gravity = Gravity.CenterHorizontal,
+                    Height = 1,
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton atHomeIconButton = new IconButton("FunctionIcon/Acst/grey/SceneAtHome.png", $"FunctionIcon/Acst/{imageFolder}/SceneAtHome.png",
+                    Language.StringByID(StringId.AtHome), curColor, function.GetAttrState(AcstParent_AttrEnum.scene.ToString()) == AcstParent_Attr_SceneValueEnum.at_home.ToString());
+                atHomeIconButton.Click(() => {
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/SceneAtHome2.png";
+                    dialog.Close();
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add(AcstParent_AttrEnum.scene.ToString(), AcstParent_Attr_SceneValueEnum.at_home.ToString());
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+                atHomeView.AddChidren(atHomeIconButton);
+                #endregion
+
+
+                #region 绂诲
+                var awayHomeView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = atHomeView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(awayHomeView);
+                awayHomeView.AddChidren(new Button
+                {
+                    Width = Application.GetRealWidth(112),
+                    Gravity = Gravity.CenterHorizontal,
+                    Height = 1,
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton awayHomeIconButton = new IconButton("FunctionIcon/Acst/grey/SceneAwayHomeIcon.png", $"FunctionIcon/Acst/{imageFolder}/SceneAwayHomeIcon.png",
+                    Language.StringByID(StringId.AwayHome), curColor, function.GetAttrState(AcstParent_AttrEnum.scene.ToString()) == AcstParent_Attr_SceneValueEnum.leave_home.ToString());
+                awayHomeIconButton.Click(() => {
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/SceneAwayHomeIcon2.png";
+                    dialog.Close();
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add("scene", "leave_home");
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+                awayHomeView.AddChidren(awayHomeIconButton);
+                #endregion 
+
+                #region 鐫$湢
+                var sleepView = new FrameLayout()
+                {
+                    X = Application.GetRealWidth(2),
+                    Y = awayHomeView.Bottom,
+                    Width = Application.GetRealWidth(144),
+                    Height = Application.GetRealHeight(44),
+                };
+                dialogContentView.AddChidren(sleepView);
+                sleepView.AddChidren(new Button
+                {
+                    Height = 1,
+                    Gravity = Gravity.CenterHorizontal,
+                    Width = Application.GetRealWidth(112),
+                    BackgroundColor = CSS.CSS_Color.DividingLineColor,
+                });
+                IconButton sleepIconButton = new IconButton("FunctionIcon/Acst/grey/SceneSleepIcon.png", $"FunctionIcon/Acst/{imageFolder}/SceneSleepIcon.png",
+                    Language.StringByID(StringId.Sleep), curColor, function.GetAttrState(AcstParent_AttrEnum.scene.ToString()) == AcstParent_Attr_SceneValueEnum.sleep.ToString());
+                sleepIconButton.Click(() => {
+                    btnModeControl.SelectedImagePath = $"FunctionIcon/Acst/{imageFolder}/SceneSleepIcon2.png";
+                    dialog.Close();
+                    new System.Threading.Thread(() => {
+                        Dictionary<string, string> d = new Dictionary<string, string>();
+                        d.Add("scene", "sleep");
+                        Control.Ins.SendWriteCommand(function, d);
+                    })
+                    { IsBackground = true }.Start();
+                });
+                sleepView.AddChidren(sleepIconButton);
+                #endregion 
+                dialog.Show();
+            };
 
 
 
@@ -591,12 +1050,9 @@
             #endregion
 
 
-
-
-
-
-
             InitGetWeatherAction();
+
+            Control.Ins.SendReadCommand(function);
 
         }
 
@@ -613,15 +1069,22 @@
         private Button btnValue;
         private Button btnText;
         public string Tag;
+        public string unitString;
 
-        public SensorDiyView(HorizontalScrolViewLayout view,uint color,string value,string text)
+        public SensorDiyView(HorizontalScrolViewLayout view,uint color,string value,string unitStr,string text,int setWidth = 60)
         {
+            unitString = unitStr;
+            if (string.IsNullOrEmpty(value))
+            {
+                value = "--";
+            }
+
             ///榛樿Tag 涓轰紶杩涙潵鐨凾ext
             Tag = text;
 
             contentView = new FrameLayout()
             {
-                Width = Application.GetRealWidth(60),
+                Width = Application.GetRealWidth(setWidth),
                 Height = Application.GetRealHeight(72),
             };
             view.AddChidren(contentView);
@@ -633,7 +1096,7 @@
                 TextAlignment = TextAlignment.Center,
                 TextColor = color,
                 TextSize = 20,
-                Text = value,
+                Text = value + unitString,
             };
             contentView.AddChidren(btnValue);
 
@@ -651,7 +1114,7 @@
 
         public void UpdateValue(string value)
         {
-            btnText.Text = value;
+            btnValue.Text = value + unitString;
         }
     }
 
@@ -663,9 +1126,12 @@
         public TextButton btnSubTempValues;
         public TextButton btnSubHumidityValues;
         public Button btnSubPower;
+        public string Tag;
 
         public AcstSubControlView(Function sub, HorizontalScrolViewLayout subFunctionListView,string imageFolder)
         {
+            Tag = sub.sid;
+
             var subFunctionView = new FrameLayout()
             {
                 Width = Application.GetRealWidth(177),
@@ -682,7 +1148,7 @@
                 TextAlignment = TextAlignment.CenterLeft,
                 TextColor = 0xFF1b3053,
                 TextSize = 13,
-                Text = sub.GetRoomListName(),
+                Text = sub.name,
             };
             subFunctionView.AddChidren(btnRoomInfo);
 
@@ -701,7 +1167,7 @@
                 X = btnSubTempIcon.Right,
                 Y = Application.GetRealHeight(45 + 11),
                 Height = Application.GetRealHeight(14),
-                Width = Application.GetRealWidth(22),
+                Width = Application.GetRealWidth(35),
                 TextColor = 0xFF1b3035,
                 TextSize = 10,
                 Text = sub.GetAttrState(AcstSub_AttrEnum.room_temp.ToString()) + "掳C",
@@ -724,7 +1190,7 @@
                 X = btnSubHumidityIcon.Right,
                 Y = Application.GetRealHeight(45 + 11),
                 Height = Application.GetRealHeight(14),
-                Width = Application.GetRealWidth(22),
+                Width = Application.GetRealWidth(35),
                 TextColor = 0xFF1b3053,
                 TextSize = 10,
                 Text = sub.GetAttrState(AcstSub_AttrEnum.room_humidity.ToString()) + "%",
@@ -743,7 +1209,29 @@
                 TextAlignment = TextAlignment.Center,
             };
             subFunctionView.AddChidren(btnSubPower);
+            btnSubPower.MouseUpEventHandler = (sender, e) => {
+                btnSubPower.IsSelected = !btnSubPower.IsSelected;
+                string onoff = btnSubPower.IsSelected ? "on" : "off";
+                Dictionary<string, string> d = new Dictionary<string, string>();
+                d.Add(FunctionAttributeKey.OnOff, onoff);
+                Control.Ins.SendWriteCommand(sub, d);
+            };
 
+            EventHandler<MouseEventArgs> eventHandler = (sender, e) => {
+                var page = new AcstSubPage(sub,imageFolder);
+                MainPage.BasePageView.AddChidren(page);
+                page.LoadPage(()=> {
+                    btnRoomInfo.Text = sub.name;
+                });
+                MainPage.BasePageView.PageIndex = MainPage.BasePageView.ChildrenCount - 1;
+            };
+
+            btnRoomInfo.MouseUpEventHandler = eventHandler;
+            btnSubHumidityIcon.MouseUpEventHandler = eventHandler;
+            btnSubHumidityValues.MouseUpEventHandler = eventHandler;
+            btnSubTempIcon.MouseUpEventHandler = eventHandler;
+            btnSubTempValues.MouseUpEventHandler = eventHandler;
+            subFunctionView.MouseUpEventHandler = eventHandler;
         }
     }
 
@@ -765,7 +1253,7 @@
             btnIcon = new Button()
             {
                 X = Application.GetRealWidth(16),
-                Gravity = Gravity.CenterHorizontal,
+                Gravity = Gravity.CenterVertical,
                 Width = Application.GetRealWidth(24),
                 Height = Application.GetRealWidth(24),
                 UnSelectedImagePath = iconPath,
@@ -776,7 +1264,7 @@
 
             btnText = new Button()
             {
-                X = btnIcon.Right + Application.GetRealWidth(12),
+                X = Application.GetRealWidth(52),
                 Width = Application.GetRealWidth(90),
                 TextAlignment = TextAlignment.CenterLeft,
                 Text = text,
@@ -789,5 +1277,19 @@
 
             
         }
+
+
+        public void Click(Action action)
+        {
+            view.MouseUpEventHandler = (sender, e) => {
+                action();
+            };
+            btnText.MouseUpEventHandler = (sender, e) => {
+                action();
+            };
+            btnIcon.MouseUpEventHandler = (sender, e) => {
+                action();
+            };
+        }
     }
 }

--
Gitblit v1.8.0