From 5727cf0b9b54da0a191dd1e23cb5abf21320fbff Mon Sep 17 00:00:00 2001
From: 黄学彪 <hxb@hdlchina.com.cn>
Date: 星期一, 25 十一月 2019 10:34:17 +0800
Subject: [PATCH] IOS使用新的项目名称

---
 ZigbeeApp/Shared/Phone/UserCenter/Residence/EditorRoomInforForm.cs |  263 +++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 248 insertions(+), 15 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Residence/EditorRoomInforForm.cs b/ZigbeeApp/Shared/Phone/UserCenter/Residence/EditorRoomInforForm.cs
index 37409c4..a737171 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/Residence/EditorRoomInforForm.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Residence/EditorRoomInforForm.cs
@@ -12,6 +12,10 @@
         #region 鈻� 鍙橀噺澹版槑___________________________
 
         /// <summary>
+        /// 缁撴潫缂栬緫鍚嶇О鐨勪簨浠�
+        /// </summary>
+        public Action<string> FinishEditorEvent = null;
+        /// <summary>
         /// 鍒楄〃鎺т欢
         /// </summary>
         private VerticalListControl listview = null;
@@ -82,19 +86,23 @@
             //搴曠嚎
             txtRoomName.AddBottomLine();
 
-            //銆愭墍灞炴ゼ灞傘��
-            var btnBelone = new FrameCaptionViewControl(Language.StringByID(R.MyInternationalizationString.uBelongeFloor), Common.Config.Instance.Home.FloorDics[this.cloneRoom.FloorId], this.listview.rowSpace / 2);
-            listview.AddChidren(btnBelone);
-            btnBelone.InitControl();
-            //鍙崇澶�
-            btnBelone.AddRightArrow();
-            //搴曠嚎
-            btnBelone.AddBottomLine();
-            btnBelone.ButtonClickEvent += (sender, e) =>
+            //璇PP涓烘湁妤煎眰鐨勬ā寮忔墠寮�鍚繖涓彍鍗�
+            if (string.IsNullOrEmpty(this.cloneRoom.FloorId) == false)
             {
-                //妤煎眰閫夋嫨
-                this.ShowSelectFloor(btnBelone);
-            };
+                //銆愭墍灞炴ゼ灞傘��
+                var btnBelone = new FrameCaptionViewControl(Language.StringByID(R.MyInternationalizationString.uBelongeFloor), Common.Config.Instance.Home.FloorDics[this.cloneRoom.FloorId], this.listview.rowSpace / 2);
+                listview.AddChidren(btnBelone);
+                btnBelone.InitControl();
+                //鍙崇澶�
+                btnBelone.AddRightArrow();
+                //搴曠嚎
+                btnBelone.AddBottomLine();
+                btnBelone.ButtonClickEvent += (sender, e) =>
+                {
+                    //妤煎眰閫夋嫨
+                    this.ShowSelectFloor(btnBelone);
+                };
+            }
 
             //銆愭俯搴︺��
             var rowTemperature = new FrameRowControl(this.listview.rowSpace / 2);
@@ -107,7 +115,14 @@
             rowTemperature.AddBottomLine();
             rowTemperature.ButtonClickEvent += (sender, e) =>
             {
+                //鏄剧ず娓╁害浼犳劅鍣ㄥ垪琛�
+                this.ShowTemperatrueDevice(btnTemper);
             };
+            if (string.IsNullOrEmpty(cloneRoom.TemperatrueDevice) == false)
+            {
+                //鑾峰彇娓╁害
+                this.GetTemperatrueValue(btnTemper, cloneRoom.TemperatrueDevice);
+            }
 
             //銆愭箍搴︺��
             var rowHumidity = new FrameRowControl(this.listview.rowSpace / 2);
@@ -120,7 +135,14 @@
             rowHumidity.AddBottomLine();
             rowHumidity.ButtonClickEvent += (sender, e) =>
             {
+                //鏄剧ず婀垮害浼犳劅鍣ㄥ垪琛�
+                this.ShowHumidityDevice(btnHumi);
             };
+            if (string.IsNullOrEmpty(cloneRoom.HumidityDevice) == false)
+            {
+                //鑾峰彇婀垮害
+                this.GetHumidityValue(btnHumi, cloneRoom.HumidityDevice);
+            }
 
             //鍒濆鍖栨甯冨畬鎴�
             tableContr.FinishInitControl(bodyFrameLayout, this.listview);
@@ -138,6 +160,8 @@
                     return;
                 }
                 editorRoom.Save();
+
+                FinishEditorEvent?.Invoke(this.cloneRoom.Name);
                 this.CloseForm();
             };
         }
@@ -180,6 +204,200 @@
 
         #endregion
 
