From b9cb076fe6127160c96c35bf9c8cebcffe1d5ccd Mon Sep 17 00:00:00 2001
From: gxc <guoxuecheng@guoxuechengdeMacBook-Pro.local>
Date: 星期五, 10 一月 2020 17:35:23 +0800
Subject: [PATCH] 2020.1.10

---
 ZigbeeApp/Shared/Phone/Device/Room/RoomManagement.cs |  127 ++++++++++++++++++++++++++++++-----------
 1 files changed, 92 insertions(+), 35 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/Device/Room/RoomManagement.cs b/ZigbeeApp/Shared/Phone/Device/Room/RoomManagement.cs
index c6f94e4..a6c927f 100644
--- a/ZigbeeApp/Shared/Phone/Device/Room/RoomManagement.cs
+++ b/ZigbeeApp/Shared/Phone/Device/Room/RoomManagement.cs
@@ -17,13 +17,37 @@
         private FrameLayout bodyFrameLayout;
 
         private Button floorBtn;
+        /// <summary>
+        /// 褰撳墠妤煎眰id
+        /// </summary>
+        private string curFloorId;
 
         public FrameLayout itemView;
+
+        static RoomManagement roomManagement;
+        public static RoomManagement Instance
+        {
+            get
+            {
+                if (roomManagement == null)
+                {
+                    roomManagement = new RoomManagement { };
+                }
+                return roomManagement;
+            }
+        }
+
+        /// <summary>
+        /// 鏄惁鍙互瑙﹀彂鐐瑰嚮浜嬩欢--鏄惁鍙互璺宠浆涓婚〉鎴块棿
+        /// </summary>
+        public bool CanClick = true;
 
         #endregion
 
 
         public Action action;
