From 002a3f2e9d2f9579c01f88af12bd8a320003569f Mon Sep 17 00:00:00 2001
From: wxr <464027401@qq.com>
Date: 星期二, 31 三月 2020 08:57:19 +0800
Subject: [PATCH] 20200331

---
 HDL_ON/Entity/DB_ResidenceData.cs |  370 +++++++++++++++++++++++++++++-----------------------
 1 files changed, 207 insertions(+), 163 deletions(-)

diff --git a/HDL_ON/Entity/DB_ResidenceData.cs b/HDL_ON/Entity/DB_ResidenceData.cs
index 924313e..93583a6 100644
--- a/HDL_ON/Entity/DB_ResidenceData.cs
+++ b/HDL_ON/Entity/DB_ResidenceData.cs
@@ -13,10 +13,6 @@
         /// 浣忓畢鍚嶇О
         /// </summary>
         public string residenceName;
-        /// <summary>
-        /// 浣忓畢鍥剧墖
-        /// </summary>
-        public string residenceImage;
 
         /// <summary>
         /// 妤煎眰鍒楄〃
@@ -27,15 +23,15 @@
         /// 鎴块棿鍒楄〃
         /// </summary>
         public List<Room> rooms = new List<Room>();
-
-        /// <summary>
-        /// 鍔熻兘绫诲瀷鍒楄〃
-        /// </summary>
-        public List<string> functionTypeList = new List<string>();
         /// <summary>
         /// 鍔熻兘鍒楄〃
         /// </summary>
         public FunctionList functionList = new FunctionList();
+
+        /// <summary>
+        /// 鍔熻兘绫诲瀷鍒楄〃
+        /// </summary>
+        public List<FunctionCategory> functionTypeList = new List<FunctionCategory>();
 
         static DB_ResidenceData instance;
         public static DB_ResidenceData residenceData
