From 66a9965c44ecc32a6696abca876ab9d1cd091584 Mon Sep 17 00:00:00 2001
From: gxc <guoxuecheng@guoxuechengdeMacBook-Pro.local>
Date: 星期五, 28 二月 2020 15:25:13 +0800
Subject: [PATCH] 2020.2.28

---
 ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs |  910 ++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 778 insertions(+), 132 deletions(-)

diff --git a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs
index 0970bc3..8b0d4e2 100755
--- a/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs
+++ b/ZigbeeApp/Shared/Phone/UserCenter/CommonBase/Logic/HdlShardLogic.cs
@@ -1,6 +1,9 @@
 锘縰sing Shared.Common;
 using System;
 using System.Collections.Generic;
+using System.Collections.Specialized;
+using System.IO;
+using System.Net;
 using System.Text;
 using System.Threading.Tasks;
 using ZigBee.Device;
@@ -36,6 +39,11 @@
                 m_Current = value;
             }
         }
+        /// <summary>
+        /// 鍒嗕韩鐨勮澶囨枃浠�(key:璁惧涓婚敭,value:璁惧鏂囦欢)
+        /// </summary>
+        private Dictionary<string, string> dicShardDeviceFile = new Dictionary<string, string>();
+
         #endregion
 
         #region 鈻� 鑾峰彇鍒嗕韩鏂囦欢_______________________
@@ -45,13 +53,13 @@
         /// </summary>
         /// <param name="listDistributedMark"></param>
         /// <returns></returns>
-        public async Task<List<string>> SetShardFileToLocation(List<string> listDistributedMark)
+        private async Task<List<string>> SetShardFileToLocation(List<string> listDistributedMark)
         {
             if (listDistributedMark.Count == 0)
             {
                 return new List<string>();
             }
-            ProgressBar.SetMaxValue(listDistributedMark.Count);
+            int listMarkCount = listDistributedMark.Count;
 
             List<string> listFile = new List<string>();
             //鏂囦欢澶�
@@ -61,8 +69,9 @@
             Shared.Common.CommonPage.BackKeyCanClick = false;
             UserCenterResourse.Option.AppCanSignout = false;
 
-            foreach (string keys in listDistributedMark)
+            for (int i = 0; i < listDistributedMark.Count; i++)
             {
+                string keys = listDistributedMark[i];
                 var dataPra = new { DistributedMark = keys, HouseDistributedMark = Common.Config.Instance.Home.Id, IsOtherAccountControl = Common.Config.Instance.isAdministrator };
                 var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/GetOneShareData", false, dataPra);
                 if (result == null)
@@ -78,7 +87,7 @@
                 //淇濆瓨鍒版寚瀹氭枃浠跺す涓�
                 Global.WriteFileToDirectoryByBytes(strDir, dataResult.ShareName, dataResult.ShareDataBytes);
                 //璁剧疆杩涘害鍊�
-                ProgressBar.SetValue(1);
+                ProgressFormBar.Current.SetValue(i + 1, listMarkCount);
             }
 
             //鍏佽鎸夌郴缁熺殑杩斿洖閿�
@@ -181,6 +190,20 @@
             Shared.IO.FileUtils.WriteFileByBytes(fullName, byteData);
         }
 
+        /// <summary>
+        /// 娣诲姞妤煎眰瀵硅薄鍒扮紦瀛�
+        /// </summary>
+        /// <param name="dic">妤煎眰</param>
+        public void AddShardFile(Dictionary<string, string> dic)
+        {
+            var data = Newtonsoft.Json.JsonConvert.SerializeObject(dic);
+            var byteData = System.Text.Encoding.UTF8.GetBytes(data);
+
+            string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.DownLoadShardDirectory, DirNameResourse.ShardFloorFile);
+            //鍐欏叆鍐呭
+            Shared.IO.FileUtils.WriteFileByBytes(fullName, byteData);
+        }
+
         #endregion
 
         #region 鈻� 鍒犻櫎鍒嗕韩鏂囦欢_______________________
@@ -203,6 +226,7 @@
         /// </summary>
         public void ClearShardDirectory()
         {
+            this.dicShardDeviceFile.Clear();
             //鍒涘缓鏂囦欢澶�
             string strDir = System.IO.Path.Combine(DirNameResourse.LocalMemoryDirectory, DirNameResourse.DownLoadShardDirectory);
             Global.CreateEmptyDirectory(strDir, true);
@@ -224,7 +248,7 @@
             }
 
             //鑾峰彇涓讳汉鍒嗕韩缁欐垚鍛樼殑鏂囦欢鍒楄〃
-            var infoPra = new { DistributedMark = Config.Instance.Guid, HouseDistributedMark = Common.Config.Instance.Home.Id , IsOtherAccountControl = Common.Config.Instance.isAdministrator };
+            var infoPra = new { DistributedMark = Config.Instance.Guid, HouseDistributedMark = Common.Config.Instance.Home.Id, IsOtherAccountControl = Common.Config.Instance.isAdministrator };
             var listNotShow = new List<string>() { "NotSetAgain" };
             var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/GetShareDataBySubAccount", false, infoPra, listNotShow);
             if (string.IsNullOrEmpty(result) == true)
@@ -261,11 +285,9 @@
             //浠庝簯绔幏鍙栦笅鏉ユ枃浠�
             if (listAddMark.Count > 0)
             {
-                //寮哄埗鎸囧畾鏂囨湰闄勫姞淇℃伅锛氬叡浜暟鎹悓姝ヤ腑
-                string msg = Language.StringByID(R.MyInternationalizationString.uShardDataIsSynchronizing);
-                //寮�鍚繘搴︽潯
-                ProgressBar.Show(msg);
-                ProgressBar.SetAppendText(msg);
+                //寮�鍚繘搴︽潯 鍏变韩鏁版嵁鍚屾涓�
+                ProgressFormBar.Current.Start();
+                ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uShardDataIsSynchronizing));
 
                 //灏嗗垎浜殑鏁版嵁瀛樺叆鏈湴(鑾峰彇鐨勬槸鏈湴娌℃湁鐨�)
                 this.ClearShardDirectory();
@@ -273,15 +295,17 @@
                 if (listDbFile == null)
                 {
                     //鍏抽棴
-                    ProgressBar.Close();
+                    ProgressFormBar.Current.Close();
                     return false;
                 }
 
                 //鐢熸垚鏂囦欢
                 foreach (string fileName in listDbFile)
                 {
-                    var data = this.GetShardFileContent(fileName);
-                    Global.WriteFileByBytesByHomeId(fileName, data);
+                    var oldPath = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.DownLoadShardDirectory, fileName);
+                    var newPath = System.IO.Path.Combine(Config.Instance.FullPath, fileName);
+                    System.IO.File.Copy(oldPath, newPath, true);
+
                     if (fileName.StartsWith("Room_") == true)
                     {
                         //鎴块棿鏂囦欢鐗规畩澶勭悊
@@ -309,11 +333,9 @@
                 //鍙湁鎴愬憳鎵嶆湁杩欎釜姒傚康
                 return true;
             }