+
+
 
         public override void RemoveFromParent()
         {
@@ -35,6 +59,8 @@
         /// </summary>
         public void Show()
         {
+            RemoveAll();
+
             AddTop();
 
             AddBodyView(Config.Instance.Home.CurrentFloorId);
@@ -80,6 +106,7 @@
             floorBtn.Text = Config.Instance.Home.GetCurrentFloorName;
             if(Config.Instance.Home.FloorDics.Count>0)
             {
+                curFloorId = Config.Instance.Home.CurrentFloorId;
                 top.topView.AddChidren(floorBtn);
                 top.topView.AddChidren(selectFloorBtn);
             }
@@ -96,9 +123,12 @@
         {
             var floors = new SelectFloor();
             AddChidren(floors);
+            floors.changeFloor = false;
+            floors.CurFloorId = curFloorId;
             floors.Init(599, 161,Direction.Right);
             floors.FloorAction += (floorId) =>
             {
+                curFloorId = floorId;
                 floorBtn.Text = Config.Instance.Home.GetFloorNameById(floorId);
                 AddBodyView(floorId);
             };
@@ -119,51 +149,73 @@
 
             var roomScrolView = new VerticalScrolViewLayout { };
             bodyFrameLayout.AddChidren(roomScrolView);
-            var roomList = Common.Room.CurrentRoom.GetRoomsByFloorId(floorId);
-            for (int i = 0; i < roomList.Count+1; i++)
+            try
             {
-                int xx = 43 + i % 2 * (20 + 487);
-                int yy = 0;
-                if (i == 0 || i == 1)
+                var roomList = Common.Room.CurrentRoom.GetRoomsByFloorId(floorId);
+                if (roomList == null || roomList.Count == 0)
                 {
-                    if (i % 2 == 0)
+                    return;
+                }
+                for (int i = 0; i < roomList.Count + 1; i++)
+                {
+                    int xx = 43 + i % 2 * (20 + 487);
+                    int yy = 0;
+                    if (i == 0 || i == 1)
+                    {
+                        if (i % 2 == 0)
+                        {
+                            itemView = new FrameLayout()
+                            {
+                                Height = Application.GetRealHeight(354 + 58)
+                            };
+                            roomScrolView.AddChidren(itemView);
+                        }
+                        yy = 58;
+                    }
+                    else if (i % 2 == 0)
                     {
                         itemView = new FrameLayout()
                         {
-                            Height = Application.GetRealHeight(354 + 58)
+                            Height = Application.GetRealHeight(354)
                         };
                         roomScrolView.AddChidren(itemView);
                     }
-                    yy = 58;
-                }
-                else if (i % 2 == 0)
-                {
-                    itemView = new FrameLayout()
+
+                    if (i < roomList.Count)
                     {
-                        Height = Application.GetRealHeight(354)
-                    };
-                    roomScrolView.AddChidren(itemView);
-                }
+                        var room = roomList[i];
+                        var roomView = new RoomMainView(xx, yy);
+                        itemView.AddChidren(roomView);
+                        roomView.Init(this, room);
+                        roomView.SetRoomName(room.Name);
+                        roomView.SetRoomIcon(room.BackgroundImageType == 0 ? room.BackgroundImage : System.IO.Path.Combine(Config.Instance.FullPath, room.BackgroundImage));
+                        roomView.ClickBtn.MouseUpEventHandler += (sender, e) =>
+                        {
+                            if (CanClick == false)
+                            {
+                                return;
+                            }
+                            CommonPage.Instance.CloseLeftMenu();
+                            Common.Room.CurrentRoom = room;
+                            Config.Instance.Home.CurrentFloorId = room.FloorId;
+                            UserPage.Instance.Fresh();
+                        };
+                    }
+                    else
+                    {
+                        var roomView = new RoomNoNameMainView(xx, yy);
+                        itemView.AddChidren(roomView);
+                        roomView.Init();
 
-                if (i< roomList.Count)
-                {
-                    var room = roomList[i];
-                    var roomView = new RoomMainView(xx, yy);
-                    itemView.AddChidren(roomView);
-                    roomView.Init();
-                    roomView.SetRoomName(room.Name);
-                    roomView.SetRoomIcon(room.BackgroundImage);
+                        roomView.Icon.MouseUpEventHandler += ShowUnallocatedRoom_MouseUpEvent;
+                        roomView.RoomNameButton.MouseUpEventHandler += ShowUnallocatedRoom_MouseUpEvent;
+                        roomView.iconFL.MouseUpEventHandler += ShowUnallocatedRoom_MouseUpEvent;
+                    }
                 }
-                else
-                {
-                    var roomView = new RoomNoNameMainView(xx, yy);
-                    itemView.AddChidren(roomView);
-                    roomView.Init();
-
-                    roomView.Icon.MouseUpEventHandler += ShowUnallocatedRoom_MouseUpEvent;
-                    roomView.RoomNameButton.MouseUpEventHandler += ShowUnallocatedRoom_MouseUpEvent;
-                    roomView.iconFL.MouseUpEventHandler += ShowUnallocatedRoom_MouseUpEvent;
-                }
+            }
+            catch (Exception ex)
+            {
+                string tt=ex.Message;
             }
         }
 
@@ -172,9 +224,10 @@
         /// <summary>
         /// 鎴块棿绠$悊鐣岄潰
         /// </summary>
-        void RoomPage()
+        public RoomManagement()
         {
             BackgroundColor = ZigbeeColor.Current.GXCBackgroundColor;
+            roomManagement = this;
         }
 
         /// <summary>
@@ -184,6 +237,10 @@
         /// <param name="mouseEventArgs"></param>
         private void ShowUnallocatedRoom_MouseUpEvent(object sender,MouseEventArgs mouseEventArgs)
         {
+            if(CanClick==false)
+            {
+                return;
+            }
             var unalloctedRoom = new UnallocatedRoom();
             AddChidren(unalloctedRoom);
             unalloctedRoom.Show();

--
Gitblit v1.8.0