+        #region 鈻� 娓╁害浼犳劅鍣ㄧ浉鍏砡____________________
+
+        /// <summary>
+        /// 鏄剧ず娓╁害浼犳劅鍣ㄥ垪琛�
+        /// </summary>
+        /// <param name="btnTemper"></param>
+        private void ShowTemperatrueDevice(NormalViewControl btnTemper)
+        {
+            var listDevice = new List<ZigBee.Device.CommonDevice>();
+            foreach (var device in Common.LocalDevice.Current.listAllDevice)
+            {
+                //鑾峰彇娓╁害浼犳劅鍣�
+                if (device is ZigBee.Device.TemperatureSensor && ((ZigBee.Device.TemperatureSensor)device).SensorDiv == 1)
+                {
+                    listDevice.Add(device);
+                }
+            }
+            var listSelect = new List<string>() { cloneRoom.TemperatrueDevice };
+            var form = new SelectDeviceForm();
+            form.AddForm(listDevice, listSelect, true, true);
+            form.ActionSelectDevice += (list) =>
+            {
+                if (list.Count == 0)
+                {
+                    cloneRoom.TemperatrueDevice = string.Empty;
+                    btnTemper.Text = Language.StringByID(R.MyInternationalizationString.uNothing);
+                    return;
+                }
+                cloneRoom.TemperatrueDevice = Common.LocalDevice.Current.GetDeviceMainKeys(list[0]);
+                //鑾峰彇娓╁害鍊�
+                this.GetTemperatrueValue(btnTemper, cloneRoom.TemperatrueDevice);
+            };
+        }
+
+        /// <summary>
+        /// 鑾峰彇娓╁害鍊�
+        /// </summary>
+        /// <param name="btnHumi"></param>
+        /// <param name="deviceKey"></param>
+        private void GetTemperatrueValue(NormalViewControl btnTemper, string deviceKey)
+        {
+            var device = Common.LocalDevice.Current.GetDevice(deviceKey);
+            if (device == null)
+            {
+                return;
+            }
+            //鑾峰彇涓�...
+            btnTemper.Text = Language.StringByID(R.MyInternationalizationString.uGetting);
+
+            HdlDeviceAttributeLogic.Current.RemoveEvent("TemperatrueDevice");
+            HdlDeviceAttributeLogic.Current.AddAttributeEvent("TemperatrueDevice", "DeviceStatusReport", (Action<ZigBee.Device.CommonDevice>)((report) =>
+            {
+                string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(report);
+                if (cloneRoom.TemperatrueDevice != mainKeys || btnTemper == null)
+                {
+                    return;
+                }
+                //绉婚櫎鎺変簨浠�
+                HdlDeviceAttributeLogic.Current.RemoveEvent("TemperatrueDevice");
+
+                foreach (var data in report.DeviceStatusReport.AttriBute)
+                {
+                    if (data.AttributeId == (int)ZigBee.Device.AttriButeId.MeasuredValue)
+                    {
+                        if (data.AttriButeData == 0)
+                        {
+                            //0鈩�
+                            btnTemper.Text = "0.0鈩�";
+                        }
+                        else if (data.AttriButeData > 32767)
+                        {
+                            //璐熸暟(鐗规畩澶勭悊)
+                            string strValue = (data.AttriButeData - 65536).ToString();
+                            //灏忔暟鐐归渶瑕佷竴浣�
+                            strValue = strValue.Substring(0, strValue.Length - 1);
+                            btnTemper.Text = strValue.Insert(strValue.Length - 1, ".") + "鈩�";
+                        }
+                        else
+                        {
+                            //灏忔暟鐐归渶瑕佷竴浣�
+                            string strValue = data.AttriButeData.ToString();
+                            strValue = strValue.Substring(0, strValue.Length - 1);
+                            btnTemper.Text = strValue.Insert(strValue.Length - 1, ".") + "鈩�";
+                        }
+                    }
+                }
+            }));
+            //鍙戦�佽幏鍙栨俯搴︾殑鍛戒护
+            ((ZigBee.Device.TemperatureSensor)device).ReadTemperatureOrHumidity();
+        }
+
+        #endregion
+
+        #region 鈻� 婀垮害浼犳劅鍣ㄧ浉鍏砡____________________
+
+        /// <summary>
+        /// 鏄剧ず婀垮害浼犳劅鍣ㄥ垪琛�
+        /// </summary>
+        /// <param name="btnHumi"></param>
+        private void ShowHumidityDevice(NormalViewControl btnHumi)
+        {
+            var listDevice = new List<ZigBee.Device.CommonDevice>();
+            foreach (var device in Common.LocalDevice.Current.listAllDevice)
+            {
+                //鑾峰彇婀垮害浼犳劅鍣�
+                if (device is ZigBee.Device.TemperatureSensor && ((ZigBee.Device.TemperatureSensor)device).SensorDiv == 2)
+                {
+                    listDevice.Add(device);
+                }
+            }
+            var listSelect = new List<string>() { cloneRoom.HumidityDevice };
+            var form = new SelectDeviceForm();
+            form.AddForm(listDevice, listSelect, true, true);
+            form.ActionSelectDevice += (list) =>
+            {
+                if (list.Count == 0)
+                {
+                    cloneRoom.HumidityDevice = string.Empty;
+                    btnHumi.Text = Language.StringByID(R.MyInternationalizationString.uNothing);
+                    return;
+                }
+                cloneRoom.HumidityDevice = Common.LocalDevice.Current.GetDeviceMainKeys(list[0]);
+                //鑾峰彇婀垮害鍊�
+                this.GetHumidityValue(btnHumi, cloneRoom.HumidityDevice);
+            };
+        }
+
+        /// <summary>
+        /// 鑾峰彇婀垮害鍊�
+        /// </summary>
+        /// <param name="btnHumi"></param>
+        /// <param name="deviceKey"></param>
+        private void GetHumidityValue(NormalViewControl btnHumi, string deviceKey)
+        {
+            var device = Common.LocalDevice.Current.GetDevice(deviceKey);
+            if (device == null)
+            {
+                return;
+            }
+            //鑾峰彇涓�...
+            btnHumi.Text = Language.StringByID(R.MyInternationalizationString.uGetting);
+
+            HdlDeviceAttributeLogic.Current.RemoveEvent("HumidityDevice");
+            HdlDeviceAttributeLogic.Current.AddAttributeEvent("HumidityDevice", "DeviceStatusReport", (report) =>
+            {
+                string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(report);
+                if (cloneRoom.HumidityDevice != mainKeys || btnHumi == null)
+                {
+                    return;
+                }
+                //绉婚櫎鎺変簨浠�
+                HdlDeviceAttributeLogic.Current.RemoveEvent("HumidityDevice");
+                foreach (var data in report.DeviceStatusReport.AttriBute)
+                {
+                    if (data.AttributeId == (int)ZigBee.Device.AttriButeId.MeasuredValue)
+                    {
+                        if (data.AttriButeData == 0)
+                        {
+                            //0
+                            btnHumi.Text = "0.0%";
+                        }
+                        else
+                        {
+                            //灏忔暟鐐归渶瑕佷竴浣�(婀垮害娌℃湁璐熸暟)
+                            string strValue = data.AttriButeData.ToString();
+                            strValue = strValue.Substring(0, strValue.Length - 1);
+                            btnHumi.Text = strValue.Insert(strValue.Length - 1, ".") + "%";
+                        }
+                    }
+                }
+            });
+            //鍙戦�佽幏鍙栨箍搴︾殑鍛戒护
+            ((ZigBee.Device.TemperatureSensor)device).ReadTemperatureOrHumidity();
+        }
+
+        #endregion
+
+        #region 鈻� 鐣岄潰鍏抽棴___________________________
+
+        /// <summary>
+        /// 鐣岄潰鍏抽棴
+        /// </summary>
+        public override void CloseForm()
+        {
+            this.FinishEditorEvent = null;
+
+            HdlDeviceAttributeLogic.Current.RemoveEvent("TemperatrueDevice");
+            HdlDeviceAttributeLogic.Current.RemoveEvent("HumidityDevice");
+
+            base.CloseForm();
+        }
+
+        #endregion
+
         #region 鈻� 涓�鑸柟娉昣__________________________
 
         /// <summary>
