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 |  692 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 692 insertions(+), 0 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/Residence/AddNewRoomForm.cs b/ZigbeeApp/Shared/Phone/UserCenter/Residence/AddNewRoomForm.cs
new file mode 100644
index 0000000..dc8e022
--- /dev/null
+++ b/ZigbeeApp/Shared/Phone/UserCenter/Residence/AddNewRoomForm.cs
@@ -0,0 +1,692 @@
+锘縰sing System;
+using System.Collections.Generic;
+using System.Text;
+
+namespace Shared.Phone.UserCenter.Residence
+{
+  /// <summary>
+  /// 娣诲姞鏂版埧闂寸殑鐣岄潰
+  /// </summary>
+  public class AddNewRoomForm : EditorCommonForm
+  {
+    #region 鈻� 鍙橀噺澹版槑___________________________
+
+    /// <summary>
+    /// 瀹屾垚娣诲姞鎴块棿鐨勪簨浠�
+    /// </summary>
+    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