From d76b0e40e5bb127fd33aa1f7842447a1df0628d5 Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期日, 30 七月 2023 22:16:34 +0800
Subject: [PATCH] Update PublicAssmeblyBLL.cs

---
 HDL_ON/UI/UI2/3-Intelligence/Automation/InpOrOutLogicMethod.cs |  234 ++++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 219 insertions(+), 15 deletions(-)

diff --git a/HDL_ON/UI/UI2/3-Intelligence/Automation/InpOrOutLogicMethod.cs b/HDL_ON/UI/UI2/3-Intelligence/Automation/InpOrOutLogicMethod.cs
index eb3fb05..1d787cb 100644
--- a/HDL_ON/UI/UI2/3-Intelligence/Automation/InpOrOutLogicMethod.cs
+++ b/HDL_ON/UI/UI2/3-Intelligence/Automation/InpOrOutLogicMethod.cs
@@ -460,14 +460,26 @@
                                     break;
                                 case SPK.IpCam_Imou:
                                     {
-                                        if (inputCondition.identifier == "door_caipcam_region_alram_eventll_cloud_event")
+                                        if (inputCondition.identifier == "ipcam_region_alram_event")
                                         {
                                             inputView.btnState.Text = Language.StringByID(StringId.quyuruqingaojing);
                                         }
 
                                     }
                                     break;