-            //寮哄埗鎸囧畾鏂囨湰闄勫姞淇℃伅锛氬叡浜暟鎹悓姝ヤ腑
-            string msg = Language.StringByID(R.MyInternationalizationString.uShardDataIsSynchronizing);
-            //寮�鍚繘搴︽潯
-            ProgressBar.Show(msg);
-            ProgressBar.SetAppendText(msg);
+            //寮�鍚繘搴︽潯  鍏变韩鏁版嵁鍚屾涓�
+            ProgressFormBar.Current.Start();
+            ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uShardDataIsSynchronizing));
 
             if (dicUpdateTime == null)
             {
@@ -332,7 +354,7 @@
                 if (string.IsNullOrEmpty(result) == true)
                 {
                     //鍏抽棴
-                    ProgressBar.Close();
+                    ProgressFormBar.Current.Close();
                     return false;
                 }
                 var listShardData = Newtonsoft.Json.JsonConvert.DeserializeObject<List<GetShardInfoResult>>(result);
@@ -347,13 +369,25 @@
             var listLocalFile = Global.FileListByHomeId();
             foreach (string fileName in listLocalFile)
             {
+                if (fileName == DirNameResourse.ShardFloorFile)
+                {
+                    //妤煎眰鏂囦欢
+                    var varData = Global.ReadFileByHomeId(fileName);
+                    var dicFloor = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary<string, string>>(Encoding.UTF8.GetString(varData));
+                    Common.Config.Instance.Home.FloorDics = dicFloor;
+                    Common.Config.Instance.Home.Save(false);
+
+                    Global.DeleteFilebyHomeId(fileName);
+                }
+
                 if (listShardFile.Contains(fileName) == true)
                 {
                     //鏈湴鐨勮繖涓枃浠惰繕鍒嗕韩鐫�,娌℃湁闂
                     continue;
                 }
+
                 //妫�娴嬫湰鍦拌澶囨枃浠�,鏄惁瀛樺湪宸茬粡鍙栨秷浜嗗叡浜簡鐨�
-                if (fileName.StartsWith(Common.LocalDevice.deviceFirstName) == true)
+                if (fileName.StartsWith("Device_") == true)
                 {
                     //鍒犻櫎鎺夎繖涓澶囨枃浠�
                     Global.DeleteFilebyHomeId(fileName);
@@ -398,7 +432,7 @@
             //淇濆瓨鍏ㄩ儴鍒嗕韩鏂囦欢鐨勬洿鏂版棩鏈�
             this.SaveAllShardFileAgoUpdateTime(dicUpdateTime);
             //鍏抽棴
-            ProgressBar.Close();
+            ProgressFormBar.Current.Close();
 
             return true;
         }
@@ -437,6 +471,238 @@
 
         #endregion
 
+        //----------------------------------鍒嗗壊绾�(鏁版嵁棰勫)-------------------------------------------------
+
+        #region 鈻� 鏁版嵁棰勫___________________________
+
+        /// <summary>
+        /// 鑾峰彇鎴愬憳鍏变韩鍒楄〃鐒跺悗淇濆瓨鍒版湰鍦�(鐢ㄥ畬涔嬪悗鏈�濂借皟鐢ㄦ竻绌� ClearShardDirectory鍑芥暟娓呯┖)
+        /// </summary>
+        /// <param name="memberShardInfo">
+        /// <para>鎴愬憳鐨勫垎浜暟鎹�</para>
+        /// <para>濡傛灉涓嶇煡閬撹繖鏄粈涔堜笢瑗�,灏盢ew涓�涓�,鐒跺悗缂撳瓨璧锋潵,璋冪敤鍏朵粬鍑芥暟閮介渶瑕佽繖涓笢瑗�</para>
+        /// <para>New鐨勬椂鍊欒寰楀SubAccountDistributedMark璧嬪��,瀹冩槸鎴愬憳鍒楄〃鎺ュ彛杩斿洖鐨凷ubAccountDistributedMark</para>
+        /// </param>
+        /// <returns></returns>
+        public async Task<bool> GetMemberShardContentListAndSetToLocation(MemberShardInfoData memberShardInfo)
+        {
+            if (memberShardInfo.Refresh == false)
+            {
+                //浠庢湰鍦拌幏鍙栨垚鍛樼殑鍒嗕韩鍒楄〃
+                this.GetMemberShardContentListFromLocal(memberShardInfo);
+                return true;
+            }
+            memberShardInfo.Refresh = false;
+
+            //姝e湪鑾峰彇鍒嗕韩鏁版嵁
+            ProgressFormBar.Current.Start();
+            ProgressFormBar.Current.SetMsg(Language.StringByID(R.MyInternationalizationString.uShardContentGetting));
+
+            var infoPra = new
+            {
+                DistributedMark = memberShardInfo.SubAccountDistributedMark,
+                HouseDistributedMark = Shared.Common.Config.Instance.HomeId,
+                IsOtherAccountControl = Common.Config.Instance.isAdministrator
+            };
+            var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/GetShareDataBySubAccount", false, infoPra);
+            if (result == null)
+            {
+                //鍏抽棴杩涘害鏉�
+                ProgressFormBar.Current.Close();
+                return false;
+            }
+            var listData = Newtonsoft.Json.JsonConvert.DeserializeObject<List<ReceiveShardInfoResult>>(result);
+            //鍏堟竻绌哄叡浜枃浠跺す
+            this.ClearShardDirectory();
+
+            var listMark = new List<string>();
+            foreach (var data in listData)
+            {
+                //鎬ц兘浼樺寲锛氬鏋滄湰鍦版嫢鏈夎繖涓枃浠剁殑璇�,鐩存帴浣跨敤閭d釜鏂囦欢
+                string fileName = data.ShareName;
+                //璁板綍璧峰畠鐨勪富閿�
+                memberShardInfo.dicAllShardKeys[fileName] = data.DistributedMark;
+
+                if (fileName.StartsWith("Room_") == true || fileName.StartsWith("Scene_") == true)
+                {
+                    //鎴块棿鏂囦欢鍜屽満鏅枃浠堕渶瑕侀噸鏂板弽搴忓垪鍖�
+                    listMark.Add(data.DistributedMark);
+                    continue;
+                }
+                if (Shared.Common.Global.IsExistsByHomeId(fileName) == true)
+                {
+                    //鍏朵粬鏂囦欢鐨勮瘽锛屽鏋滄湰鍦板瓨鍦紝鍒欎互鏈湴鏂囦欢涓哄噯
+                    this.AddShardFile(fileName);
+                    continue;
+                }
+                listMark.Add(data.DistributedMark);
+            }
+
+            //灏嗗垎浜殑鏁版嵁瀛樺叆鏈湴,杩斿洖鐨勬槸鏂囦欢鍚嶅瓧(寮傚父鏃惰繑鍥瀗ull)
+            var listFile = await this.SetShardFileToLocation(listMark);
+            if (listFile == null)
+            {
+                //鍏抽棴杩涘害鏉�
+                ProgressFormBar.Current.Close();
+                return false;
+            }
+
+            //浠庢湰鍦拌幏鍙栨垚鍛樼殑鍒嗕韩鍒楄〃
+            this.GetMemberShardContentListFromLocal(memberShardInfo);
+
+            //鍏抽棴杩涘害鏉�
+            ProgressFormBar.Current.Close();
+
+            return true;
+        }
+
+        /// <summary>
+        /// 浠庢湰鍦拌幏鍙栨垚鍛樼殑鍒嗕韩鍒楄〃
+        /// </summary>
+        /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜暟鎹殑缂撳瓨(璋冪敤杩欎釜鍑芥暟浼氬埛鏂拌繖涓彉閲忕殑淇℃伅)</param>
+        private void GetMemberShardContentListFromLocal(MemberShardInfoData memberShardInfo)
+        {
+            memberShardInfo.dicShardRoom = new Dictionary<string, Common.Room>();
+            this.dicShardDeviceFile.Clear();
+
+            var listDeviceFile = new HashSet<string>();
+            var listSceneFile = new HashSet<string>();
+
+            var listFile = this.GetLocalAllShardFile();
+            //鍏堝垵濮嬪寲鎴块棿
+            foreach (string fileName in listFile)
+            {
+                try
+                {
+                    if (fileName.StartsWith("Room_") == true)
+                    {
+                        //鎴块棿鏂囦欢
+                        var byteData = this.GetShardFileContent(fileName);
+                        if (byteData != null)
+                        {
+                            string valueData = System.Text.Encoding.UTF8.GetString(byteData);
+                            var roomTemp = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.Room>(valueData);
+                            memberShardInfo.dicShardRoom[fileName] = roomTemp;
+                        }
+                    }
+                    else if (fileName == DirNameResourse.ShardFloorFile)
+                    {
+                        //妤煎眰鏂囦欢
+                        var byteData = this.GetShardFileContent(fileName);
+                        if (byteData != null)
+                        {
+                            string valueData = System.Text.Encoding.UTF8.GetString(byteData);
+                            memberShardInfo.dicShardFloor = Newtonsoft.Json.JsonConvert.DeserializeObject<Dictionary<string, string>>(valueData);
+                        }
+                    }
+                    else if (fileName.StartsWith("Device_") == true)
+                    {
+                        string[] Arry = fileName.Split(new string[] { "_" }, StringSplitOptions.RemoveEmptyEntries);
+                        string mainKeys = Common.LocalDevice.Current.GetDeviceMainKeys(Arry[2], Convert.ToInt32(Arry[3]));
+                        this.dicShardDeviceFile[mainKeys] = fileName;
+
+                        //璁惧鏂囦欢
+                        listDeviceFile.Add(fileName);
+                    }
+                    else if (fileName.StartsWith("Scene_") == true)
+                    {
+                        //鍦烘櫙鏂囦欢
+                        listSceneFile.Add(fileName);
+                    }
+                }
+                catch (Exception ex) { HdlLogLogic.Current.WriteLog(ex); }
+            }
+
+            //璁剧疆鎴块棿閲岄潰璁惧鐨刄I瀵硅薄(鍥犱负杩欎釜涓滆タ鏄弽搴忓垪鍖栧嚭鏉ョ殑,璁惧UI瀵硅薄鏄笉搴忓垪鍖栧璞�)
+            foreach (var tempRoom in memberShardInfo.dicShardRoom.Values)
+            {
+                //杩樺師璁惧瀵硅薄
+                tempRoom.DeviceUIList.Clear();
+                for (int i = 0; i < tempRoom.DeviceUIFilePathList.Count; i++)
+                {
+                    string deviceFile = tempRoom.DeviceUIFilePathList[i];
+                    //杩欎釜璁惧鏂囦欢鍖归厤寰楀埌鎴块棿
+                    listDeviceFile.Remove(deviceFile);
+                    if (this.IsFileExists(deviceFile) == false)
+                    {
+                        //绉婚櫎鎺夎繖涓笉瀵瑰姴鐨勮矾寰�
+                        tempRoom.DeviceUIFilePathList.RemoveAt(i);
+                        i--;
+                        continue;
+                    }
+                    tempRoom.DeviceUIList.Add(Common.LocalDevice.Current.GetDeviceUI(deviceFile));
+                }
+                //杩樺師鍦烘櫙瀵硅薄
+                tempRoom.SceneUIList.Clear();
+                for (int i = 0; i < tempRoom.SceneUIFilePathList.Count; i++)
+                {
+                    string uiPath = tempRoom.SceneUIFilePathList[i];
+                    //杩欎釜鍦烘櫙鏂囦欢鍖归厤寰楀埌鎴块棿
+                    listSceneFile.Remove(uiPath);
+                    var byteData = this.GetShardFileContent(uiPath);
+                    if (byteData == null)
+                    {
+                        //绉婚櫎鎺夎繖涓笉瀵瑰姴鐨勮矾寰�
+                        tempRoom.SceneUIFilePathList.RemoveAt(i);
+                        i--;
+                        continue;
+                    }
+                    string valueData = System.Text.Encoding.UTF8.GetString(byteData);
+                    var tempUi = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.SceneUI>(valueData);
+                    tempRoom.SceneUIList.Add(tempUi);
+
+                    //鑾峰彇鍦烘櫙閲岄潰鐨勫叏閮ㄧ洰鏍�(2019.11.05杩藉姞鎿嶄綔,鏈夊彲鑳介偅涓澶囨槸鐢卞満鏅祵濂楁潵鐨�,鎵�浠ュ畠鏈夊彲鑳戒笉灞炰簬浠讳綍鎴块棿)
+                    foreach (var data in tempUi.AddSceneMemberDataList)
+                    {
+                        //璁惧
+                        if (data.Type == 0)
+                        {
+                            string mainkey = LocalDevice.Current.GetDeviceMainKeys(data.DeviceAddr, data.Epoint);
+                            if (dicShardDeviceFile.ContainsKey(mainkey) == true )
+                            {
+                                //杩欎釜璁惧鏂囦欢鍖归厤寰楀埌
+                                listDeviceFile.Remove(dicShardDeviceFile[mainkey]);
+                            }
+                        }
+                        if (data.Type == 1)
+                        {
+                            var temp = new SceneUI();
+                            temp.Id = data.ElseScenesId;
+                            //杩欎釜鍦烘櫙鏂囦欢鍖归厤寰楀埌
+                            listSceneFile.Remove(temp.FileName);
+                        }
+                    }
+                }
+            }
+            //濡傛灉瀛樺湪鍖归厤涓嶄笂鐨勬枃浠�
+            if (listDeviceFile.Count != 0 || listSceneFile.Count != 0)
+            {
+                //鍒涘缓涓�涓复鏃舵埧闂存潵瀛樺偍
+                var roomTemp = new Room();
+                roomTemp.Id = "Other";
+                roomTemp.FloorId = "Other";
+                memberShardInfo.dicShardRoom[roomTemp.FileName] = roomTemp;
+                roomTemp.Name = Language.StringByID(R.MyInternationalizationString.uUnallocated);
+                //杩樺師璁惧瀵硅薄
+                foreach (string deviceFile in listDeviceFile)
+                {
+                    roomTemp.DeviceUIFilePathList.Add(deviceFile);
+                    roomTemp.DeviceUIList.Add(Common.LocalDevice.Current.GetDeviceUI(deviceFile));
+                }
+                //杩樺師鍦烘櫙瀵硅薄
+                foreach (string uiPath in listSceneFile)
+                {
+                    var byteData = this.GetShardFileContent(uiPath);
+                    string valueData = System.Text.Encoding.UTF8.GetString(byteData);
+                    var tempUi = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.SceneUI>(valueData);
+                    roomTemp.SceneUIList.Add(tempUi);
+                }
+            }
+        }
+
+
+        #endregion
+
         //----------------------------------鍒嗗壊绾�(涓婁紶鏂扮殑鍒嗕韩)---------------------------------------------
 
         #region 鈻� 鎵ц涓婁紶鏂扮殑鍒嗕韩___________________
@@ -447,10 +713,16 @@
         /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜暟鎹�</param>
         /// <param name="nowRoom">褰撳墠鐨勬埧闂村璞�</param>
         /// <param name="listDevice">閫夋嫨涓婁紶鐨勮澶�</param>
-        /// <param name="listScene">閫夋嫨涓婁紶鐨勫満鏅�</param>
+        /// <param name="listScene">閫夋嫨涓婁紶鐨勫満鏅�(涓嶈鑾峰彇瀹冮噷闈㈢殑缁戝畾鍒楄〃)</param>
+        /// <param name="BarMaxValue">杩涘害鏉$殑鏈�澶у��,濡傛灉涓嶄负-1,鍒欏唴閮ㄤ笉浼氳嚜鍔ㄥ脊鍑鸿繘搴︽潯</param>
+        /// <param name="listCheckFile">鏂囦欢閲嶅涓婁紶妫�娴�</param>
         public async Task<bool> DoUploadSharedContent(MemberShardInfoData memberShardInfo, Common.Room nowRoom,
-            List<CommonDevice> listDevice, List<Common.SceneUI> listScene)
+            List<CommonDevice> listDevice, List<Common.SceneUI> listScene, int BarMaxValue = -1, HashSet<string> listCheckFile = null)
         {
+            if (listDevice.Count == 0 && listScene.Count == 0)
+            {
+                return true;
+            }
             var listCheck = new HashSet<string>();
 
             //鑾峰彇鍦烘櫙閲岄潰宓屽鐨勫瓙璁惧鍜屽瓙鍦烘櫙
@@ -462,36 +734,53 @@
                 this.GetSceneDeviceList(SceneTemp, listCheck, listChirdScene, listChirdDevice);
             }
 
+            //杩欎釜涔熸槸澶囦唤
+            int BackgroundImageType = 0;
+            string BackgroundImage = string.Empty;
+            if (memberShardInfo.dicShardRoom.ContainsKey(nowRoom.FileName) == true)
+            {
+                BackgroundImageType = memberShardInfo.dicShardRoom[nowRoom.FileName].BackgroundImageType;
+                BackgroundImage = memberShardInfo.dicShardRoom[nowRoom.FileName].BackgroundImage;
+            }
             //闃叉鍑虹幇閿欒,鏆傛椂淇濆瓨涓や釜鍒楄〃(铏界劧娌¢偅涔堥夯鐑︼紝涓嶈繃鏃㈢劧宸茬粡杩欐牱鍐欎簡灏辫繖鏍蜂簡)
             var dicBackDevice = new Dictionary<string, List<string>>();
             var dicBackScene = new Dictionary<string, List<string>>();
             //涓存椂澶囦唤鎴块棿璁惧鍒楄〃
             this.BackupRoomDevicelistTemporary(memberShardInfo, dicBackDevice, dicBackScene);
 
-            Common.Room roomTemp = null;
-            if (memberShardInfo.dicShardRoom.ContainsKey(nowRoom.FileName) == false)
-            {
-                //鍏嬮殕涓�涓璞�
-                roomTemp = nowRoom.CloneRoomClass();
-                memberShardInfo.dicShardRoom[nowRoom.FileName] = roomTemp;
-            }
-            roomTemp = memberShardInfo.dicShardRoom[nowRoom.FileName];
-
             //鑾峰彇涓婁紶鐨勬枃浠�,鐒跺悗灏嗘枃浠跺鍒跺埌鎸囧畾鏂囦欢澶�
-            var listFile = this.GetUploadListFile(ref roomTemp, listDevice, listScene, listChirdDevice, listChirdScene);
+            var listDelPic = new List<string>();
+            var listFile = this.GetUploadListFile(memberShardInfo, nowRoom, listDevice, listScene, listChirdDevice, listChirdScene, listDelPic);
 
             //涓嶅厑璁告寜绯荤粺鐨勮繑鍥為敭
             Shared.Common.CommonPage.BackKeyCanClick = false;
             UserCenterResourse.Option.AppCanSignout = false;
 
-            //鎵撳紑杩涘害鏉�
-            ProgressBar.Show();
-            //璁剧疆鏈�澶у��
-            ProgressBar.SetMaxValue(listFile.Count);
+            if (BarMaxValue == -1)
+            {
+                //鎵撳紑杩涘害鏉�
+                ProgressBar.Show();
+                //璁剧疆鏈�澶у��
+                ProgressBar.SetMaxValue(listFile.Count);
+            }
+            else
+            {
+                //璁剧疆鏈�澶у��
+                ProgressBar.SetMaxValue(BarMaxValue);
+            }
+
             //涓婁紶鍒嗕韩
-            var result = await this.DoUploadShardContent(memberShardInfo, nowRoom, listFile);
-            //鍏抽棴杩涘害鏉�
-            ProgressBar.Close();
+            var result = await this.DoUploadShardContent(memberShardInfo, listFile, listCheckFile);
+            if (result == true)
+            {
+                //鍒犻櫎鎸囧畾鑷畾涔夊浘鐗�
+                result = await this.DoDeleteSharedContent(memberShardInfo, listDelPic);
+            }
+            if (BarMaxValue == -1)
+            {
+                //鍏抽棴杩涘害鏉�
+                ProgressBar.Close();
+            }
 
             //鍏佽鎸夌郴缁熺殑杩斿洖閿�
             Shared.Common.CommonPage.BackKeyCanClick = true;
@@ -500,35 +789,90 @@
             if (result == false)
             {
                 //鎭㈠鍘熸暟鎹�
+                if (memberShardInfo.TempRoom == null)
+                {
+                    memberShardInfo.dicShardRoom[nowRoom.FileName].BackgroundImageType = BackgroundImageType;
+                    memberShardInfo.dicShardRoom[nowRoom.FileName].BackgroundImage = BackgroundImage;
+                }
                 this.RecoverRoomDevicelistTemporary(memberShardInfo, dicBackDevice, dicBackScene, listFile);
-                return false;
             }
+            else
+            {
+                //瑕嗙洊鏁版嵁
+                if (memberShardInfo.TempRoom != null)
+                {
+                    memberShardInfo.dicShardRoom[nowRoom.FileName] = memberShardInfo.TempRoom;
+                }
+            }
+            memberShardInfo.TempRoom = null;
 
-            return true;
+            return result;
         }
 
         /// <summary>
         /// 鑾峰彇涓婁紶鐨勬枃浠跺悕
         /// </summary>