@@ -63,159 +59,181 @@
                         }
                         if (instance.functionTypeList.Count == 0)
                         {
-                            instance.functionTypeList.AddRange(new List<string> {
-                                    "Light","AC","Curtain"
-                                    ,"FloorHeating","DoorLock"
-                                    ,"Electric","EnergyMonitoring",
-                                    "Environmental",
-                                    "FreshAir","Music",
-                                    "Panel","SecurityMonitoring",
-                                    "Sensor","VideoIntercom"
+                            instance.functionTypeList.AddRange(new List<FunctionCategory> {
+                                    FunctionCategory.Light,FunctionCategory.AC,FunctionCategory.Curtain,
+                                    FunctionCategory.FloorHeating,FunctionCategory.DoorLock,
+                                    FunctionCategory.Electric,FunctionCategory.EnergyMonitoring,
+                                    FunctionCategory.Environmental,
+                                    FunctionCategory.FreshAir,FunctionCategory.Music,
+                                    FunctionCategory.Panel,FunctionCategory.SecurityMonitoring,
+                                    FunctionCategory.Sensor,FunctionCategory.VideoIntercom
                                 });
                         }
 
                         //new System.Threading.Thread(() =>
                         //{
 #if DEBUG
-                            if (DB_ResidenceData.residenceData.functionList.scenes.Count == 0)
+                        if (DB_ResidenceData.residenceData.functionList.scenes.Count == 0)
+                        {
+                            var s0 = new Scene()
                             {
-                                var s1 = new Scene()
-                                {
-                                    name = "鍦烘櫙",
-                                    scene_id = "0001",
-                                    sceneType = SceneType.OrdinaryScenes,
-                                    roomIdList = new List<string>() { "0001" },
-                                };
-                                DB_ResidenceData.residenceData.functionList.scenes.Add(s1);
-                                var s2 = new Scene()
-                                {
-                                    name = "鐢靛奖鍦烘櫙",
-                                    scene_id = "0002",
-                                    sceneType = SceneType.MovieScene,
-                                    roomIdList = new List<string>() { "0001" },
-                                };
-                                DB_ResidenceData.residenceData.functionList.scenes.Add(s2);
-
-                                var s3 = new Scene()
-                                {
-                                    name = "鐢靛奖鍦烘櫙2",
-                                    scene_id = "0003",
-                                    sceneType = SceneType.MovieScene,
-                                    roomIdList = new List<string>() { "0001" },
-                                };
-                                DB_ResidenceData.residenceData.functionList.scenes.Add(s3);
-                            }
-                            if (instance.rooms.Count == 0)
+                                sid = "12341212345678901234560100010001",
+                                name = "鍏ㄥ叧鍦烘櫙",
+                                scene_id = "0001",
+                                sceneType = SceneType.OrdinaryScenes,
+                                roomIdList = new List<string>() { "0001" },
+                                bus_SceneData = new Dictionary<string, byte[]>(),
+                            };
+                            s0.bus_SceneData.Add("12341212345678901234560401020002", new byte[] { 1, 0, 0, 0 });
+                            s0.bus_SceneData.Add("12341212345678901234560401010005", new byte[] { 1, 0, 0, 0 });
+                            s0.bus_SceneData.Add("12341212345678901234560401030006", new byte[] { 1, 0, 254, 0, 0, 3, 255, 0, 0, 0, 0 });
+                            s0.bus_SceneData.Add("12341212345678901234560603010001", new byte[] { 1, 0, 32, 32, 32, 32, 32, 0, 0, 0, 1, 28, 0 });
+                            s0.bus_SceneData.Add("12341212345678901234560502010003", new byte[] { 1, 2 });
+                            DB_ResidenceData.residenceData.functionList.scenes.Add(s0);
+                            var s1 = new Scene()
                             {
-                                //--------------------
-                                var r111 = new Room() { sid = "0001", name = "Room-1", floorIndex = 1, backgroundImage = "Classification/Room/Roombg.png" };
-                                instance.rooms.Add(r111);
-                                instance.functionList.aCs.Add(new AC()
+                                sid = "12341212345678901234560100010002",
+                                name = "鍏ㄥ紑鍦烘櫙",
+                                scene_id = "0002",
+                                sceneType = SceneType.OrdinaryScenes,
+                                roomIdList = new List<string>() { "0001" },
+                                bus_SceneData = new Dictionary<string, byte[]>(),
+                            };
+                            s1.bus_SceneData.Add("12341212345678901234560401020002", new byte[] { 1, 100, 0, 0 });
+                            s1.bus_SceneData.Add("12341212345678901234560401010005", new byte[] { 1, 100, 0, 0 });
+                            s1.bus_SceneData.Add("12341212345678901234560401030006", new byte[] { 1, 100, 254, 0, 0, 3, 255, 0, 0, 0, 0 });
+                            s1.bus_SceneData.Add("12341212345678901234560603010001", new byte[] { 1, 0, 32, 32, 32, 32, 32, 0, 1, 0, 1, 28, 0 });
+                            s1.bus_SceneData.Add("12341212345678901234560502010003", new byte[] { 1, 1 });
+                            DB_ResidenceData.residenceData.functionList.scenes.Add(s1);
+                            var s2 = new Scene()
+                            {
+                                sid = "12341212345678901234560100010004",
+                                name = "鐢靛奖鍦烘櫙",
+                                scene_id = "0004",
+                                sceneType = SceneType.MovieScene,
+                                roomIdList = new List<string>() { "0001" },
+                            };
+                            DB_ResidenceData.residenceData.functionList.scenes.Add(s2);
+                            var s3 = new Scene()
+                            {
+                                name = "鐢靛奖鍦烘櫙2",
+                                scene_id = "0003",
+                                sceneType = SceneType.MovieScene,
+                                roomIdList = new List<string>() { "0001" },
+                            };
+                            DB_ResidenceData.residenceData.functionList.scenes.Add(s3);
+                        }
+                        if (instance.rooms.Count == 0)
+                        {
+                            //--------------------
+                            var r111 = new Room() { sid = "0001", name = "Room-1", floorIndex = 1, backgroundImage = "Classification/Room/Roombg.png" };
+                            instance.rooms.Add(r111);
+                            instance.functionList.aCs.Add(new AC()
+                            {
+                                sid = "12341212345678901234560603010001",
+                                name = "绌鸿皟",
+                                trait = "on_off,mode,fan,temperature",
+                                roomIdList = new List<string>() { "0001" },
+                                lastState = "鍒跺喎 涓 18掳C",
+                                bus_Data = new BusData
                                 {
-                                    sid = "12341212345678901234560600000001",
-                                    name = "绌鸿皟",
-                                    trait = "on_off,mode,fan,temperature",
-                                    roomIdList = new List<string>() { "0001" },
-                                    lastState = "鍒跺喎 涓 18掳C",
-                                    bus_Data = new BusData
-                                    {
-                                        SubnetID = 111,
-                                        DeviceID = 9,
-                                        LoopID = 1,
-                                    },
-                                });
-                                instance.functionList.lights.Add(new Light()
+                                    SubnetID = 42,
+                                    DeviceID = 8,
+                                    LoopID = 1,
+                                },
+                            });
+                            instance.functionList.lights.Add(new Light()
+                            {
+                                sid = "12341212345678901234560401020002",
+                                name = "璋冨厜鐏�",
+                                trait = "brightness",
+                                roomIdList = new List<string>() { "0001" },
+                                lastState = "20%",
+                                bus_Data = new BusData
                                 {
-                                    sid = "12341212345678901234560400000002",
-                                    name = "瀹㈠巺鐏�",
-                                    trait = "brightness",
-                                    roomIdList = new List<string>() { "0001" },
-                                    lastState = "20%",
-                                    bus_Data = new BusData
-                                    {
-                                        SubnetID = 111,
-                                        DeviceID = 2,
-                                        LoopID = 1,
-                                    },
+                                    SubnetID = 111,
+                                    DeviceID = 2,
+                                    LoopID = 1,
+                                },
 
-                                });
-                                instance.functionList.curtains.Add(new Curtain()
+                            });
+                            instance.functionList.curtains.Add(new Curtain()
+                            {
+                                sid = "12341212345678901234560502010003",
+                                name = "绐楀笜妯″潡",
+                                roomIdList = new List<string>() { "0001" },
+                                trait = "curtain",
+                                lastState = "寮�",
+                                bus_Data = new BusData
                                 {
-                                    sid = "12341212345678901234560500000003",
-                                    name = "绐楀笜妯″潡",
-                                    roomIdList = new List<string>() { "0001" },
-                                    trait = "curtain",
-                                    lastState = "寮�",
-                                    bus_Data = new BusData
-                                    {
-                                        SubnetID = 42,
-                                        DeviceID = 7,
-                                        LoopID = 1,
-                                    },
-                                });
-                                instance.functionList.curtains.Add(new Curtain()
+                                    SubnetID = 42,
+                                    DeviceID = 7,
+                                    LoopID = 1,
+                                },
+                            });
+                            instance.functionList.curtains.Add(new Curtain()
+                            {
+                                sid = "12341212345678901234560502020011",
+                                name = "寮�鍚堝笜",
+                                roomIdList = new List<string>() { "0001" },
+                                trait = "curtaintype",
+                                lastState = "20%",
+                                bus_Data = new BusData
                                 {
-                                    sid = "12341212345678901234560500000011",
-                                    name = "寮�鍚堝笜",
-                                    roomIdList = new List<string>() { "0001" },
-                                    trait = "curtaintype",
-                                    lastState = "20%",
-                                    bus_Data = new BusData
-                                    {
-                                        SubnetID = 42,
-                                        DeviceID = 7,
-                                        LoopID = 11,
-                                    },
-                                });
-                                instance.functionList.curtains.Add(new Curtain()
+                                    SubnetID = 42,
+                                    DeviceID = 7,
+                                    LoopID = 11,
+                                },
+                            });
+                            instance.functionList.curtains.Add(new Curtain()
+                            {
+                                sid = "12341212345678901234560502030012",
+                                name = "鍗峰笜",
+                                roomIdList = new List<string>() { "0001" },
+                                trait = "rollingshutter",
+                                lastState = "20%",
+                                bus_Data = new BusData
                                 {
-                                    sid = "12341212345678901234560500000012",
-                                    name = "鍗峰笜",
-                                    roomIdList = new List<string>() { "0001" },
-                                    trait = "rollingshutter",
-                                    lastState = "20%",
-                                    bus_Data = new BusData
-                                    {
-                                        SubnetID = 42,
-                                        DeviceID = 7,
-                                        LoopID = 12,
-                                    },
-                                });
-                                instance.functionList.floorHeatings.Add(new FloorHeating()
+                                    SubnetID = 42,
+                                    DeviceID = 7,
+                                    LoopID = 12,
+                                },
+                            });
+                            instance.functionList.floorHeatings.Add(new FloorHeating()
+                            {
+                                sid = "12341212345678901234560704010004",
+                                name = "鍦扮儹",
+                                roomIdList = new List<string>() { "0001" },
+                                lastState = ""
+                            });
+                            instance.functionList.lights.Add(new Light()
+                            {
+                                sid = "12341212345678901234560401010005",
+                                name = "澶у悐鐏�",
+                                trait = "on_off",
+                                roomIdList = new List<string>() { "0001" },
+                                bus_Data = new BusData
                                 {
-                                    sid = "12341212345678901234560700000004",
-                                    name = "鍦扮儹",
-                                    roomIdList = new List<string>() { "0001" },
-                                    lastState = ""
-                                });
-                                instance.functionList.lights.Add(new Light()
+                                    SubnetID = 42,
+                                    DeviceID = 6,
+                                    LoopID = 1,
+                                },
+                            });
+                            instance.functionList.lights.Add(new Light()
+                            {
+                                sid = "12341212345678901234560401030006",
+                                name = "RGB鐏�",
+                                trait = "brightness,color",
+                                roomIdList = new List<string>() { "0001" },
+                                bus_Data = new BusData
                                 {
-                                    sid = "12341212345678901234560400000005",
-                                    name = "瀹㈠巺澶х伅",
-                                    trait = "on_off",
-                                    roomIdList = new List<string>() { "0001" },
-                                    bus_Data = new BusData
-                                    {
-                                        SubnetID = 111,
-                                        DeviceID = 6,
-                                        LoopID = 1,
-                                    },
-                                });
-                                instance.functionList.lights.Add(new Light()
-                                {
-                                    sid = "12341212345678901234560400000006",
-                                    name = "瀹㈠巺RGB鐏�",
-                                    trait = "brightness,color",
-                                    roomIdList = new List<string>() { "0001" },
-                                    bus_Data = new BusData
-                                    {
-                                        SubnetID = 42,
-                                        DeviceID = 4,
-                                        LoopID = 1,
-                                    },
-                                });
-                                instance.SaveResidenceData();
-                            }
+                                    SubnetID = 42,
+                                    DeviceID = 4,
+                                    LoopID = 1,
+                                },
+                            });
+                            instance.SaveResidenceData();
+                        }
 
 #endif
                         //})
