From f71e74b5f0d2716fbf05da016cdaa18d64e09f80 Mon Sep 17 00:00:00 2001
From: xm <1271024303@qq.com>
Date: 星期四, 31 十二月 2020 17:01:18 +0800
Subject: [PATCH] 又换完成最新门锁。空气质量传感器完成数据和基本配置功能。开发图表和自动化的同事可下载此代码

---
 ZigbeeApp/Shared/Phone/UserCenter/Residence/AddNewRoomForm.cs | 1211 ++++++++++++++++++++++++++++++++-------------------------
 1 files changed, 684 insertions(+), 527 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Residence/AddNewRoomForm.cs b/ZigbeeApp/Shared/Phone/UserCenter/Residence/AddNewRoomForm.cs
old mode 100755
new mode 100644
index c6e916c..dc8e022
--- a/ZigbeeApp/Shared/Phone/UserCenter/Residence/AddNewRoomForm.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Residence/AddNewRoomForm.cs
@@ -3,533 +3,690 @@
 using System.Text;
 
 namespace Shared.Phone.UserCenter.Residence
-{
+{
+  /// <summary>
+  /// 娣诲姞鏂版埧闂寸殑鐣岄潰
+  /// </summary>
+  public class AddNewRoomForm : EditorCommonForm
+  {
+    #region 鈻� 鍙橀噺澹版槑___________________________
+
     /// <summary>
-    /// 娣诲姞鏂版埧闂寸殑鐣岄潰
+    /// 瀹屾垚娣诲姞鎴块棿鐨勪簨浠�
     /// </summary>
-    public class AddNewRoomForm : EditorCommonForm
-    {
-        #region 鈻� 鍙橀噺澹版槑___________________________
-
-        /// <summary>
-        /// 瀹屾垚娣诲姞鎴块棿鐨勪簨浠�
-        /// </summary>
-        public Action FinishEditorEvent = null;
-        /// <summary>
-        /// 鍒楄〃鎺т欢
-        /// </summary>
-        private VerticalListControl listview = null;
-        /// <summary>
-        /// 妤煎眰涓婚敭
-        /// </summary>
-        private string floorKeys = string.Empty;
-        /// <summary>
-        /// 鏂版埧闂村璞�
-        /// </summary>
-        private Common.Room newRoom = null;
-
-        #endregion
-
-        #region 鈻� 鍒濆鍖朹____________________________
-
-        /// <summary>
-        /// 鐢婚潰鏄剧ず(搴曞眰浼氬浐瀹氳皟鐢ㄦ鏂规硶锛屽�熶互瀹屾垚鐢婚潰鍒涘缓)
-        /// </summary>
-        /// <param name="i_floorKeys">妤煎眰涓婚敭</param>
-        public void ShowForm(string i_floorKeys)
-        {
-            this.floorKeys = i_floorKeys;
-            //璁剧疆澶撮儴淇℃伅
-            base.SetTitleText(Language.StringByID(R.MyInternationalizationString.uCreatRoom));
-
-            //鍒濆鍖栦腑閮ㄤ俊鎭�
-            this.InitMiddleFrame();
-        }
-
-        /// <summary>
-        /// 鍒濆鍖栦腑閮ㄤ俊鎭�
-        /// </summary>
-        private void InitMiddleFrame()
-        {
-            //娓呯┖bodyFrame
-            this.ClearBodyFrame();
-
-            //鎴块棿鍥剧墖
-            var btnPic = new ImageView();
-            btnPic.Y = Application.GetRealHeight(60);
-            btnPic.Width = Application.GetMinRealAverage(887);
-            btnPic.Height = Application.GetMinRealAverage(444);
-            btnPic.Radius = (uint)Application.GetRealHeight(17);
-            btnPic.Gravity = Gravity.CenterHorizontal;
-            btnPic.ImagePath = "RoomIcon/0.JPG";
-            bodyFrameLayout.AddChidren(btnPic);
-            var btnShadow = new PicViewControl(916, 487);
-            btnShadow.Y = btnPic.Y;
-            btnShadow.Gravity = Gravity.CenterHorizontal;
-            btnShadow.UnSelectedImagePath = "Room/RoomShadow.png";
-            bodyFrameLayout.AddChidren(btnShadow);
-            btnShadow.MouseUpEventHandler += (sender, e) =>
-            {
-                //鎴块棿鍥剧墖閫夋嫨
-                this.RoomPictrueSelect(btnPic);
-            };
-
-            this.newRoom = new Common.Room();
-            newRoom.FloorId = this.floorKeys;
-            newRoom.BackgroundImage = btnPic.ImagePath;
-
-            //鍒濆鍖栨甯�
-            var tableContr = new InformationEditorControl();
-            this.listview = tableContr.InitControl(bodyFrameLayout, Language.StringByID(R.MyInternationalizationString.uInfoEditor), 562, 1175);
-
-            //娣诲姞鍏ㄩ儴鑿滃崟
-            this.AddAllMenuRow(tableContr, btnPic);
-        }
-
-        #endregion
-
-        #region 鈻� 娣诲姞鑿滃崟___________________________
-
-        /// <summary>
-        /// 娣诲姞鍏ㄩ儴鑿滃崟
-        /// </summary>
-        private void AddAllMenuRow(InformationEditorControl tableContr, ImageView btnPic)
-        {
-            //銆愭埧闂村悕绉般��
-            var txtRoomName = new FrameCaptionInputControl(Language.StringByID(R.MyInternationalizationString.uRoomName), string.Empty, this.listview.rowSpace / 2);
-            txtRoomName.txtInput.PlaceholderText = Language.StringByID(R.MyInternationalizationString.uPleaseInputRoomName);
-            listview.AddChidren(txtRoomName);
-            txtRoomName.InitControl();
-            //搴曠嚎
-            txtRoomName.AddBottomLine();
-
-            //璇PP涓烘湁妤煎眰鐨勬ā寮忔墠寮�鍚繖涓彍鍗�
-            if (floorKeys != string.Empty)
-            {
-                //銆愭墍灞炴ゼ灞傘��
-                var btnBelone = new FrameCaptionViewControl(Language.StringByID(R.MyInternationalizationString.uBelongeFloor), Common.Config.Instance.Home.FloorDics[this.floorKeys], 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);
-            listview.AddChidren(rowTemperature);
-            rowTemperature.AddLeftCaption(Language.StringByID(R.MyInternationalizationString.uTemperature), 600);
-            //鍙崇澶�
-            rowTemperature.AddRightArrow();
-            var btnTemper = rowTemperature.AddMostRightView(Language.StringByID(R.MyInternationalizationString.uNothing), 300);
-            //搴曠嚎
-            rowTemperature.AddBottomLine();
-            rowTemperature.ButtonClickEvent += (sender, e) =>
-            {
-                //鏄剧ず娓╁害浼犳劅鍣ㄥ垪琛�
-                this.ShowTemperatrueDevice(btnTemper);
-            };
-
-            //銆愭箍搴︺��
-            var rowHumidity = new FrameRowControl(this.listview.rowSpace / 2);
-            listview.AddChidren(rowHumidity);
-            rowHumidity.AddLeftCaption(Language.StringByID(R.MyInternationalizationString.uHumidity), 600);
-            //鍙崇澶�
-            rowHumidity.AddRightArrow();
-            var btnHumi = rowHumidity.AddMostRightView(Language.StringByID(R.MyInternationalizationString.uNothing), 300);
-            //搴曠嚎
-            rowHumidity.AddBottomLine();
-            rowHumidity.ButtonClickEvent += (sender, e) =>
-            {
-                //鏄剧ず婀垮害浼犳劅鍣ㄥ垪琛�
-                this.ShowHumidityDevice(btnHumi);
-            };
-
-            //鍒濆鍖栨甯冨畬鎴�
-            tableContr.FinishInitControl(bodyFrameLayout, this.listview);
-            tableContr = null;
-            //淇濆瓨
-            var btnFinish = new BottomClickButton();
-            btnFinish.TextID = R.MyInternationalizationString.uSave;
-            bodyFrameLayout.AddChidren(btnFinish);
-            btnFinish.ButtonClickEvent += (sender, e) =>
-            {
-                this.newRoom.Name = txtRoomName.Text;
-                //妫�娴嬭兘鍚︿繚瀛樻埧闂�
-                if (this.CheckCanSaveRoom() == false)
-                {
-                    return;
-                }
-                if (newRoom.BackgroundImageType == 1 || newRoom.BackgroundImageType == 2)
-                {
-                    //鐢熸垚鍥剧墖
-                    string picName = $"RoomIcon_{DateTime.Now.ToString("yyyyMMddHHmmss")}.png";
-                    string picFullName = System.IO.Path.Combine(Common.Config.Instance.FullPath, picName);
-                    Shared.IO.FileUtils.WriteFileByBytes(picFullName, btnPic.ImageBytes);
-                    newRoom.BackgroundImage = picName;
-                    //澶囦唤
-                    Phone.UserCenter.HdlAutoBackupLogic.AddOrEditorFile(picName);
-                }
-
-                newRoom.FloorId = this.floorKeys;
-                var result = newRoom.AddRoom(newRoom);
-                if (result == false)
-                {
-                    //鎻愮ず鐢ㄦ埛娣诲姞澶辫触
-                    this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.FAIL));
-                }
-                else
-                {
-                    this.FinishEditorEvent?.Invoke();
-
-                    this.CloseForm();
-                }
-            };
-        }
-
-        #endregion
-
-        #region 鈻� 妤煎眰閫夋嫨___________________________
-
-        /// <summary>
-        /// 妤煎眰閫夋嫨
-        /// </summary>
-        /// <param name="control"></param>
-        private void ShowSelectFloor(FrameCaptionViewControl control)
-        {
-            var dicFloor = Common.Room.CurrentRoom.GetFloorSortList();
-
-            var listKeys = new List<string>();
-            var listName = new List<string>();
-            int index = 0;
-            foreach (string keys in dicFloor.Keys)
-            {
-                listKeys.Add(keys);
-                listName.Add(dicFloor[keys]);
-                if (keys == this.floorKeys)
-                {
-                    index = listKeys.Count - 1;
-                }
-            }
-            PickerView.Show(listName, (value) =>
-             {
-                 control.txtView.Text = listName[value];
-                 //涓婚敭淇敼
-                 this.floorKeys = listKeys[value];
-             },
-            index,
-            Language.StringByID(R.MyInternationalizationString.uBelongeFloor),
-            Language.StringByID(R.MyInternationalizationString.uFinish),
-            Language.StringByID(R.MyInternationalizationString.uCancel));
-        }
-
-        #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>() { newRoom.TemperatrueDevice };
-            var form = new SelectDeviceForm();
-            form.AddForm(listDevice, listSelect, true, true);
-            form.ActionSelectDevice += (list) =>
-            {
-                if (list.Count == 0)
-                {
-                    newRoom.TemperatrueDevice = string.Empty;
-                    btnTemper.Text = Language.StringByID(R.MyInternationalizationString.uNothing);
-                    return;
-                }
-                newRoom.TemperatrueDevice = Common.LocalDevice.Current.GetDeviceMainKeys(list[0]);
-                //鑾峰彇娓╁害鍊�
-                this.GetTemperatrueValue(btnTemper, newRoom.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);
-
-            HdlGatewayReceiveLogic.Current.RemoveEvent("TemperatrueDevice");
-            HdlGatewayReceiveLogic.Current.AddAttributeEvent("TemperatrueDevice", ReceiveComandDiv.A璁惧灞炴�т笂鎶�, ((report) =>
-            {
-                string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(report);
-                if (newRoom.TemperatrueDevice != mainKeys || btnTemper == null)
-                {
-                    return;
-                }
-                //绉婚櫎鎺変簨浠�
-                HdlGatewayReceiveLogic.Current.RemoveEvent("TemperatrueDevice");
-
-                foreach (var data in report.DeviceStatusReport.AttriBute)
-                {
-                    if (data.AttributeId == (int)ZigBee.Device.AttriButeId.MeasuredValue)
-                    {
-                        HdlThreadLogic.Current.RunMain(() =>
-                        {
-                            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>() { newRoom.HumidityDevice };
-            var form = new SelectDeviceForm();
-            form.AddForm(listDevice, listSelect, true, true);
-            form.ActionSelectDevice += (list) =>
-            {
-                if (list.Count == 0)
-                {
-                    newRoom.HumidityDevice = string.Empty;
-                    btnHumi.Text = Language.StringByID(R.MyInternationalizationString.uNothing);
-                    return;
-                }
-                newRoom.HumidityDevice = Common.LocalDevice.Current.GetDeviceMainKeys(list[0]);
-                //鑾峰彇婀垮害鍊�
-                this.GetHumidityValue(btnHumi, newRoom.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);
-
-            HdlGatewayReceiveLogic.Current.RemoveEvent("HumidityDevice");
-            HdlGatewayReceiveLogic.Current.AddAttributeEvent("HumidityDevice", ReceiveComandDiv.A璁惧灞炴�т笂鎶�, (report) =>
-            {
-                string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(report);
-                if (newRoom.HumidityDevice != mainKeys || btnHumi == null)
-                {
-                    return;
-                }
-                //绉婚櫎鎺変簨浠�
-                HdlGatewayReceiveLogic.Current.RemoveEvent("HumidityDevice");
-                foreach (var data in report.DeviceStatusReport.AttriBute)
-                {
-                    if (data.AttributeId == (int)ZigBee.Device.AttriButeId.MeasuredValue)
-                    {
-                        HdlThreadLogic.Current.RunMain(() =>
-                        {
-                            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>
-        /// <param name="imageContr"></param>
-        private void RoomPictrueSelect(ImageView imageContr)
-        {
-            var menuContr = new BottomMenuSelectForm();
-            menuContr.AddForm(3);
-            //榛樿鍥惧簱
-            menuContr.AddMenu(Language.StringByID(R.MyInternationalizationString.LocalPicture), () =>
-            {
-                var localPic = new Phone.Device.Room.AddRoomSelectPicByLocal();
-                Shared.Phone.UserView.HomePage.Instance.AddChidren(localPic);
-                Shared.Phone.UserView.HomePage.Instance.PageIndex += 1;
-                localPic.Show();
-                localPic.action = (imgPath) =>
-                {
-                    if (string.IsNullOrEmpty(imgPath) == true)
-                    {
-                        return;
-                    }
-                    this.newRoom.BackgroundImageType = 0;
-                    this.newRoom.BackgroundImage = imgPath;
-                    imgPath = IO.FileUtils.GetImageFilePath(imgPath);
-                    imageContr.ImageBytes = IO.FileUtils.ReadFile(imgPath);
-                };
-            });
-            //鎷嶇収
-            menuContr.AddMenu(Language.StringByID(R.MyInternationalizationString.Photograph), () =>
-            {
-                //閫氳繃鐩告満鎷嶇収瑁佸壀
-                CropImage.TakePicture((imagePath) =>
-                {
-                    if (string.IsNullOrEmpty(imagePath) == true)
-                    {
-                        return;
-                    }
-                    this.newRoom.BackgroundImageType = 1;
-                    imageContr.ImageBytes = Shared.IO.FileUtils.ReadFile(imagePath);
-                    System.IO.File.Delete(imagePath);
-                }, "HdlPic", 2, 1);
-            });
-            //鎴戠殑鐩稿唽
-            menuContr.AddMenu(Language.StringByID(R.MyInternationalizationString.MyAblums), () =>
-            {
-                //浠庣浉鍐岄�夋嫨鍥剧墖瑁佸壀
-                CropImage.SelectPicture((imagePath) =>
-                {
-                    if (string.IsNullOrEmpty(imagePath) == true)
-                    {
-                        return;
-                    }
-                    this.newRoom.BackgroundImageType = 2;
-                    imageContr.ImageBytes = Shared.IO.FileUtils.ReadFile(imagePath);
-                    System.IO.File.Delete(imagePath);
-
-                }, "HdlPic", 2, 1);
-            });
-        }
-
-        #endregion
-
-        #region 鈻� 鐣岄潰鍏抽棴___________________________
-
-        /// <summary>
-        /// 鐣岄潰鍏抽棴
-        /// </summary>
-        public override void CloseFormBefore()
-        {
-            this.FinishEditorEvent = null;
-
-            HdlGatewayReceiveLogic.Current.RemoveEvent("TemperatrueDevice");
-            HdlGatewayReceiveLogic.Current.RemoveEvent("HumidityDevice");
-
-            base.CloseFormBefore();
-        }
-
-        #endregion
-
-        #region 鈻� 涓�鑸柟娉昣__________________________
-
-        /// <summary>
-        /// 妫�娴嬭兘鍚︿繚瀛樻埧闂�
-        /// </summary>
-        /// <returns></returns>
-        private bool CheckCanSaveRoom()
-        {
-            if (this.newRoom.Name == string.Empty)
-            {
-                //璇疯緭鍏ユ埧闂村悕绉�
-                this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uPleaseInputRoomName));
-                return false;
-            }
-            if (string.IsNullOrEmpty(this.floorKeys) == true)
-            {
-                if (Shared.Common.Room.Lists.Find((obj) => obj.Name == this.newRoom.Name && obj.Id != this.newRoom.Id) != null)
-                {
-                    this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uRoomNameIsExist));
-                    return false;
-                }
-            }
-            else
-            {
-                var listRoom = Common.Room.CurrentRoom.GetFloorSortRoom(this.floorKeys);
-                if (listRoom.Find((obj) => obj.Name == this.newRoom.Name && obj.Id != this.newRoom.Id) != null)
-                {
-                    this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uRoomNameIsExist));
-                    return false;
-                }
-            }
-
-            return true;
-        }
-
-        #endregion
-    }
+    public Action FinishEditorEvent = null;
+    /// <summary>
+    /// 鍒楄〃鎺т欢
+    /// </summary>
+    private FrameListControl listview = null;
+    /// <summary>
+    /// 妤煎眰涓婚敭
+    /// </summary>
+    private string floorKeys = string.Empty;
+    /// <summary>
+    /// 鏂版埧闂村璞�
+    /// </summary>
+    private Common.Room newRoom = null;
+
+    #endregion
+
+    #region 鈻� 鍒濆鍖朹____________________________
+
+    /// <summary>
+    /// 鐢婚潰鏄剧ず(搴曞眰浼氬浐瀹氳皟鐢ㄦ鏂规硶锛屽�熶互瀹屾垚鐢婚潰鍒涘缓)
+    /// </summary>
+    /// <param name="i_floorKeys">妤煎眰涓婚敭</param>
+    public void ShowForm(string i_floorKeys)
+    {
+      this.floorKeys = i_floorKeys;
+      //璁剧疆澶撮儴淇℃伅
+      base.SetTitleText(Language.StringByID(R.MyInternationalizationString.uCreatRoom));
+
+      //鍒濆鍖栦腑閮ㄤ俊鎭�
+      this.InitMiddleFrame();
+    }
+
+    /// <summary>
+    /// 鍒濆鍖栦腑閮ㄤ俊鎭�
+    /// </summary>
+    private void InitMiddleFrame()
+    {
+      //娓呯┖bodyFrame
+      this.ClearBodyFrame();
+
+      var listBackControl = new VerticalFrameControl();
+      listBackControl.Height = bodyFrameLayout.Height;
+      bodyFrameLayout.AddChidren(listBackControl);
+
+      //鍔犱竴涓櫧鑹茶儗鏅�
+      var frameBack1 = new FrameLayout();
+      frameBack1.Height = Application.GetRealHeight(750);
+      frameBack1.Y = Application.GetRealHeight(196);
+      frameBack1.BackgroundColor = UserCenterColor.Current.White;
+      frameBack1.SetCornerWithSameRadius(Application.GetRealHeight(58), HDLUtils.RectCornerTopLeft | HDLUtils.RectCornerTopRight);
+      listBackControl.frameTable.AddChidren(frameBack1);
+
+      //鎴块棿鍥剧墖搴曢儴闃村奖
+      var btnShadow = new PicViewControl(853, 593);
+      btnShadow.Y = Application.GetRealHeight(58);
+      btnShadow.Gravity = Gravity.CenterHorizontal;
+      btnShadow.UnSelectedImagePath = "Room/RoomShadow.png";
+      listBackControl.frameTable.AddChidren(btnShadow);
+      //鎴块棿鍥剧墖
+      var btnPic = new ImageView();
+      btnPic.Y = Application.GetRealHeight(60);
+      btnPic.Width = this.GetPictrueRealSize(824);
+      btnPic.Height = this.GetPictrueRealSize(549);
+      btnPic.Radius = (uint)Application.GetRealHeight(17);
+      btnPic.Gravity = Gravity.CenterHorizontal;
+      btnPic.ImagePath = "RoomIcon/0.jpg";
+      listBackControl.frameTable.AddChidren(btnPic);
+      //鍥剧墖閬僵
+      var btnZhezhao = new FrameLayout();
+      btnZhezhao.Width = btnPic.Width;
+      btnZhezhao.Height = btnPic.Height;
+      btnZhezhao.Y = btnPic.Y;
+      btnZhezhao.Gravity = Gravity.CenterHorizontal;
+      btnZhezhao.Radius = (uint)Application.GetRealHeight(17);
+      btnZhezhao.BackgroundColor = UserCenterColor.Current.PictrueZhezhaoColor;
+      listBackControl.frameTable.AddChidren(btnZhezhao);
+      btnZhezhao.MouseUpEventHandler += (sender, e) =>
+      {
+        //鎴块棿鍥剧墖閫夋嫨
+        this.RoomPictrueSelect(btnPic);
+      };
+
+      this.newRoom = new Common.Room();
+      newRoom.FloorId = this.floorKeys;
+      newRoom.BackgroundImage = btnPic.ImagePath;
+
+      //鍒濆鍖栦俊鎭甯�
+      var tableContr = new InformationEditorControl();
+      this.listview = tableContr.InitControl(listBackControl.frameTable, Language.StringByID(R.MyInternationalizationString.uInfoEditor), bodyFrameLayout.Height - btnShadow.Bottom, false);
+
+      //娣诲姞鍏ㄩ儴鑿滃崟
+      this.AddAllMenuRow(tableContr, btnPic);
+    }
+
+    #endregion
+
+    #region 鈻� 娣诲姞鑿滃崟___________________________
+
+    /// <summary>
+    /// 娣诲姞鍏ㄩ儴鑿滃崟
+    /// </summary>
+    private void AddAllMenuRow(InformationEditorControl tableContr, ImageView btnPic)
+    {
+      //銆愭埧闂村悕绉般��
+      var txtRoomName = new FrameCaptionInputControl(Language.StringByID(R.MyInternationalizationString.uRoomName), string.Empty, this.listview.rowSpace / 2);
+      txtRoomName.txtInput.PlaceholderText = Language.StringByID(R.MyInternationalizationString.uPleaseInputRoomName);
+      txtRoomName.txtInput.MaxByte = 48;//闄愬埗鍙兘杈撳叆48涓瓧鑺�
+      listview.AddChidren(txtRoomName);
+      txtRoomName.InitControl();
+      //搴曠嚎
+      txtRoomName.AddBottomLine();
+
+      //璇PP涓烘湁妤煎眰鐨勬ā寮忔墠寮�鍚繖涓彍鍗�
+      if (floorKeys != string.Empty)
+      {
+        //銆愭墍灞炴ゼ灞傘��
+        var btnBelone = new FrameCaptionViewControl(Language.StringByID(R.MyInternationalizationString.uBelongeFloor), Common.Config.Instance.Home.FloorDics[this.floorKeys], 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);
+      listview.AddChidren(rowTemperature);
+      rowTemperature.AddLeftCaption(Language.StringByID(R.MyInternationalizationString.uTemperature), 600);
+      //鍙崇澶�
+      rowTemperature.AddRightArrow();
+      var btnTemper = rowTemperature.AddMostRightView(Language.StringByID(R.MyInternationalizationString.uNothing), 300);
+      //搴曠嚎
+      rowTemperature.AddBottomLine();
+      rowTemperature.ButtonClickEvent += (sender, e) =>
+      {
+        //鏄剧ず娓╁害浼犳劅鍣ㄥ垪琛�
+        this.ShowTemperatrueDevice(btnTemper);
+      };
+
+      //銆愭箍搴︺��
+      var rowHumidity = new FrameRowControl(this.listview.rowSpace / 2);
+      listview.AddChidren(rowHumidity);
+      rowHumidity.AddLeftCaption(Language.StringByID(R.MyInternationalizationString.uHumidity), 600);
+      //鍙崇澶�
+      rowHumidity.AddRightArrow();
+      var btnHumi = rowHumidity.AddMostRightView(Language.StringByID(R.MyInternationalizationString.uNothing), 300);
+      //搴曠嚎
+      rowHumidity.AddBottomLine();
+      rowHumidity.ButtonClickEvent += (sender, e) =>
+      {
+        //鏄剧ず婀垮害浼犳劅鍣ㄥ垪琛�
+        this.ShowHumidityDevice(btnHumi);
+      };
+
+      //鍒濆鍖栨甯冨畬鎴�
+      tableContr.FinishInitControl();
+      tableContr = null;
+      //淇濆瓨
+      var btnFinish = new BottomClickButton();
+      btnFinish.TextID = R.MyInternationalizationString.uSave;
+      bodyFrameLayout.AddChidren(btnFinish);
+      btnFinish.ButtonClickEvent += (sender, e) =>
+      {
+        this.newRoom.Name = txtRoomName.Text;
+        //妫�娴嬭兘鍚︿繚瀛樻埧闂�
+        if (this.CheckCanSaveRoom() == false)
+        {
+          return;
+        }
+        if (newRoom.BackgroundImageType == 1 || newRoom.BackgroundImageType == 2)
+        {
+          //鐢熸垚鍥剧墖
+          string picName = $"RoomIcon_{DateTime.Now.ToString("yyyyMMddHHmmss")}.png";
+          string picFullName = System.IO.Path.Combine(Common.Config.Instance.FullPath, picName);
+          Shared.IO.FileUtils.WriteFileByBytes(picFullName, btnPic.ImageBytes);
+          newRoom.BackgroundImage = picName;
+          //澶囦唤
+          Phone.UserCenter.HdlAutoBackupLogic.AddOrEditorFile(picName);
+        }
+
+        newRoom.FloorId = this.floorKeys;
+
+        //娣诲姞鎴块棿,涓婚〉闇�瑕侀噸鏂板埛鏂�
+        UserView.UserPage.Instance.RefreshAllForm = true;
+
+        HdlRoomLogic.Current.AddRoom(newRoom);
+        this.FinishEditorEvent?.Invoke();
+
+        this.CloseForm();
+      };
+    }
+
+    #endregion
+
+    #region 鈻� 妤煎眰閫夋嫨___________________________
+
+    /// <summary>
+    /// 妤煎眰閫夋嫨
+    /// </summary>
+    /// <param name="control"></param>
+    private void ShowSelectFloor(FrameCaptionViewControl control)
+    {
+      var dicFloor = HdlRoomLogic.Current.GetFloorSortList();
+
+      var listKeys = new List<string>();
+      var listName = new List<string>();
+      int index = 0;
+      foreach (string keys in dicFloor.Keys)
+      {
+        listKeys.Add(keys);
+        listName.Add(dicFloor[keys]);
+        if (keys == this.floorKeys)
+        {
+          index = listKeys.Count - 1;
+        }
+      }
+      PickerView.Show(listName, (value) =>
+       {
+         control.txtView.Text = listName[value];
+         //涓婚敭淇敼
+         this.floorKeys = listKeys[value];
+       },
+      index,
+      Language.StringByID(R.MyInternationalizationString.uBelongeFloor),
+      Language.StringByID(R.MyInternationalizationString.uFinish),
+      Language.StringByID(R.MyInternationalizationString.uCancel));
+    }
+
+    #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);
+        }
+        //PM2.5鏄俯搴﹀拰婀垮害鍚堝湪鍚屼竴涓鐐�
+        else if (device.Type == ZigBee.Device.DeviceType.PMSensor)
+        {
+          listDevice.Add(device);
+        }
+      }
+      var listSelect = new List<string>() { newRoom.TemperatrueDevice };
+      var form = new SelectDeviceForm();
+      form.AddForm(listDevice, listSelect, true, true);
+      form.ActionSelectDevice += (list) =>
+      {
+        if (list.Count == 0)
+        {
+          newRoom.TemperatrueDevice = string.Empty;
+          btnTemper.Text = Language.StringByID(R.MyInternationalizationString.uNothing);
+          return;
+        }
+        newRoom.TemperatrueDevice = Common.LocalDevice.Current.GetDeviceMainKeys(list[0]);
+        //鑾峰彇娓╁害鍊�
+        this.GetTemperatrueValue(btnTemper, newRoom.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.Getting);
+
+      bool receiveData = false;
+      HdlGatewayReceiveLogic.Current.RemoveEvent("TemperatrueDevice");
+      HdlGatewayReceiveLogic.Current.AddAttributeEvent("TemperatrueDevice", ReceiveComandDiv.A璁惧灞炴�т笂鎶�, ((report) =>
+      {
+        string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(report);
+        if (newRoom.TemperatrueDevice != mainKeys || btnTemper == null
+              || report.DeviceStatusReport.CluterID != 1026)
+        {
+          return;
+        }
+        receiveData = true;
+
+        HdlThreadLogic.Current.RunMain(() =>
+              {
+                decimal temperatrue = (decimal)device.GetType().InvokeMember("currentTemperature", System.Reflection.BindingFlags.GetField, null, device, null);
+                if (temperatrue == 0)
+                {
+                  //0
+                  btnTemper.Text = "0.0鈩�";
+                }
+                else
+                {
+                  btnTemper.Text = temperatrue + "鈩�";
+                }
+
+              }, ShowErrorMode.NO);
+
+      }));
+      //鍙戦�佽幏鍙栨俯搴︾殑鍛戒护
+      device.ReadAttri(ZigBee.Device.Cluster_ID.TemperatureMeasurement, ZigBee.Device.AttriButeId.MeasuredValue);
+
+      HdlThreadLogic.Current.RunThread(() =>
+      {
+        //鍘昏幏鍙栬澶囧垪琛ㄧ殑淇℃伅
+        System.Threading.Thread.Sleep(1500);
+        var result = Common.LocalDevice.Current.ReadDeviceEpointDeviceInfo(device);
+        if (result != null)
+        {
+          device.AttributeStatus.Clear();
+          device.AttributeStatus.AddRange(result.AttributeStatus);
+          device.ReSave();
+        }
+        if (receiveData == true)
+        {
+          //宸茬粡璇诲彇鍒版暟鎹�
+          return;
+        }
+
+        foreach (var data in device.AttributeStatus)
+        {
+          if (data.ClusterId == 1026
+                   && data.AttributeId == (int)ZigBee.Device.AttriButeId.MeasuredValue)
+          {
+            //澶勭悊缃戝叧杩斿洖鐨勬俯搴﹀��
+            decimal temperatrue = 0;
+            this.AdjustTemperatrueValue(data.AttributeData, ref temperatrue);
+
+            device.GetType().InvokeMember("currentTemperature", System.Reflection.BindingFlags.SetField, null, device, new object[] { temperatrue });
+            device.ReSave();
+
+            //鍒朵綔铏氬亣鐨勫睘鎬т笂鎶�
+            var report = new ZigBee.Device.CommonDevice { DeviceAddr = device.DeviceAddr, DeviceEpoint = device.DeviceEpoint };
+            report.DeviceStatusReport.CluterID = 1026;
+            HdlGatewayReceiveLogic.Current.DeviceReportPush(report, ReceiveComandDiv.A璁惧灞炴�т笂鎶�);
+
+            HdlThreadLogic.Current.RunMain(() =>
+                  {
+                    btnTemper.Text = temperatrue == 0 ? "0.0鈩�" : temperatrue.ToString() + "鈩�";
+                  });
+            break;
+          }
+        }
+      });
+    }
+
+    /// <summary>
+    /// 澶勭悊缃戝叧杩斿洖鐨勬俯搴﹀��
+    /// </summary>
+    /// <param name="value">缃戝叧杩斿洖鐨勫睘鎬у��</param>
+    /// <param name="temperatrue">杞崲鎴愮殑娓╁害鍊�</param>
+    private void AdjustTemperatrueValue(int value, ref decimal temperatrue)
+    {
+      if (value == 0)
+      {
+        //0鈩�
+        temperatrue = 0;
+      }
+      else if (value > 32767)
+      {
+        //璐熸暟(鐗规畩澶勭悊)
+        string strValue = (value - 65536).ToString();
+        //灏忔暟鐐归渶瑕佷竴浣�
+        strValue = strValue.Substring(0, strValue.Length - 1);
+        //璁板綍娓╁害
+        temperatrue = Convert.ToDecimal(strValue.Insert(strValue.Length - 1, "."));
+      }
+      else
+      {
+        //灏忔暟鐐归渶瑕佷竴浣�
+        string strValue = value.ToString();
+        strValue = strValue.Substring(0, strValue.Length - 1);
+        //璁板綍娓╁害
+        temperatrue = Convert.ToDecimal(strValue.Insert(strValue.Length - 1, "."));
+      }
+    }
+
+    #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);
+        }
+        //鏂伴鍜岀┖姘旇川閲忎紶鎰熷櫒鐨勬箍搴︿紶鎰熷櫒
+        else if (device.Type == ZigBee.Device.DeviceType.FreshAirHumiditySensor)
+        {
+          listDevice.Add(device);
+        }
+        //PM2.5鏄俯搴﹀拰婀垮害鍚堝湪鍚屼竴涓鐐�
+        else if (device.Type == ZigBee.Device.DeviceType.PMSensor)
+        {
+          listDevice.Add(device);
+        }
+
+      }
+      var listSelect = new List<string>() { newRoom.HumidityDevice };
+      var form = new SelectDeviceForm();
+      form.AddForm(listDevice, listSelect, true, true);
+      form.ActionSelectDevice += (list) =>
+      {
+        if (list.Count == 0)
+        {
+          newRoom.HumidityDevice = string.Empty;
+          btnHumi.Text = Language.StringByID(R.MyInternationalizationString.uNothing);
+          return;
+        }
+        newRoom.HumidityDevice = Common.LocalDevice.Current.GetDeviceMainKeys(list[0]);
+        //鑾峰彇婀垮害鍊�
+        this.GetHumidityValue(btnHumi, newRoom.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.Getting);
+
+      bool receiveData = false;
+      HdlGatewayReceiveLogic.Current.RemoveEvent("HumidityDevice");
+      HdlGatewayReceiveLogic.Current.AddAttributeEvent("HumidityDevice", ReceiveComandDiv.A璁惧灞炴�т笂鎶�, (report) =>
+      {
+        string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(report);
+        if (newRoom.HumidityDevice != mainKeys || btnHumi == null
+              || report.DeviceStatusReport.CluterID != 1029)
+        {
+          return;
+        }
+        receiveData = true;
+        HdlThreadLogic.Current.RunMain(() =>
+              {
+                decimal humidity = (decimal)device.GetType().InvokeMember("currentHumidity", System.Reflection.BindingFlags.GetField, null, device, null);
+                if (humidity == 0)
+                {
+                  //0
+                  btnHumi.Text = "0.0%";
+                }
+                else
+                {
+                  btnHumi.Text = humidity.ToString() + "%";
+                }
+
+              }, ShowErrorMode.NO);
+      });
+      //鍙戦�佽幏鍙栨箍搴︾殑鍛戒护
+      device.ReadAttri(ZigBee.Device.Cluster_ID.RelativeHumidityMeasurement, ZigBee.Device.AttriButeId.MeasuredValue);
+
+      HdlThreadLogic.Current.RunThread(() =>
+      {
+        //鍘昏幏鍙栬澶囧垪琛ㄧ殑淇℃伅
+        System.Threading.Thread.Sleep(1500);
+        var result = Common.LocalDevice.Current.ReadDeviceEpointDeviceInfo(device);
+        if (result != null)
+        {
+          device.AttributeStatus.Clear();
+          device.AttributeStatus.AddRange(result.AttributeStatus);
+          device.ReSave();
+        }
+        if (receiveData == true)
+        {
+          //宸茬粡璇诲彇鍒版暟鎹�
+          return;
+        }
+
+        //鍒濆鍊�,鍙栫紦瀛樻暟鎹�
+        foreach (var data in device.AttributeStatus)
+        {
+          if (data.ClusterId == 1029
+                   && data.AttributeId == (int)ZigBee.Device.AttriButeId.MeasuredValue)
+          {
+            //澶勭悊缃戝叧杩斿洖鐨勬箍搴﹀��
+            decimal humidity = 0;
+            this.AdjustHumidityValue(data.AttributeData, ref humidity);
+
+            device.GetType().InvokeMember("currentHumidity", System.Reflection.BindingFlags.SetField, null, device, new object[] { humidity });
+            device.ReSave();
+
+            //鍒朵綔铏氬亣鐨勫睘鎬т笂鎶�
+            var report = new ZigBee.Device.CommonDevice { DeviceAddr = device.DeviceAddr, DeviceEpoint = device.DeviceEpoint };
+            report.DeviceStatusReport.CluterID = 1029;
+            HdlGatewayReceiveLogic.Current.DeviceReportPush(report, ReceiveComandDiv.A璁惧灞炴�т笂鎶�);
+
+            HdlThreadLogic.Current.RunMain(() =>
+                  {
+                    btnHumi.Text = humidity == 0 ? "0.0%" : humidity.ToString() + "%";
+                  });
+            break;
+          }
+        }
+      });
+    }
+
+    /// <summary>
+    /// 澶勭悊缃戝叧杩斿洖鐨勬箍搴﹀��
+    /// </summary>
+    /// <param name="value">缃戝叧杩斿洖鐨勫睘鎬у��</param>
+    /// <param name="temperatrue">杞崲鎴愮殑婀垮害鍊�</param>
+    /// <param name="valueText">杞崲鎴愮殑婀垮害鍊肩殑缈昏瘧鏂囨湰</param>
+    private void AdjustHumidityValue(int value, ref decimal humidity)
+    {
+      if (value == 0)
+      {
+        //0%
+        humidity = 0;
+      }
+      //涓嶄細鍑虹幇璐熸暟
+      else
+      {
+        //灏忔暟鐐归渶瑕佷竴浣�
+        string strValue = value.ToString();
+        strValue = strValue.Substring(0, strValue.Length - 1);
+        //璁板綍娓╁害
+        humidity = Convert.ToDecimal(strValue.Insert(strValue.Length - 1, "."));
+      }
+    }
+
+    #endregion
+
+    #region 鈻� 鎴块棿鍥剧墖閫夋嫨_______________________
+
+    /// <summary>
+    /// 鎴块棿鍥剧墖閫夋嫨
+    /// </summary>
+    /// <param name="imageContr"></param>
+    private void RoomPictrueSelect(ImageView imageContr)
+    {
+      var menuContr = new BottomMenuSelectForm();
+      menuContr.AddForm(3);
+      //榛樿鍥惧簱
+      menuContr.AddMenu(Language.StringByID(R.MyInternationalizationString.LocalPicture), () =>
+      {
+        var form = new SelectLocalRoomImageForm();
+        form.AddForm();
+        form.FinishSelectEvent = (imgPath) =>
+              {
+                if (string.IsNullOrEmpty(imgPath) == true)
+                {
+                  return;
+                }
+                this.newRoom.BackgroundImageType = 0;
+                this.newRoom.BackgroundImage = imgPath;
+                imgPath = IO.FileUtils.GetImageFilePath(imgPath);
+                imageContr.ImageBytes = IO.FileUtils.ReadFile(imgPath);
+              };
+      });
+      //鎷嶇収
+      menuContr.AddMenu(Language.StringByID(R.MyInternationalizationString.Photograph), () =>
+      {
+        //閫氳繃鐩告満鎷嶇収瑁佸壀
+        CropImage.TakePicture((imagePath) =>
+        {
+          if (string.IsNullOrEmpty(imagePath) == true)
+          {
+            return;
+          }
+          this.newRoom.BackgroundImageType = 1;
+          imageContr.ImageBytes = Shared.IO.FileUtils.ReadFile(imagePath);
+          System.IO.File.Delete(imagePath);
+        }, "HdlPic", 2, 1);
+      });
+      //鎴戠殑鐩稿唽
+      menuContr.AddMenu(Language.StringByID(R.MyInternationalizationString.MyAblums), () =>
+      {
+        //浠庣浉鍐岄�夋嫨鍥剧墖瑁佸壀
+        CropImage.SelectPicture((imagePath) =>
+        {
+          if (string.IsNullOrEmpty(imagePath) == true)
+          {
+            return;
+          }
+          this.newRoom.BackgroundImageType = 2;
+          imageContr.ImageBytes = Shared.IO.FileUtils.ReadFile(imagePath);
+          System.IO.File.Delete(imagePath);
+
+        }, "HdlPic", 2, 1);
+      });
+    }
+
+    #endregion
+
+    #region 鈻� 鐣岄潰鍏抽棴___________________________
+
+    /// <summary>
+    /// 鐣岄潰鍏抽棴
+    /// </summary>
+    public override void CloseFormBefore()
+    {
+      this.FinishEditorEvent = null;
+
+      HdlGatewayReceiveLogic.Current.RemoveEvent("TemperatrueDevice");
+      HdlGatewayReceiveLogic.Current.RemoveEvent("HumidityDevice");
+
+      base.CloseFormBefore();
+    }
+
+    #endregion
+
+    #region 鈻� 涓�鑸柟娉昣__________________________
+
+    /// <summary>
+    /// 妫�娴嬭兘鍚︿繚瀛樻埧闂�
+    /// </summary>
+    /// <returns></returns>
+    private bool CheckCanSaveRoom()
+    {
+      if (this.newRoom.Name == string.Empty)
+      {
+        //璇疯緭鍏ユ埧闂村悕绉�
+        this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uPleaseInputRoomName));
+        return false;
+      }
+      if (string.IsNullOrEmpty(this.floorKeys) == true)
+      {
+        var listRoom = HdlRoomLogic.Current.GetAllListRooms();
+        if (listRoom.Find((obj) => obj.Name == this.newRoom.Name && obj.Id != this.newRoom.Id) != null)
+        {
+          this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uRoomNameIsExist));
+          return false;
+        }
+      }
+      else
+      {
+        var listRoom = HdlRoomLogic.Current.GetFloorSortRoom(this.floorKeys);
+        if (listRoom.Find((obj) => obj.Name == this.newRoom.Name && obj.Id != this.newRoom.Id) != null)
+        {
+          this.ShowMassage(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uRoomNameIsExist));
+          return false;
+        }
+      }
+
+      return true;
+    }
+
+    #endregion
+  }
 }

--
Gitblit v1.8.0