-        /// <param name="roomTemp">闇�瑕佷笂浼犲埌浜戠鐨勬埧闂村璞�</param>
-        /// <param name="listDevice">鍒嗕韩鐨勮澶囧垪琛�</param>
-        /// <param name="listScene">鍒嗕韩鐨勫満鏅垪琛�</param>
+        /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜暟鎹�</param>
+        /// <param name="nowRoom">闇�瑕佷笂浼犲埌浜戠鐨勬埧闂村璞�(娉ㄦ剰,杩欎釜鎴块棿鏄富浜虹殑鎴块棿瀵硅薄,鑰屼笉鏄櫄鎷熺殑)</param>
+        /// <param name="listDevice">鍒嗕韩鐨勮澶囧垪琛�(娉ㄦ剰,杩欎釜涓滆タ鏄富浜虹殑)</param>
+        /// <param name="listScene">鍒嗕韩鐨勫満鏅垪琛�(娉ㄦ剰,杩欎釜涓滆タ鏄富浜虹殑)</param>
         /// <param name="listChirdDevice">鍦烘櫙閲岄潰閫掑綊鑾峰彇鐨勮澶�</param>
         /// <param name="listChirdScene">鍦烘櫙閲岄潰閫掑綊鑾峰彇鐨勫満鏅�</param>
