From 792ca2a402feb952ef890d653f2e049c1230baf1 Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期六, 19 十二月 2020 18:48:33 +0800
Subject: [PATCH] 1111
---
HDL_ON/Entity/DB_ResidenceData.cs | 212 +++++++++++++++++++++++++++++++++++++---------------
1 files changed, 151 insertions(+), 61 deletions(-)
diff --git a/HDL_ON/Entity/DB_ResidenceData.cs b/HDL_ON/Entity/DB_ResidenceData.cs
old mode 100644
new mode 100755
index 4cdf89b..16fb651
--- a/HDL_ON/Entity/DB_ResidenceData.cs
+++ b/HDL_ON/Entity/DB_ResidenceData.cs
@@ -1,11 +1,13 @@
锘縰sing System;
using System.Collections.Generic;
+using System.IO;
using System.Threading;
using HDL_ON.DAL.Server;
using Shared;
namespace HDL_ON.Entity
{
+ [System.Serializable]
public class DB_ResidenceData
{
public DB_ResidenceData()
@@ -16,77 +18,50 @@
/// 涓讳汉token
/// </summary>
public string MasterToken;
+
+ //RegionInfoRes _residecenInfo;
+ RegionInfoRes _residecenInfo = new RegionInfoRes();
/// <summary>
/// 浣忓畢鍩虹淇℃伅
/// </summary>
- public RegionInfoRes residecenInfo
+ public RegionInfoRes CurrentRegion
{
get
{
if (MainPage.NoLoginMode)
{
- return new RegionInfoRes() { Name = "鏈湴妯″紡" , };
+ return new RegionInfoRes() { Name = "鏈湴妯″紡" };
}
else
{
- var curRegion = UserInfo.Current.regionList.Find((obj) => obj.RegionID == UserInfo.Current.CurReginID);
- if (curRegion == null)
+ if (_residecenInfo == null)
{
if (UserInfo.Current.regionList != null && UserInfo.Current.regionList.Count > 0)
{
- UserInfo.Current.CurReginID = UserInfo.Current.regionList[0].RegionID;
- //鎭㈠澶囦唤
- //HDLCommon.Current.RestoreHomeBackup(CurReginID);
-
- return UserInfo.Current.regionList[0];
+ _residecenInfo = UserInfo.Current.regionList[0];
}
else
{
- return new RegionInfoRes();
+ _residecenInfo = new RegionInfoRes();
+ HDLCommon.Current.Logout();
}
}
- return curRegion;
+ return _residecenInfo;
}
+ }
+ set
+ {
+ _residecenInfo = value;
}
}
- ///// <summary>
- ///// 鑾峰彇缃戝叧鍒楄〃
- ///// </summary>
- //void GetHomeGatewayList()
- //{
- // new Thread(() =>
- // {
- // //鍒囨崲浣忓畢鍚庯紝鏌ヨ涓�娆$綉鍏冲垪琛�
- // new HttpServerRequest().GetHomeGatewayList();
- // })
- // { IsBackground = true }.Start();
-
- //}
-
- //string curReginID;
- ///// <summary>
- ///// 褰撳墠閫夋嫨鐨勪綇瀹呯储寮�
- ///// </summary>
- //public string CurReginID
- //{
- // set
- // {
- // curReginID = value;
- // GetHomeGatewayList();
- // }
- // get
- // {
- // return curReginID;
- // }
- //}
/// <summary>
/// 鍔熻兘绫诲瀷鍒楄〃
/// </summary>
public List<ShowFunction> functionTypeList = new List<ShowFunction>();
static DB_ResidenceData instance;
- public static DB_ResidenceData residenceData
+ public static DB_ResidenceData Instance
{
get
{
@@ -94,7 +69,7 @@
{
try
{
- var residenceDataBytes = Common.FileUtlis.Files.ReadFile("DB_ResidenceData");
+ var residenceDataBytes = ReadResidenceInfo();
var userConfigString = System.Text.Encoding.UTF8.GetString(residenceDataBytes);
DB_ResidenceData temp = null;
@@ -114,12 +89,12 @@
{
instance.functionTypeList.AddRange(new List<ShowFunction> {
ShowFunction.Light,ShowFunction.AC,ShowFunction.Curtain,
- ShowFunction.FloorHeating,ShowFunction.DoorLock,
- ShowFunction.Electric,ShowFunction.EnergyMonitoring,
- ShowFunction.Environmental,
- ShowFunction.FreshAir,ShowFunction.Music,
- ShowFunction.Panel,ShowFunction.SecurityMonitoring,
- ShowFunction.Sensor,ShowFunction.VideoIntercom
+ ShowFunction.FloorHeating,ShowFunction.Music,
+ ShowFunction.Electric,ShowFunction.Environmental,
+ //ShowFunction.EnergyMonitoring,
+ //ShowFunction.FreshAir,ShowFunction.DoorLock,
+ //ShowFunction.Panel,ShowFunction.SecurityMonitoring,
+ //ShowFunction.Sensor,ShowFunction.VideoIntercom
});
instance.SaveResidenceData();
}
@@ -146,8 +121,10 @@
instance = null;
ins_OidList = null;
HomeGateway = null;
- SpatialInfo.CurrentSpatial.ClearRooms();
+ SpatialInfo.CurrentSpatial.Clear();
FunctionList.List.Clear();
+ ///鍒囨崲浣忓畢娓呯┖鍓嶄綇瀹呯紦瀛樿嚜鍔ㄥ寲鍒楄〃锛�
+ HDL_ON.UI.UI2.Intelligence.Automation.Logic.LogicList.Clear();
if (MainPage.IsRemote)
{
DAL.Mqtt.MqttClient.DisConnectRemote("閫�鍑虹櫥褰曪紝鎴栬�呭垏鎹綇瀹�");
@@ -182,7 +159,10 @@
}
}
}
-
+ /// <summary>
+ /// 璁板綍绐楀笜鍏ㄥ紑鍏ㄥ叧鐘舵��
+ /// </summary>
+ public bool GlobalCurtainStatus = false;
/// <summary>
/// 妫�娴嬩綇瀹呮槸鍚︾粦瀹氫簡缃戝叧
/// gatewayId 鍒ょ┖
@@ -192,11 +172,11 @@
{
if (HomeGateway != null && !string.IsNullOrEmpty(HomeGateway.gatewayId))
{
- return true;
+ return false;
}
else
{
- return false;
+ return true;
}
}
@@ -259,22 +239,132 @@
/// </summary>
public void SaveResidenceData()
{
- if (this == null || this.residecenInfo == null)
+ if (this == null || this.CurrentRegion == null)
return;
var ssd = System.Text.Encoding.UTF8.GetBytes(Newtonsoft.Json.JsonConvert.SerializeObject(this));
- Common.FileUtlis.Files.WriteFileByBytes("DB_ResidenceData", ssd);
+ WirteResidenceInfo(ssd);
}
-
/// <summary>
/// 褰撳墠閫夋嫨鐨勬ゼ灞�
/// </summary>
public string CurFoor = Language.StringByID(StringId.All);
- ///// <summary>
- ///// 鎴块棿鍒楄〃
- ///// </summary>
- //[Newtonsoft.Json.JsonIgnore]
- //public List<Room> Rooms = SpatialInfo.CurrentSpatial.RoomList;
+ /// <summary>
+ /// 褰撳墠閫夋嫨鐨勬ゼ灞�
+ /// </summary>
+ [Newtonsoft.Json.JsonIgnore]
+ public SpatialInfo CurFloor = new SpatialInfo() { roomId = "", roomName = Language.StringByID(StringId.All)};
+ /// <summary>
+ /// 鍒嗙被鐣岄潰鏄剧ず鐨勬ゼ灞�
+ /// </summary>
+ [Newtonsoft.Json.JsonIgnore]
+ public SpatialInfo ClassificationChooseFloor = new SpatialInfo() { roomId = "", roomName = Language.StringByID(StringId.All) };
+
+ /// <summary>
+ /// 鏍圭洰褰�
+ /// </summary>
+ static string RootPath = Environment.GetFolderPath(System.Environment.SpecialFolder.Personal) + "/";
+ /// <summary>
+ /// 璇诲彇ResidenceInfo鏂囦欢
+ /// </summary>
+ /// <returns></returns>
+ static byte[] ReadResidenceInfo()
+ {
+ MainPage.Log("get file Instance ");
+ var fileName = "DB_ResidenceData";
+ FileStream fs = null;
+ try
+ {
+ var temp = CreateUserFloder(OnAppConfig.Instance.LastLoginUserId);
+ if (File.Exists(Path.Combine(temp, fileName)))
+ {
+ fs = new FileStream(Path.Combine(temp, fileName), FileMode.Open, FileAccess.Read);
+ }
+ else if (File.Exists(fileName))
+ {
+ fs = new FileStream(fileName, FileMode.Open, FileAccess.Read);
+ }
+ else
+ {
+ return new byte[0];
+ }
+ byte[] bytes = new byte[fs.Length];
+ fs.Read(bytes, 0, bytes.Length);
+ return bytes;
+ }
+ catch
+ {
+ return new byte[0];
+ }
+ finally
+ {
+ MainPage.Log("get file ");
+ try
+ {
+ if (fs != null)
+ {
+ fs.Close();
+ }
+ }
+ catch
+ {
+
+ }
+ }
+
+ }
+ /// <summary>
+ /// 淇濆瓨ResidenceInfo
+ /// </summary>
+ /// <param name="bytes"></param>
+ /// <returns></returns>
+ static bool WirteResidenceInfo(byte[] bytes)
+ {
+ var fileName = "DB_ResidenceData";
+ FileStream fs = null;
+
+ try
+ {
+ var temp = CreateUserFloder(OnAppConfig.Instance.LastLoginUserId);
+ fs = new FileStream(Path.Combine(temp, fileName), FileMode.Create, FileAccess.Write);
+ fs.Write(bytes, 0, bytes.Length);
+ fs.Flush();
+ MainPage.Log("SaveFile:" + fileName);
+ return true;
+ }
+ catch (Exception ex)
+ {
+ MainPage.Log("FileUtiles Code 113:" + ex.ToString());
+ return false;
+ }
+ finally
+ {
+ try
+ {
+ if (fs != null)
+ {
+ fs.Close();
+ }
+ }
+ catch (Exception ex)
+ {
+ MainPage.Log("FileUtils Code 121 :" + ex.ToString());
+ }
+ }
+ }
+ /// <summary>
+ /// 鍒涘缓涓�涓綇瀹呯殑璐﹀彿鏂囦欢澶�
+ /// </summary>
+ static string CreateUserFloder(string userId)
+ {
+ var path = Path.Combine(RootPath, userId);
+ if (!Directory.Exists(path))
+ {
+ Directory.CreateDirectory(path);
+ }
+ return path + "/";
+ }
+
#region oid鍒楄〃 a鍗忚杞琤us鍗忚鎺у埗浣跨敤
/// <summary>
--
Gitblit v1.8.0