-                                case SPK.sensorPirhold:
+                                case SPK.Ev_Ipcam:
+                                    if (inputCondition.identifier == "motiondetect_event")
+                                    {
+                                        inputView.btnState.Text = Language.StringByID(StringId.shi);
+                                    }
+                                    break;
+                                case SPK.Peephole:
+                                    if (inputCondition.identifier == "pir_event")
+                                    {
+                                        inputView.btnState.Text = Language.StringByID(StringId.shi);
+                                    }
+                                    break;
+                                case SPK.SensorPirHold:
                                     {
                                         string value = this.GetKeyValue("people_status", dicList);
                                         if (string.IsNullOrEmpty(value))
@@ -989,6 +1001,7 @@
                 switch (outputTarget.target_type)
                 {
                     case "1":
+                    case "5":
                         {
                             //鐢╯id鎵惧埌璁惧锛�
                             var device = LogicMethod.Current.GetDevice(outputTarget.sid);
@@ -1002,7 +1015,11 @@
                             //鍖哄埆涓嶅悓璁惧锛屾樉绀轰笉鍚岃澶囩姸鎬�
                             switch (device.spk)
                             {
-
+                               
+                                case SPK.CommonSeries:
+                                    targetView.btnIcon.UnSelectedImagePath = "FunctionIcon/Icon/groupControl.png";
+                                    stateStr = GetKeyValue("on_off", dicList) == "on" ? Language.StringByID(StringId.onLogic) : Language.StringByID(StringId.offLogic);
+                                    break;
                                 //鎻掑骇(鏈塙SB)
                                 case SPK.PanelSocket:
                                     {
@@ -1040,11 +1057,14 @@
                                         }
                                     }
                                     break;
+                               
+                              
                                 case SPK.LightRGB:
                                 case SPK.LightRGBW:
                                 case SPK.LightCCT:
                                 case SPK.LightDimming:
                                     {
+                                        
                                         string on_off = GetKeyValue("on_off", dicList);
                                         string brightness = GetKeyValue("brightness", dicList);
                                         if (on_off == "on" && brightness != "")
@@ -1071,9 +1091,83 @@
                                                 stateStr += "," +GetKeyValue("cct", dicList) + "k";
                                             }
                                         }
+                                        if (device.spk == SPK.LightRGB)
+                                        {
+                                            string rgb = GetKeyValue("rgb", dicList);
+                                            if (!string.IsNullOrEmpty(rgb) && rgb.Length > 6)
+                                            {
+                                                targetView.btnStateColor.Visible = true;
+                                                targetView.btnStateColor.BackgroundColor = new LogicView.RGBColorView().GetBackgroundColor(rgb);
+                                            }
+                                        }
+                                        if (device.spk == SPK.LightRGBW)
+                                        {
+                                            string rgb = GetKeyValue("rgbw", dicList);
+                                            if (!string.IsNullOrEmpty(rgb) && rgb.Length > 6)
+                                            {
+                                                targetView.btnStateColor.Visible = true;
+                                                targetView.btnStateColor.BackgroundColor = new LogicView.RGBColorView().GetBackgroundColor(rgb);
+                                            }
+                                        }
 
                                     }
                                     break;
+                                case SPK.GroupControl: //缇ゆ帶
+                                    {
+                                        targetView.btnIcon.UnSelectedImagePath = "FunctionIcon/Icon/groupControl.png";
+                                        string on_off = GetKeyValue("on_off", dicList);
+                                        string brightness = GetKeyValue("brightness", dicList);
+                                        string cct = GetKeyValue(FunctionAttributeKey.CCT, dicList);
+                                        //鑷姩鍖栫粍鎺� 鐐僵鍔熻兘
+                                        //string colorful = GetKeyValue(FunctionAttributeKey.Colorful, dicList);
+                                        string rgb = GetKeyValue("rgb", dicList);
+
+
+                                        if (on_off == "on" && brightness != "")
+                                        {
+                                            stateStr = Language.StringByID(StringId.onLogic) + brightness + "%";
+                                        }
+                                        else if (on_off == "on")
+                                        {
+                                            stateStr = Language.StringByID(StringId.onLogic);
+                                        }
+                                        else if (on_off == "off")
+                                        {
+                                            stateStr = Language.StringByID(StringId.offLogic);
+                                        }
+                                        else if (brightness != "")
+                                        {
+                                            stateStr = brightness + "%";
+                                        }
+                                        //鑹叉俯杩欎釜灞炴�ф墠鏈夋晥
+                                        if (!string.IsNullOrEmpty(cct))
+                                        {
+                                            stateStr += "," + Language.StringByID(StringId.ColorTemperature) + cct + "k";
+                                        }
+
+                                        //if (!string.IsNullOrEmpty(colorful))
+                                        //{
+                                        //    stateStr += "," + Language.StringByID(StringId.ColorfulFunction);
+                                        //    if (colorful == "on")
+                                        //    {
+                                        //        stateStr += Language.StringByID(StringId.onLogic);
+                                        //    }
+                                        //    else if (colorful == "off")
+                                        //    {
+                                        //        stateStr += Language.StringByID(StringId.offLogic);
+                                        //    }
+                                        //}
+
+                                        if (!string.IsNullOrEmpty(rgb) && rgb.Length > 6)
+                                        {
+                                            targetView.btnStateColor.Visible = true;
+                                            targetView.btnStateColor.BackgroundColor = new LogicView.RGBColorView().GetBackgroundColor(rgb);
+                                        }
+
+
+                                    }
+                                    break;
+
                                 case SPK.CurtainSwitch:
                                     {
                                         foreach (var dic in dicList)
@@ -1170,8 +1264,8 @@
 
                                         if (set_temp != "")
                                         {
-
-                                            stateStr += set_temp + "鈩�,";
+                                            string unit =GetTemperatureUnit(device);
+                                            stateStr += set_temp + unit + ",";
                                         }
 
                                         if (mode != "")
@@ -1268,8 +1362,8 @@
                                         }
                                         if (set_temp != "")
                                         {
-
-                                            stateStr += set_temp + "鈩�,";
+                                            string unit = GetTemperatureUnit(device);
+                                            stateStr += set_temp + unit + ",";
                                         }
                                         if (mode != "")
                                         {
@@ -1437,7 +1531,10 @@
                         break;
                 }
 
-                if (outputTarget.target_type == "1" || outputTarget.target_type == "3")
+                if (outputTarget.target_type == "1"
+                    || outputTarget.target_type == "3"
+                    || outputTarget.target_type == "5"
+                    )
                 {
                     targetView.btnState.Text = this.GetTimeText(outputTarget.delay) + stateStr;
                 }
@@ -1467,6 +1564,7 @@
                     switch (button.Name)
                     {
                         case "1":
+                        case "5":
                             {
                                 //鐢╯id鎵惧埌璁惧锛�
                                 var device = LogicMethod.Current.GetDevice(outputTarget.sid);
@@ -1503,7 +1601,8 @@
                     this.Delayed(thisView, outputTarget.delay, (value) =>
                      {
                          outputTarget.delay = value.ToString();
-                         if (outputTarget.target_type == "1")
+                         if (outputTarget.target_type == "1"
+                         || outputTarget.target_type == "5")
                          {
                              targetView.btnState.Text = this.GetTimeText(outputTarget.delay) + stateStr;
                          }
@@ -1529,8 +1628,9 @@
         /// <param name="button1">鏄剧ずBtn</param>
         /// <param name="button2">鏄剧ずBtn</param>
         /// <param name="button3">鏄剧ずBtn</param>
-        /// <param name="button4">鏄剧ずBtn</param> 
-        public void EditDeviceState(Entity.Function device, List<Dictionary<string, string>> dicList, Button button1, Button button2, Button button3, Button button4)
+        /// <param name="button4">鏄剧ずBtn</param>
+        /// <param name="attribute">灞炴�х储寮�</param>
+        public void EditDeviceState(Entity.Function device, List<Dictionary<string, string>> dicList, Button button1, Button button2, Button button3, Button button4, string attribute)
         {
             switch (device.spk)
             {
@@ -1614,9 +1714,92 @@
                                         button3.Text = value + "k";
                                     }
                                     break;
+                                case "rgb":
+                                case "rgbw":
+                                    {
+                                        if (button3 == null)
+                                        {
+                                            //鎬曡皟璇曡蒋浠朵贡涓婁笢瑗垮鑷存姏寮傚父
+                                            break;
+                                        }
+                                        if (!string.IsNullOrEmpty(value) && value.Length > 6)
+                                        {
+                                            button3.BackgroundColor = new LogicView.RGBColorView().GetBackgroundColor(value);
+                                            button3.Tag = value;
+                                        }
+                                    }
+                                    break;
+
                             }
 
                         }
+                    }
+                    break;
+                case SPK.GroupControl://缇ゆ帶
+                    {
+                        foreach (var dic in dicList)
+                        {
+                            string key = dic["key"];
+                            if (key != attribute)
+                            {
+                                continue;
+                            }
+                            string value = dic["value"];
+                            switch (key)
+                            {
+                                case "on_off":
+                                case "colorful":
+                                    {
+                                        if (value == "on")
+                                        {
+                                            button1.Text = Language.StringByID(StringId.onLogic);
+                                        }
+                                        else
+                                        {
+                                            button1.Text = Language.StringByID(StringId.offLogic);
+                                        }
+                                    }
+                                    break;
+                                case "brightness":
+                                    {
+                                        if (button1 == null)
+                                        {
+                                            //鎬曡皟璇曡蒋浠朵贡涓婁笢瑗垮鑷存姏寮傚父
+                                            break;
+                                        }
+                                        button1.Text = value + "%";
+                                    }
+                                    break;
+                                case "cct":
+                                    {
+                                        if (button1 == null)
+                                        {
+                                            //鎬曡皟璇曡蒋浠朵贡涓婁笢瑗垮鑷存姏寮傚父
+                                            break;
+                                        }
+                                        button1.Text = value + "k";
+                                    }
+                                    break;
+                                case "rgb":
+                                    {
+                                        if (button1 == null)
+                                        {
+                                            //鎬曡皟璇曡蒋浠朵贡涓婁笢瑗垮鑷存姏寮傚父
+                                            break;
+                                        }
+                                        if (!string.IsNullOrEmpty(value) && value.Length > 6)
+                                        {
+                                            button1.BackgroundColor = new LogicView.RGBColorView().GetBackgroundColor(value);
+                                            button1.Tag = value;
+                                        }
+                                    }
+                                    break;
+
+
+
+                            }
+                        }
+
                     }
                     break;
                 case SPK.CurtainSwitch:
@@ -1757,7 +1940,7 @@
                                             //鎬曡皟璇曡蒋浠朵贡涓婁笢瑗垮鑷存姏寮傚父
                                             break;
                                         }
-                                        button2.Text = value + "鈩�";
+                                        button2.Text = value + GetTemperatureUnit(device); ;
                                     }
                                     break;
                                 case "mode":
@@ -1870,7 +2053,7 @@
                                             //鎬曡皟璇曡蒋浠朵贡涓婁笢瑗垮鑷存姏寮傚父
                                             break;
                                         }