+        /// <param name="listDelPic">闇�瑕佸垹闄ょ殑鍥剧墖</param>
         /// <returns></returns>
-        private List<string> GetUploadListFile(ref Common.Room roomTemp, List<CommonDevice> listDevice, List<Common.SceneUI> listScene,
-            List<CommonDevice> listChirdDevice, List<Common.SceneUI> listChirdScene)
+        private List<string> GetUploadListFile(MemberShardInfoData memberShardInfo, Common.Room nowRoom, List<CommonDevice> listDevice, List<Common.SceneUI> listScene,
+            List<CommonDevice> listChirdDevice, List<Common.SceneUI> listChirdScene, List<string> listDelPic)
         {
             var listFile = new List<string>();
-            var listOtaCheck = new List<string>();
+
+            Common.Room roomTemp = null;
+            if (memberShardInfo.dicShardRoom.ContainsKey(nowRoom.FileName) == false)
+            {
+                //鍏嬮殕涓�涓璞�
+                roomTemp = nowRoom.CloneRoomClass();
+                memberShardInfo.TempRoom = roomTemp;
+                //鏂板垎浜殑鎴块棿,濡傛灉鍥剧墖鏄嚜瀹氫箟鐨�,骞朵笖杩欎釜鍥剧墖鏄瓨鍦ㄧ殑,鍒欎笂浼犲浘鐗�
+                if (roomTemp.BackgroundImageType != 0 && Common.Global.IsExistsByHomeId(roomTemp.BackgroundImage) == true)
+                {
+                    //鑷畾涔夌殑鍥剧墖,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰�
+                    listFile.Add(roomTemp.BackgroundImage);
+                    this.AddShardFile(roomTemp.BackgroundImage);
+                }
+            }
+            else
+            {
+                roomTemp = memberShardInfo.dicShardRoom[nowRoom.FileName];
+                //濡傛灉浜戠鍒嗕韩鐨勬埧闂寸殑鍥剧墖鍜屼富浜虹殑涓嶄竴鏍风殑鏃跺��
+                if (roomTemp.BackgroundImage != nowRoom.BackgroundImage)
+                {
+                    if (roomTemp.BackgroundImageType != 0)
+                    {
+                        //鍒犻櫎鑷畾涔夊浘鐗�
+                        listDelPic.Add(roomTemp.BackgroundImage);
+                    }
+                    if (nowRoom.BackgroundImageType != 0 && Common.Global.IsExistsByHomeId(nowRoom.BackgroundImage) == true)
+                    {
+                        //鑷畾涔夌殑鍥剧墖,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰�
+                        listFile.Add(nowRoom.BackgroundImage);
+                        this.AddShardFile(nowRoom.BackgroundImage);
+                    }
+                    //鍙樻洿鍥剧墖璁剧疆
+                    roomTemp.BackgroundImageType = nowRoom.BackgroundImageType;
+                    roomTemp.BackgroundImage = nowRoom.BackgroundImage;
+                }
+            }
+
             foreach (var device in listDevice)
             {
                 //璁惧
                 listFile.Add(device.FilePath);
-                HdlShardLogic.Current.AddShardFile(device.FilePath);
+                this.AddShardFile(device.FilePath);
+
+                //鍔犵偣缂撳瓨
+                this.dicShardDeviceFile[LocalDevice.Current.GetDeviceMainKeys(device)] = device.FilePath;
 
                 //璁惧鐨刄I
-                var deviceUi = $"DeviceUI_{device.FilePath}";
+                var deviceUi = device.FilePath;
                 if (roomTemp.DeviceUIFilePathList.Contains(deviceUi) == false)
                 {
                     roomTemp.DeviceUIFilePathList.Add(deviceUi);
@@ -539,14 +883,24 @@
             {
                 //璁惧
                 listFile.Add(device.FilePath);
-                HdlShardLogic.Current.AddShardFile(device.FilePath);
+                this.AddShardFile(device.FilePath);
+
+                //鍔犵偣缂撳瓨
+                this.dicShardDeviceFile[LocalDevice.Current.GetDeviceMainKeys(device)] = device.FilePath;
             }
 
             //鍦烘櫙
             foreach (var secene in listScene)
             {
+                if (secene.IconPathType != 0 && Common.Global.IsExistsByHomeId(secene.IconPath) == true)
+                {
+                    //鑷畾涔夌殑鍥剧墖,瀹冨瓨鍦ㄤ簬鏈湴
+                    listFile.Add(secene.IconPath);
+                    this.AddShardFile(secene.IconPath);
+                }
+
                 listFile.Add(secene.FileName);
-                HdlShardLogic.Current.AddShardFile(secene);
+                this.AddShardFile(secene);
 
                 if (roomTemp.SceneUIFilePathList.Contains(secene.FileName) == false)
                 {
@@ -557,24 +911,32 @@
             foreach (var secene in listChirdScene)
             {
                 listFile.Add(secene.FileName);
-                HdlShardLogic.Current.AddShardFile(secene);
+                this.AddShardFile(secene);
             }
             //鎴块棿鏂囦欢涔熺粰杩囧幓
             listFile.Add(roomTemp.FileName);
-            HdlShardLogic.Current.AddShardFile(roomTemp);
+            this.AddShardFile(roomTemp);
+
+            //鍙嶆妤煎眰鏂囦欢寰堝皬,涓�璧风粰杩囧幓鍚�
+            if (roomTemp.FloorId != string.Empty)
+            {
+                memberShardInfo.dicShardFloor[roomTemp.FloorId] = roomTemp.FloorName; ;
+            }
+            this.AddShardFile(memberShardInfo.dicShardFloor);
+            listFile.Add(DirNameResourse.ShardFloorFile);
 
             return listFile;
         }
 
         /// <summary>
-        /// 浠庣綉鍏宠幏鍙栧満鏅殑鐩爣璁惧鍒楄〃
+        /// 鑾峰彇鍦烘櫙鐨勭洰鏍囪澶囧垪琛�(杩欎釜涓嶈兘浠庡垎浜暟鎹腑鑾峰彇)
         /// </summary>
         /// <param name="scene">鍦烘櫙</param>
         /// <param name="listCheck">閲嶅妫�娴嬬敤</param>
         /// <param name="listSceneUI">娣诲姞鍒嗕韩鐨勫満鏅垪琛�</param>
         /// <param name="listDevice">娣诲姞鍒嗕韩鐨勮澶囧垪琛�</param>
         /// <returns></returns>
-        private void GetSceneDeviceList(Common.SceneUI scene, HashSet<string> listCheck, List<Common.SceneUI> listSceneUI, List<CommonDevice> listDevice)
+        public void GetSceneDeviceList(Common.SceneUI scene, HashSet<string> listCheck, List<Common.SceneUI> listSceneUI, List<CommonDevice> listDevice)
         {
             foreach (var data in scene.AddSceneMemberDataList)
             {
@@ -624,57 +986,205 @@
         /// 涓婁紶鍒嗕韩(杩斿洖浜戠鍒嗕韩鏂囦欢鐨勪富閿�:DistributedMark)
         /// </summary>
         /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜暟鎹�</param>
-        /// <param name="nowRoom">褰撳墠鐨勬埧闂村璞�</param>
         /// <param name="listFile">涓婁紶鐨勬枃浠跺悕</param>
+        /// <param name="listCheckFile">閲嶅鏂囦欢涓婁紶妫�娴�</param>
         /// <returns></returns>
-        private async Task<bool> DoUploadShardContent(MemberShardInfoData memberShardInfo, Common.Room nowRoom, List<string> listFile)
+        private async Task<bool> DoUploadShardContent(MemberShardInfoData memberShardInfo, List<string> listFile, HashSet<string> listCheckFile)
         {
             var dicKeys = new Dictionary<string, string>();
             for (int i = 0; i < listFile.Count; i++)
             {
                 string fileName = listFile[i];
-                var info = new UploadShardContent();
-                info.SubAccountDistributedMark = memberShardInfo.SubAccountDistributedMark;
-                info.ShareName = fileName;
-                info.ShareDataBytes = HdlShardLogic.Current.GetShardFileContent(fileName);
-
-                //杩藉姞鍏变韩
-                if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == false)
+                if (listCheckFile != null)
                 {
-                    var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/AddShareData", false, info);
-                    if (string.IsNullOrEmpty(result) == true)
+                    if (listCheckFile.Contains(fileName) == true)
+                    {
+                        //閲嶅鏂囦欢涓嶅啀涓婁紶
+                        continue;
+                    }
+                    listCheckFile.Add(fileName);
+                }
+                if (fileName.EndsWith(".png") == true)
+                {
+                    //涓婁紶鍥剧墖
+                    var result = this.UpLoadBigBackupFileToDB(memberShardInfo, fileName);
+                    if (result == null)
                     {
                         return false;
                     }
-                    //杩欓噷鏈夌偣鐗规畩锛屾帴鍙f槸鐩存帴杩斿洖涓婚敭鍥炴潵鐨勶紝鑰屼笉鏄疛soin
                     dicKeys[fileName] = result;
                 }
                 else
                 {
-                    info.DistributedMark = memberShardInfo.dicAllShardKeys[fileName];
-                    var result = await UserCenterLogic.GetResultStatuByRequestHttps("ZigbeeDataShare/EditShareData", false, info);
-                    if (result == false)
+                    var info = new UploadShardContent();
+                    info.SubAccountDistributedMark = memberShardInfo.SubAccountDistributedMark;
+                    info.ShareName = fileName;
+                    info.ShareDataBytes = HdlShardLogic.Current.GetShardFileContent(fileName);
+
+                    //杩藉姞鍏变韩
+                    if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == false)
                     {
-                        return false;
+                        var result = await UserCenterLogic.GetResponseDataByRequestHttps("ZigbeeDataShare/AddShareData", false, info);
+                        if (result == null)
+                        {
+                            return false;
+                        }
+                        //杩欓噷鏈夌偣鐗规畩锛屾帴鍙f槸鐩存帴杩斿洖涓婚敭鍥炴潵鐨勶紝鑰屼笉鏄疛soin
+                        dicKeys[fileName] = result;
                     }
-                    dicKeys[fileName] = info.DistributedMark;
+                    else
+                    {
+                        info.DistributedMark = memberShardInfo.dicAllShardKeys[fileName];
+                        var result = await UserCenterLogic.GetResultStatuByRequestHttps("ZigbeeDataShare/EditShareData", false, info);
+                        if (result == false)
+                        {
+                            return false;
+                        }
+                        dicKeys[fileName] = info.DistributedMark;
+                    }
                 }
                 //璁剧疆杩涘害鍊�
                 ProgressBar.SetValue(1);
             }
             //濡傛灉娌℃湁閿欒,鍒欐坊鍔犱复鏃剁紦瀛�
-            var listShard = memberShardInfo.dicAllMemberShard[nowRoom.FileName];
             foreach (var keys in dicKeys.Keys)
             {
-                if (listShard.Contains(keys) == false)
-                {
-                    listShard.Add(keys);
-                }
                 memberShardInfo.dicAllShardKeys[keys] = dicKeys[keys];
             }
 
             return true;
         }
+
+        /// <summary>
+        /// 涓婁紶鍥剧墖鏂囦欢鍒颁簯绔�
+        /// </summary>
+        /// <param name="fullDir">鏂囦欢澶圭殑鍏ㄨ矾寰�</param>
+        /// <param name="listPicFile">鍥剧墖鏂囦欢鍒楄〃</param>
+        /// <returns></returns>
+        private string UpLoadBigBackupFileToDB(MemberShardInfoData memberShardInfo, string fileName)
+        {
+            string fullName = UserCenterLogic.CombinePath(DirNameResourse.LocalMemoryDirectory, DirNameResourse.DownLoadShardDirectory, fileName);
+            if (System.IO.File.Exists(fullName) == false)
+            {
+                return null;
+            }
+            var nvc = new NameValueCollection();
+            nvc.Add("ShareName", fileName);
+            nvc.Add("HouseDistributedMark", Common.Config.Instance.Home.Id);
+            nvc.Add("SubAccountDistributedMark", memberShardInfo.SubAccountDistributedMark);
+            nvc.Add("ShareDataBytes", Convert.ToBase64String(this.GetShardFileContent(fileName)));
+
+            //杩藉姞鍏变韩
+            if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == false)
+            {
+                //杩欓噷鏈夌偣鐗规畩锛屾帴鍙f槸鐩存帴杩斿洖涓婚敭鍥炴潵鐨勶紝鑰屼笉鏄疛soin
+                var result = this.DoUpLoadBigBackupFileToDB("ZigbeeDataShare/AddShareData", fullName, nvc);
+                return result;
+            }
+            else
+            {
+                nvc.Add("DistributedMark", memberShardInfo.dicAllShardKeys[fileName]);
+                var result = this.DoUpLoadBigBackupFileToDB("ZigbeeDataShare/EditShareData", fullName, nvc);
+                if (result == null)
+                {
+                    return null;
+                }
+                return memberShardInfo.dicAllShardKeys[fileName];
+            }
+        }
+
+        /// <summary>
+        /// 鎵ц涓婁紶澶ф枃浠�
+        /// </summary>
+        /// <param name="RequestName">璇锋眰鎺ュ彛</param>
+        /// <param name="fullFileName">鏂囦欢鍚嶅瓧(鍚矾寰�)</param>
+        /// <param name="nvc"></param>
+        /// <returns></returns>
+        private string DoUpLoadBigBackupFileToDB(string RequestName, string fullFileName, NameValueCollection nvc)
+        {
+            string paramName = "file";
+            string contentType = "application/octet-stream";
+            string requestUrl = $"{CommonPage.RequestHttpsHost}/{RequestName}";
+
+            string boundary = "---------------------------" + DateTime.Now.Ticks.ToString("x");
+            byte[] boundarybytes = System.Text.Encoding.ASCII.GetBytes("\r\n--" + boundary + "\r\n");
+
+            var wr = (HttpWebRequest)WebRequest.Create(requestUrl);
+            wr.ContentType = "multipart/form-data; boundary=" + boundary;
+            wr.Method = "POST";
+            wr.KeepAlive = true;
+            wr.Credentials = System.Net.CredentialCache.DefaultCredentials;
+
+            wr.Headers.Add(HttpRequestHeader.Authorization, Config.Instance.Token);
+
+            var rs = wr.GetRequestStream();
+
+            string formdataTemplate = "Content-Disposition: form-data; name=\"{0}\"\r\n\r\n{1}";
+            foreach (string key in nvc.Keys)
+            {
+                rs.Write(boundarybytes, 0, boundarybytes.Length);
+                string formitem = string.Format(formdataTemplate, key, nvc[key]);
+                byte[] formitembytes = System.Text.Encoding.UTF8.GetBytes(formitem);
+                rs.Write(formitembytes, 0, formitembytes.Length);
+            }
+            rs.Write(boundarybytes, 0, boundarybytes.Length);
+
+            string headerTemplate = "Content-Disposition: form-data; name=\"{0}\"; filename=\"{1}\"\r\nContent-Type: {2}\r\n\r\n";
+            string header = string.Format(headerTemplate, paramName, fullFileName, contentType);
+            byte[] headerbytes = System.Text.Encoding.UTF8.GetBytes(header);
+            rs.Write(headerbytes, 0, headerbytes.Length);
+
+            var fileStream = new FileStream(fullFileName, FileMode.Open, FileAccess.Read);
+            byte[] buffer = new byte[4096];
+            int bytesRead = 0;
+            while ((bytesRead = fileStream.Read(buffer, 0, buffer.Length)) != 0)
+            {
+                rs.Write(buffer, 0, bytesRead);
+            }
+            fileStream.Close();
+
+            byte[] trailer = System.Text.Encoding.ASCII.GetBytes("\r\n--" + boundary + "--\r\n");
+            rs.Write(trailer, 0, trailer.Length);
+            rs.Close();
+
+            WebResponse wresp = null;
+            try
+            {
+                wresp = wr.GetResponse();
+                Stream stream2 = wresp.GetResponseStream();
+                StreamReader reader2 = new StreamReader(stream2);
+
+                string result = reader2.ReadToEnd();
+
+                var data = Newtonsoft.Json.JsonConvert.DeserializeObject<Shared.Common.ResponseEntity.ResponsePack>(result);
+
+                bool flage = UserCenterLogic.CheckNotEorrorMsg(data, requestUrl);
+                if (flage == true)
+                {
+                    //缂栬緫鐨勬椂鍊欙紝杩欎釜涓滆タ浼氭槸null
+                    return data.ResponseData == null ? "1" : data.ResponseData.ToString();
+                }
+
+                //Log鍑哄姏
+                IMessageCommon.Current.GetMsgByRequestName(RequestName, data, nvc);
+
+                return null;
+            }
+            catch
+            {
+                return null;
+            }
+            finally
+            {
+                if (wresp != null)
+                {
+                    wresp.Close();
+                    wresp = null;
+                }
+                wr = null;
+            }
+        }
+
 
         #endregion
 
@@ -712,7 +1222,7 @@
             foreach (string fileName in listFile)
             {
                 //鐢熸垚鐨勬枃浠跺叏閮ㄥ垹闄�,鎴块棿鏂囦欢鐨勮瘽,涓嬮潰浼氶噸鏂扮敓鎴�
-                HdlShardLogic.Current.DeleteShardFile(fileName);
+                this.DeleteShardFile(fileName);
             }
 
             foreach (var roomKeys in memberShardInfo.dicShardRoom.Keys)
@@ -728,7 +1238,7 @@
                 memberShardInfo.dicShardRoom[roomKeys].SceneUIFilePathList.AddRange(dicBackScene[roomKeys]);
 
                 //瑕嗙洊鎴块棿鏂囦欢
-                HdlShardLogic.Current.AddShardFile(memberShardInfo.dicShardRoom[roomKeys]);
+                this.AddShardFile(memberShardInfo.dicShardRoom[roomKeys]);
             }
         }
 
@@ -759,10 +1269,7 @@
             var listMark = new List<string>();
             //瑕佸垹闄ょ殑鏂囦欢鍚嶅瓧
             var listDeleteFile = new List<string>();
-            //杩欎釜鏄彧绉婚櫎缂撳瓨鐨勬枃浠跺悕瀛�
-            var listDeleteFileEx = new List<string>();
-            //浜戠鐨勬寚瀹氭埧闂寸殑鍏变韩鏂囦欢鍒楄〃
-            var dicShardFile = memberShardInfo.dicAllMemberShard[nowRoom.FileName];
+
             //闄や簡瑕佸垹闄ょ殑鐩爣澶栵紝杩樺垎浜殑鏁版嵁
             var listHadShard = this.GetAllShardedFileNameFromDictionary(memberShardInfo, nowRoom, listDevice, listSceneUI);
 
@@ -772,16 +1279,15 @@
                 string deviceFileName = device.FilePath;
 
                 //绉婚櫎璺緞鍒楄〃
-                roomTemp.DeviceUIFilePathList.Remove($"DeviceUI_{device.FilePath}");
+                roomTemp.DeviceUIFilePathList.Remove(device.FilePath);
                 if (listHadShard.Contains(deviceFileName) == true)
                 {
-                    //鍏朵粬鎴块棿鍒嗕韩鏈夎繖涓澶�,鎵�浠ヤ笉鍒犻櫎杩欎釜璁惧鐨勬牴婧愭枃浠�,鍙槸鎶婃埧闂寸殑璁惧鍒楄〃璺緞绉婚櫎
-                    listDeleteFileEx.Add(deviceFileName);
+                    //鍏朵粬鍦烘櫙鍒嗕韩鏈夎繖涓澶�,鎵�浠ヤ笉鍒犻櫎杩欎釜璁惧鐨勬牴婧愭枃浠�,鍙槸鎶婃埧闂寸殑璁惧鍒楄〃璺緞绉婚櫎
                     continue;
                 }
 
                 //璁惧涓婚敭
-                if (dicShardFile.Contains(deviceFileName) == true)
+                if (memberShardInfo.dicAllShardKeys.ContainsKey(deviceFileName) == true)
                 {
                     listMark.Add(memberShardInfo.dicAllShardKeys[deviceFileName]);
                 }
@@ -798,21 +1304,31 @@
                 //浣嗘槸瀹冪粦瀹氱殑璁惧鐩爣瑕佸垹闄�
                 if (listHadShard.Contains(sceneUI.FileName) == true)
                 {
-                    listDeleteFileEx.Add(sceneUI.FileName);
+                    continue;
                 }
-                else
+                //鑾峰彇瑕佸垹闄ょ殑鍒嗕韩涓婚敭
+                if (memberShardInfo.dicAllShardKeys.ContainsKey(sceneUI.FileName) == true)
                 {
-                    //鑾峰彇瑕佸垹闄ょ殑鍒嗕韩涓婚敭
-                    if (dicShardFile.Contains(sceneUI.FileName) == true)
+                    listMark.Add(memberShardInfo.dicAllShardKeys[sceneUI.FileName]);
+                }
+                listDeleteFile.Add(sceneUI.FileName);
+
+                //鍒犻櫎鑷畾涔夊浘鐗�,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰�
+                if (sceneUI.IconPathType != 0)
+                {
+                    string[] Arry = sceneUI.IconPath.Split(new string[] { "/" }, StringSplitOptions.RemoveEmptyEntries);
+                    string sceneFile = Arry[Arry.Length - 1];
+                    listDeleteFile.Add(sceneFile);
+                    if (memberShardInfo.dicAllShardKeys.ContainsKey(sceneFile) == true)
                     {
-                        listMark.Add(memberShardInfo.dicAllShardKeys[sceneUI.FileName]);
+                        listMark.Add(memberShardInfo.dicAllShardKeys[sceneFile]);
                     }
-                    listDeleteFile.Add(sceneUI.FileName);
                 }
 
                 //鎵ц鍒犻櫎宓屽鐨勮澶�
                 var listTemp = new HashSet<string>();
-                this.GetSceneBindFileName(sceneUI, ref listTemp);
+                var dicBindScene = new Dictionary<string, SceneUI>();
+                this.GetSceneBindFileName(sceneUI, ref listTemp, ref dicBindScene);
                 foreach (var fileName in listTemp)
                 {
                     if (listHadShard.Contains(fileName) == true)
@@ -820,19 +1336,47 @@
                         continue;
                     }
                     //鑾峰彇瑕佸垹闄ょ殑鍒嗕韩涓婚敭
-                    if (dicShardFile.Contains(fileName) == true)
+                    if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == true)
                     {
                         listMark.Add(memberShardInfo.dicAllShardKeys[fileName]);
                     }
                     listDeleteFile.Add(fileName);