@@ -236,6 +254,10 @@
             }
         }
 
+        /// <summary>
+        /// 浣忓畢鍥剧墖
+        /// </summary>
+        public string residenceImage;
         /// <summary>
         /// 浣忓畢鏁版嵁鏄惁瀛樺湪鍙樺寲
         /// </summary>
@@ -266,20 +288,35 @@
         {
             new System.Threading.Thread(() =>
             {
-                foreach (var function in functionList.functions)
+                try
                 {
-                    System.Threading.Thread.Sleep(100);
-                    if (function.bus_Data != null)
+                    foreach (var function in functionList.functions)
                     {
-                        if (function.functionCategory == FunctionType.Light)
+                        System.Threading.Thread.Sleep(100);
+                        if (function.bus_Data != null)
                         {
-                            Control.Send("read", function);
+                            switch (function.functionCategory)
+                            {
+                                case FunctionCategory.Light:
+                                    Control.Send(CommandType_A.read, function);
+                                    break;
+                                case FunctionCategory.Curtain:
+                                    Control.Send(CommandType_A.read, function);
+                                    break;
+                                case FunctionCategory.AC:
+                                    Control.Send(CommandType_A.read, function);
+                                    break;
+                            }
+                        }
+                        else
+                        {
+
                         }
                     }
-                    else
-                    {
-
-                    }
+                }
+                catch (Exception ex)
+                {
+                    MainPage.Log($"Refresh Residence Function Status Error : {ex.Message}");
                 }
             })
             { IsBackground = true }.Start();
@@ -292,21 +329,28 @@
         {
             new System.Threading.Thread(() =>
             {
-                //鍒濆鍖栦綇瀹呭姛鑳芥暟鎹�
-                instance.functionList.GetAllFunction();
-                //鍒濆鍖栦綇瀹呮墍鏈夋埧闂村姛鑳芥暟鎹�
-                foreach (var r in instance.rooms)
+                try
                 {
-                    foreach (var func in instance.functionList.functions)
+                    //鍒濆鍖栦綇瀹呭姛鑳芥暟鎹�
+                    instance.functionList.GetAllFunction();
+                    //鍒濆鍖栦綇瀹呮墍鏈夋埧闂村姛鑳芥暟鎹�
+                    foreach (var r in instance.rooms)
                     {
-                        if (func.roomIdList.Contains(r.sid))
+                        foreach (var func in instance.functionList.functions)
                         {
-                            r.functionData.Add(func);
+                            MainPage.Log($"init room function sid {func.functionCategory.ToString()}:{r.sid}");
+                            if (func.roomIdList.Contains(r.sid))
+                            {
+                                r.functions.Add(func);
+                            }
                         }
                     }
+                }catch(Exception ex)
+                {
+                    MainPage.Log($"Init room function error : {ex.Message}");
                 }
             })
             { IsBackground = true }.Start();
         }
     }
-}
+}
\ No newline at end of file

--
Gitblit v1.8.0