-                                        button2.Text = value + "鈩�";
+                                        button2.Text = value + GetTemperatureUnit(device); ;
                                     }
                                     break;
                                 case "mode":
@@ -2005,7 +2188,7 @@
                         }
                     }
                     break;
-              
+
                 case SPK.SensorGas:
                 case SPK.SensorSmoke:
                     {
@@ -2074,7 +2257,7 @@
                         }
                     }
                     break;
-                case SPK.sensorPirhold:
+                case SPK.SensorPirHold:
                     {
                         foreach (var dic in dicList)
                         {
@@ -2232,6 +2415,8 @@
                         button1.Tag = tag;
                     }
                     break;
+               
+
                 case SPK.MusicStandard:
                 case SPK.AvMusic:
                     {
@@ -2322,6 +2507,25 @@
             return dicList[0]["value"].ToString();
         }
         /// <summary>
+        /// 鑾峰彇娓╁害鍗曚綅
+        /// </summary>
+        /// <param name="device"></param>
+        /// <returns></returns>
+        public string GetTemperatureUnit(Entity.Function device)
+        {
+            string unit = string.Empty;
+            if (device.GetAttribute("temperature_type") != null)
+            {
+                unit = device.GetAttribute("temperature_type").unit;
+            }
+            if (string.IsNullOrEmpty(unit))
+            {
+                //璋冭瘯杞欢鏈夌┖鑳戒笂浼犱负绌�
+                unit = "鈩�";
+            }
+            return unit;
+        }
+        /// <summary>
         ///鑾峰彇鑷姩鍖栧悕绉�
         /// </summary>
         /// <returns> 鏂板缓鑷姩鍖栧懡鍚嶈鍒�</returns>

--
Gitblit v1.8.0