+
+                    if (dicBindScene.ContainsKey(fileName) == true && dicBindScene[fileName].IconPathType != 0)
+                    {
+                        //鍒犻櫎鑷畾涔夊満鏅浘鐗�,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰�
+                        string[] Arry = dicBindScene[fileName].IconPath.Split(new string[] { "/" }, StringSplitOptions.RemoveEmptyEntries);
+                        string sceneFile = Arry[Arry.Length - 1];
+                        listDeleteFile.Add(sceneFile);
+                        if (memberShardInfo.dicAllShardKeys.ContainsKey(sceneFile) == true)
+                        {
+                            listMark.Add(memberShardInfo.dicAllShardKeys[sceneFile]);
+                        }
+                    }
                 }
             }
 
             //濡傛灉杩欎釜鎴块棿鐨勫垎浜澶囧拰鍦烘櫙鍏ㄩ儴鍒犻櫎鐨勮瘽,鎶婂垎浜埧闂存枃浠朵篃涓�璧峰垹闄�
             if (roomTemp.DeviceUIFilePathList.Count == 0 && roomTemp.SceneUIFilePathList.Count == 0)
             {
-                listMark.Add(memberShardInfo.dicAllShardKeys[nowRoom.FileName]);
+                //鎴块棿鍒犻櫎
+                if (memberShardInfo.dicAllShardKeys.ContainsKey(nowRoom.FileName) == true)
+                {
+                    listMark.Add(memberShardInfo.dicAllShardKeys[nowRoom.FileName]);
+                }
                 listDeleteFile.Add(nowRoom.FileName);
+
+                if (nowRoom.BackgroundImageType != 0)
+                {
+                    //鍒犻櫎鑷畾涔夋埧闂村浘鐗�,瀹冨瓨鍦ㄤ簬鏈湴,浣嗘槸瀹冩槸鍏ㄨ矾寰�
+                    string[] Arry = nowRoom.BackgroundImage.Split(new string[] { "/" }, StringSplitOptions.RemoveEmptyEntries);
+                    string roomFile = Arry[Arry.Length - 1];
+                    listDeleteFile.Add(roomFile);
+                    if (memberShardInfo.dicAllShardKeys.ContainsKey(roomFile) == true)
+                    {
+                        listMark.Add(memberShardInfo.dicAllShardKeys[roomFile]);
+                    }
+                }
             }
 
             //鎵ц绉婚櫎鍒嗕韩鏁版嵁