@@ -194,11 +412,24 @@
                 this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uPleaseInputRoomName));
                 return false;
             }
-            if (Shared.Common.Room.Lists.Find((obj) => obj.Name == this.cloneRoom.Name && obj.Id != this.cloneRoom.Id) != null)
+            if (string.IsNullOrEmpty(this.cloneRoom.FloorId) == true)
             {
-                this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.HadSameRoom));
-                return false;
+                if (Shared.Common.Room.Lists.Find((obj) => obj.Name == this.cloneRoom.Name && obj.Id != this.cloneRoom.Id) != null)
+                {
+                    this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.HadSameRoom));
+                    return false;
+                }
             }
+            else
+            {
+                var listRoom = Common.Room.CurrentRoom.GetFloorSortRoom(this.cloneRoom.FloorId);
+                if (listRoom.Find((obj) => obj.Name == this.cloneRoom.Name && obj.Id != this.cloneRoom.Id) != null)
+                {
+                    this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.HadSameRoom));
+                    return false;
+                }
+            }
+
             if (cloneRoom.BackgroundImageType == 1 || cloneRoom.BackgroundImageType == 2)
             {
                 this.cloneRoom.MoveBackGroundIamageFileToDirectory(cloneRoom.BackgroundImage, cloneRoom.BackgroundImage);
@@ -207,6 +438,8 @@
 
             editorRoom.FloorId = cloneRoom.FloorId;
             editorRoom.Name = cloneRoom.Name;
+            editorRoom.HumidityDevice = cloneRoom.HumidityDevice;
+            editorRoom.TemperatrueDevice = cloneRoom.TemperatrueDevice;
             editorRoom.BackgroundImage = cloneRoom.BackgroundImage;
             editorRoom.BackgroundImageType = cloneRoom.BackgroundImageType;
             cloneRoom = null;

--
Gitblit v1.8.0