@@ -840,21 +1384,28 @@
             //鍚屾鎴块棿鏂囦欢
             if (result == true && listDeleteFile.Contains(roomTemp.FileName) == false)
             {
-                //鎵ц涓婁紶瀵硅薄
+                //鎵ц涓婁紶鎴块棿瀵硅薄
                 result = await this.DoUploadRoomObject(memberShardInfo, roomTemp);
             }
-            if (result == true)
+            //鍚屾妤煎眰鏁版嵁
+            if (result == true && listDeleteFile.Contains(roomTemp.FileName) == true)
             {
-                foreach (var exFile in listDeleteFileEx)
+                int floorCount = 0;
+                foreach (var myRoom in memberShardInfo.dicShardRoom.Values)
                 {
-                    //鍙Щ闄ょ紦瀛�,涓嶅垹闄や簯绔�
-                    if (dicShardFile.Contains(exFile) == true)
-                    {
-                        dicShardFile.Remove(exFile);
-                    }
+                    if (myRoom.FloorId == roomTemp.FloorId) { floorCount++; }
                 }
+                if (floorCount == 0)
+                {
+                    //濡傛灉璇ユゼ灞傚凡缁忓垹瀹屾埧闂翠簡,鍒欐洿鏂版ゼ灞�
+                    memberShardInfo.dicShardFloor.Remove(roomTemp.FloorId);
+                    //鎵ц涓婁紶瀵硅薄
+                    result = await this.DoUploadFloorObject(memberShardInfo);
+                }
+
             }
-            else
+
+            if (result == false)
             {
                 //鎭㈠
                 roomTemp.DeviceUIFilePathList.Clear();
@@ -909,8 +1460,6 @@
             }
             //鍏抽棴杩涘害鏉�
             ProgressBar.Close();
-
-            var dicShard = memberShardInfo.dicAllMemberShard[nowRoom.FileName];
             for (int i = 0; i < listDeleteFile.Count; i++)
             {
                 string fileName = listDeleteFile[i];
@@ -918,16 +1467,50 @@
                 {
                     //鏈�鍚庝竴涓浐瀹氬彲鑳芥槸鎴块棿鏂囦欢,鐩存帴绉婚櫎鏁翠釜瀵硅薄
                     memberShardInfo.dicShardRoom.Remove(fileName);
-                    memberShardInfo.dicAllMemberShard.Remove(fileName);
-                }
-                else
-                {
-                    //绉婚櫎鎸囧畾鏂囦欢
-                    dicShard.Remove(fileName);
                 }
                 memberShardInfo.dicAllShardKeys.Remove(fileName);
 
-                HdlShardLogic.Current.DeleteShardFile(fileName);
+                this.DeleteShardFile(fileName);
+            }
+            return true;
+        }
+
+        /// <summary>
+        /// 鎵ц绉婚櫎鍒嗕韩鏁版嵁
+        /// </summary>
+        /// <param name="memberShardInfo">鎴愬憳鐨勫垎浜唴瀹�</param>
+        /// <param name="listDelFile">鍒犻櫎鐨勬枃浠�</param>
+        /// <returns></returns>
+        private async Task<bool> DoDeleteSharedContent(MemberShardInfoData memberShardInfo, List<string> listDelFile)
+        {
+            if (listDelFile.Count == 0)
+            {
+                return true;
+            }
+
+            var info = new DeleteShardInfo();
+            foreach (var fileName in listDelFile)
+            {
+                if (memberShardInfo.dicAllShardKeys.ContainsKey(fileName) == false)
+                {
+                    //鎴戜篃涓嶇煡閬撲负浠�涔堜細鎵句笉鍒颁富閿�
+                    continue;
+                }
+
+                info.DistributedMark = memberShardInfo.dicAllShardKeys[fileName];
+                //鎵ц鍒犻櫎
+                var result = await UserCenterLogic.GetResultStatuByRequestHttps("ZigbeeDataShare/DeleteShareData", false, info);
+                if (result == false)
+                {
+                    return false;
+                }
+            }
+            for (int i = 0; i < listDelFile.Count; i++)
+            {
+                string fileName = listDelFile[i];
+                memberShardInfo.dicAllShardKeys.Remove(fileName);
+
+                this.DeleteShardFile(fileName);
             }
             return true;
         }
@@ -944,6 +1527,10 @@
         /// <returns></returns>
         private async Task<bool> DoUploadRoomObject(MemberShardInfoData memberShardInfo, Common.Room upDateRoom)
         {
+            if (upDateRoom.Id == "Other")
+            {
+                return true;
+            }
             var info = new EditorShardContent();
             info.DistributedMark = memberShardInfo.dicAllShardKeys[upDateRoom.FileName];
             info.ShareName = upDateRoom.FileName;
@@ -958,7 +1545,37 @@
                 return false;
             }
             //灏嗘埧闂村璞″簭鍒楀寲鍒扮紦瀛�
-            HdlShardLogic.Current.AddShardFile(upDateRoom);
+            this.AddShardFile(upDateRoom);
+
+            return true;
+        }
+
+        #endregion
+
+        #region 鈻� 涓婁紶妤煎眰瀵硅薄_______________________
+
+        /// <summary>
+        /// 涓婁紶妤煎眰瀵硅薄
+        /// </summary>
+        /// <param name="memberShardInfo">鎴愬憳鐨勫叡浜唴瀹�</param>
+        /// <returns></returns>
+        private async Task<bool> DoUploadFloorObject(MemberShardInfoData memberShardInfo)
+        {
+            var info = new EditorShardContent();
+            info.DistributedMark = memberShardInfo.dicAllShardKeys[DirNameResourse.ShardFloorFile];
+            info.ShareName = DirNameResourse.ShardFloorFile;
+            info.SubAccountDistributedMark = memberShardInfo.SubAccountDistributedMark;
+
+            var data = Newtonsoft.Json.JsonConvert.SerializeObject(memberShardInfo.dicShardFloor);
+            var byteData = System.Text.Encoding.UTF8.GetBytes(data);
+            info.ShareDataBytes = byteData;
+            var result = await UserCenterLogic.GetResultStatuByRequestHttps("ZigbeeDataShare/EditShareData", false, info);
+            if (result == false)
+            {
+                return false;
+            }
+            //灏嗘埧闂村璞″簭鍒楀寲鍒扮紦瀛�
+            this.AddShardFile(memberShardInfo.dicShardFloor);
 
             return true;
         }
@@ -993,20 +1610,21 @@
             //鑾峰彇杩樺浜庡垎浜姸鎬佺殑鏂囦欢
             foreach (var roomTemp in memberShardInfo.dicShardRoom.Values)
             {
-                bool flage = roomTemp.FileName == nowRoom.FileName;
                 //璁惧
                 foreach (var deviceUi in roomTemp.DeviceUIFilePathList)
                 {
-                    string deviceFile = deviceUi.Replace("DeviceUI_", string.Empty);
-                    if (flage == true && listDeleteFile.Contains(deviceFile) == true)
+                    string deviceFile = deviceUi;
+                    if (listDeleteFile.Contains(deviceFile) == true)
                     {
-                        //褰撳墠鎴块棿鐨勮鐗规畩澶勭悊锛屽鏋滄槸鍒犻櫎鐩爣锛屽垯涓嶆坊鍔�
+                        //鍥犱负涓�涓洖璺彧鑳藉垎閰嶄竴涓尯鍩�,鎵�浠ュ彲浠ョ洿鎺ュ垽鏂�
                         continue;
                     }
                     if (listShardFile.Contains(deviceFile) == false)
                     {
+                        //杩欎釜鏂囦欢杩樺垎浜潃
                         listShardFile.Add(deviceFile);
                     }
+
                 }
                 //鍦烘櫙
                 foreach (var scene in roomTemp.SceneUIList)
@@ -1016,14 +1634,19 @@
                         //杩欎釜鍦烘櫙宸茬粡琚垹闄�
                         continue;
                     }
-                    if (flage == true && listDeleteFile.Contains(scene.FileName) == true)
+                    if (roomTemp.FileName == nowRoom.FileName)
                     {
-                        //褰撳墠鎴块棿鐨勮鐗规畩澶勭悊锛屽鏋滄槸鍒犻櫎鐩爣锛屽垯涓嶆坊鍔�
-                        continue;
+                        //濡傛灉寰幆鍒颁簡褰撳墠鎴块棿
+                        if (listDeleteFile.Contains(scene.FileName) == true)
+                        {
+                            //濡傛灉鏄垹闄ょ洰鏍囷紝鍒欎笉娣诲姞
+                            continue;
+                        }
                     }
                     //鑾峰彇鍦烘櫙閲岄潰鐨勫叏閮ㄧ洰鏍�
                     var listTemp = new HashSet<string>();
-                    this.GetSceneBindFileName(scene, ref listTemp);
+                    var dicTemp = new Dictionary<string, SceneUI>();
+                    this.GetSceneBindFileName(scene, ref listTemp, ref dicTemp);
 
                     if (listShardFile.Contains(scene.FileName) == false)
                     {
@@ -1043,29 +1666,38 @@
         }
 
         /// <summary>
-        /// 浠庡満鏅璞¢噷闈㈣幏鍙栧叏閮ㄧ殑缁戝畾鐩爣鐨勬枃浠跺悕瀛�
+        /// 浠庡満鏅璞¢噷闈㈣幏鍙栧叏閮ㄧ殑缁戝畾鐩爣鐨勬枃浠跺悕瀛�(杩欓噷闈㈢殑涓滆タ蹇呴』浠庡垎浜暟鎹腑鑾峰彇)
         /// </summary>
         /// <param name="scene">鍦烘櫙</param>
         /// <param name="listFile">鏂囦欢鍒楄〃(閲岄潰瀛樼殑鏄澶嘦I鏂囦欢鍜岃澶囨枃浠跺拰鍦烘櫙鏂囦欢)</param>
-        private void GetSceneBindFileName(Common.SceneUI scene, ref HashSet<string> listFile)
+        /// <param name="dicBindScene">缁戝畾鐨勫満鏅璞�</param>
+        private void GetSceneBindFileName(Common.SceneUI scene, ref HashSet<string> listFile,ref Dictionary<string, SceneUI> dicBindScene)
         {
             foreach (var data in scene.AddSceneMemberDataList)
             {
                 //璁惧
                 if (data.Type == 0)
                 {
-                    var device = Common.LocalDevice.Current.GetDevice(data.DeviceAddr, data.Epoint);
-                    if (device != null&& listFile.Contains(device.FilePath) == false)
+                    string mainkey = LocalDevice.Current.GetDeviceMainKeys(data.DeviceAddr, data.Epoint);
+                    if (dicShardDeviceFile.ContainsKey(mainkey) == true && listFile.Contains(dicShardDeviceFile[mainkey]) == false)
                     {
-                        listFile.Add(device.FilePath);
+                        listFile.Add(dicShardDeviceFile[mainkey]);
                     }
                 }
                 if (data.Type == 1)
                 {
-                    var sceneTemp = Room.CurrentRoom.GetSceneUIBySceneId(data.ElseScenesId);
-                    if (sceneTemp != null && listFile.Contains(sceneTemp.FileName))
+                    var temp = new SceneUI();
+                    temp.Id = data.ElseScenesId;
+                    var byteData = this.GetShardFileContent(temp.FileName);
+                    if (byteData != null)
                     {
-                        listFile.Add(sceneTemp.FileName);
+                        string valueData = System.Text.Encoding.UTF8.GetString(byteData);
+                        var roomTemp = Newtonsoft.Json.JsonConvert.DeserializeObject<Common.SceneUI>(valueData);
+                        dicBindScene[roomTemp.FileName] = roomTemp;
+                        if (listFile.Contains(roomTemp.FileName) == false)
+                        {
+                            listFile.Add(roomTemp.FileName);
+                        }
                     }
                 }
             }
@@ -1144,6 +1776,20 @@
             public string SubAccountDistributedMark = string.Empty;
         }
 
+        /// <summary>
+        /// 鎺ユ敹鍒嗕韩鏁版嵁
+        /// </summary>
+        private class ReceiveShardInfoResult
+        {
+            /// <summary>
+            /// 鏂囦欢鍚嶅瓧
+            /// </summary>
+            public string ShareName = string.Empty;
+            /// <summary>
+            /// 涓婚敭
+            /// </summary>
+            public string DistributedMark = string.Empty;
+        }
 
         #endregion
     }

--
Gitblit v1.8.0