From 9d75f0401985156299472e66d2fff07a854d9c67 Mon Sep 17 00:00:00 2001
From: qin <a@163.com>
Date: 星期日, 15 十二月 2024 20:19:02 +0800
Subject: [PATCH] 提交文件

---
 HStation.RevitDev/RevitDataExport/Utility/CacheUtil.cs |  191 ++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 168 insertions(+), 23 deletions(-)

diff --git a/HStation.RevitDev/RevitDataExport/Utility/CacheUtil.cs b/HStation.RevitDev/RevitDataExport/Utility/CacheUtil.cs
index 5b57df6..24325f9 100644
--- a/HStation.RevitDev/RevitDataExport/Utility/CacheUtil.cs
+++ b/HStation.RevitDev/RevitDataExport/Utility/CacheUtil.cs
@@ -8,6 +8,9 @@
 using System.IO;
 using System.Linq;
 using System.Windows.Forms;
+using Autodesk.Revit.UI;
+using static System.Windows.Forms.VisualStyles.VisualStyleElement.Window;
+using System.Net.Http;
 
 namespace HStation.RevitDev.RevitDataExport.Utility
 {
@@ -55,7 +58,7 @@
             };
             if (!File.Exists(GlobalResource.RecordFilePath))
             {
-                File.Create(GlobalResource.RecordFilePath);
+                File.Create(GlobalResource.RecordFilePath).Close();
             }
 
             var cache = File.ReadAllText(GlobalResource.RecordFilePath);
@@ -78,47 +81,142 @@
             File.WriteAllText(GlobalResource.RecordFilePath, config);
         }
 
+        public static bool UploadFile(Document _doc, string desc, out string err)
+        {
+            err = "";
+            var tempDir = Path.Combine(Path.GetDirectoryName(GlobalResource.BinDirectory), "temp"); //"d:\\temp";
+            if (!Directory.Exists(tempDir))
+                Directory.CreateDirectory(tempDir);
+            var structFile = tempDir + "\\struct.json";
+            var modelFile = tempDir + "\\model.rvt";
+            var settingFile = tempDir + "\\setting.json";
+            var otherFile = tempDir + "\\struct_others.json";
+
+            try
+            {
+                var title = _doc.Title + "_" + DateTime.Now.ToString("yyyy-MM-dd-HH-mm-ss") + ".ywrvt";
+                var zipFilePath = tempDir + "\\" + title;
+                if (File.Exists(structFile)) File.Delete(structFile);
+
+                if (File.Exists(modelFile)) File.Delete(modelFile);
+                if (!File.Exists(settingFile)) File.Create(settingFile).Close();
+                if (!File.Exists(otherFile)) File.Create(otherFile).Close();
+                File.Copy(_doc.PathName, modelFile);
+                File.Copy(GlobalResource.ExportFilePath, structFile);
+                var strConfig = File.ReadAllText(GlobalResource.SettingFilePath);
+                var ret = Newtonsoft.Json.JsonConvert.DeserializeObject<ConfigSettingModel>(strConfig);
+                var notContains = new List<string>() { "绠¢亾闄勪欢", "绠¢亾", "绠′欢 ", "绠¢亾闄勪欢", "绠¢亾绯荤粺" };
+                var c3 = new Autodesk.Revit.DB.FilteredElementCollector(_doc).WhereElementIsNotElementType();//.WhereElementIsElementType();
+                var c4 = new Autodesk.Revit.DB.FilteredElementCollector(_doc).WhereElementIsElementType();
+
+                c3.Concat(c4);
+                var r = c3.Where(c => c.Category != null && !notContains.Any(c.Category.Name.Contains)).Select(c => new { ID = c.Id.ToString(), Name = c.Name, CategoryName = c.Category.Name, CategoryID = c.Category.Id.ToString() }).Distinct().ToList();
+                var t = JsonHelper.ToJson(r);
+                File.WriteAllText(otherFile, t);
+
+                var setting = new SettingsViewModel() { Version = "1" };
+                File.WriteAllText(settingFile, JsonHelper.ToJson(setting));
+
+                var files = new string[] { structFile, modelFile, settingFile, otherFile };
+                ZipFiles(files, zipFilePath);
+
+                File.Delete(structFile);
+                File.Delete(otherFile);
+                File.Delete(modelFile);
+                File.Delete(settingFile);
+                File.Delete(otherFile);
+                using (var client = new HttpClient())
+                {
+                    var content = new MultipartFormDataContent();
+                    content.Add(new StringContent("寰幆姘碦evit"), "UploadUserName");
+                    content.Add(new StringContent(""), "FileCode");
+                    content.Add(new StringContent(desc), "Description");
+                    content.Add(new ByteArrayContent(File.ReadAllBytes(zipFilePath)), "File", title);
+                    var res = client.PostAsync(ret.UploadUrl, content).Result.Content.ReadAsStringAsync().Result;
+                    var result = JsonHelper.ToObject<HttpResultViewModel>(res);
+                    File.Delete(zipFilePath);
+                    if (result.Code == 0)
+                        return true;
+                    else
+                    {
+                        err = result.Message;
+                        return false;
+                    }
+                }
+            }
+            catch (Exception ex)
+            {
+                File.Delete(structFile);
+                File.Delete(otherFile);
+                File.Delete(modelFile);
+                File.Delete(settingFile);
+                File.Delete(otherFile);
+                err = JsonHelper.ToJson(ex);
+                return false;
+            }
+        }
+
         public static bool ExportZipFile(Document _doc, out string err)
         {
             FolderBrowserDialog dialog = new FolderBrowserDialog();
             err = "";
             if (dialog.ShowDialog() == DialogResult.OK)
             {
+                var tempDir = Path.Combine(Path.GetDirectoryName(GlobalResource.BinDirectory), "temp"); //"d:\\temp";
+                if (!Directory.Exists(tempDir))
+                    Directory.CreateDirectory(tempDir);
+                var structFile = tempDir + "\\struct.json";
+                var modelFile = tempDir + "\\model.rvt";
+                var settingFile = tempDir + "\\setting.json";
+                var otherFile = tempDir + "\\struct_others.json";
+                var userFile = GlobalResource.LoginUserFilePath;
+
                 try
                 {
                     var zipFilePath = dialog.SelectedPath + "\\model.ywrvt";
-
-                    var tempDir = "d:\\temp";
-                    if (!Directory.Exists(tempDir))
-                        Directory.CreateDirectory(tempDir);
-                    var structFile = tempDir + "\\struct.json";
-                    var modelFile = tempDir + "\\model.rvt";
-                    var settingFile = tempDir + "\\setting.json";
                     if (File.Exists(structFile)) File.Delete(structFile);
+
                     if (File.Exists(modelFile)) File.Delete(modelFile);
                     if (!File.Exists(settingFile)) File.Create(settingFile).Close();
+                    if (!File.Exists(otherFile)) File.Create(otherFile).Close();
                     File.Copy(_doc.PathName, modelFile);
                     File.Copy(GlobalResource.ExportFilePath, structFile);
+
+                    var notContains = new List<string>() { "绠¢亾闄勪欢", "绠¢亾", "绠′欢 ", "绠¢亾闄勪欢", "绠¢亾绯荤粺" };
+                    var c3 = new Autodesk.Revit.DB.FilteredElementCollector(_doc).WhereElementIsNotElementType();//.WhereElementIsElementType();
+                    var c4 = new Autodesk.Revit.DB.FilteredElementCollector(_doc).WhereElementIsElementType();
+
+                    c3.Concat(c4);
+                    var r = c3.Where(c => c.Category != null && !notContains.Any(c.Category.Name.Contains)).Select(c => new { ID = c.Id.ToString(), Name = c.Name, CategoryName = c.Category.Name, CategoryID = c.Category.Id.ToString() }).Distinct().ToList();
+
+                    var t = JsonHelper.ToJson(r);
+                    File.WriteAllText(otherFile, t);
 
                     var setting = new SettingsViewModel() { Version = "1" };
                     File.WriteAllText(settingFile, JsonHelper.ToJson(setting));
 
-                    var files = new string[] { structFile, modelFile, settingFile };
+                    var files = new string[] { structFile, modelFile, settingFile, otherFile, userFile };
                     ZipFiles(files, zipFilePath);
 
                     File.Delete(structFile);
+                    File.Delete(otherFile);
                     File.Delete(modelFile);
                     File.Delete(settingFile);
+                    File.Delete(otherFile);
                     return true;
                 }
-                catch (Exception ex)
-                {
-                    err = JsonHelper.ToJson(ex);
-                    return false;
+                catch (Exception ex)
+                {
+                    File.Delete(structFile);
+                    File.Delete(otherFile);
+                    File.Delete(modelFile);
+                    File.Delete(settingFile);
+                    File.Delete(otherFile);
+                    err = JsonHelper.ToJson(ex);
+                    return false;
                 }
-
             }
-            return true;
+            else return false;
 
         }
 
@@ -164,19 +262,66 @@
             {
                 return;
             }
-            GlobalResource.HideMode = !GlobalResource.HideMode;
-            using (Transaction trans = new Transaction(document, "hide elements"))
+            try
             {
-                trans.Start();
-                if (GlobalResource.HideMode)
+                GlobalResource.HideMode = !GlobalResource.HideMode;
+                using (Transaction trans = new Transaction(document, "hide elements"))
                 {
-                    document.ActiveView.HideElements(ids);
+                    trans.Start();
+                    if (GlobalResource.HideMode)
+                    {
+                        document.ActiveView.HideElements(ids);
+                    }
+                    else
+                    {
+                        document.ActiveView.UnhideElements(ids);
+                    }
+                    trans.Commit();
                 }
-                else
+            }
+            catch (Exception ex)
+            {
+                TaskDialog.Show("閿欒", "鏄鹃殣澶辫触锛屽彲鑳藉瓨鍦ㄤ笉鑳借缃殣钘忕殑鏋勪欢锛�");
+            }
+        }
+
+        public static void HideOrShowOtherModels(Document document)
+        {
+            if (document == null) { return; }
+
+            //var ids = GlobalResource.RevitModels.GetOtherIds()?.Select(x => new ElementId(int.Parse(x))).ToList();
+            var notContains = new List<string>() { "鍥句緥鏋勪欢", "妤兼澘", "澧�", "鏍忔潌鎵舵墜", "妤兼" };
+            var nameContains = new List<string>() { "娣峰嚌鍦熷簳搴�" };
+            var c3 = new Autodesk.Revit.DB.FilteredElementCollector(document).WhereElementIsNotElementType();//.WhereElementIsElementType();
+            var c4 = new Autodesk.Revit.DB.FilteredElementCollector(document).WhereElementIsElementType();
+
+            c3.Concat(c4);
+            //var ids = c3.Where(c => c.Category != null && !notContains.Any(c.Category.Name.Contains)).Select(c => new ElementId(int.Parse(c.Id.ToString()))).Distinct().ToList();
+            var ids = c3.Where(c => (c.Category != null && notContains.Any(c.Category.Name.Contains)) || nameContains.Any(c.Name.Contains)).Select(c => new ElementId(int.Parse(c.Id.ToString()))).Distinct().ToList();
+            if (ids.Count == 0)
+            {
+                return;
+            }
+            try
+            {
+                GlobalResource.IsOtherHidden = !GlobalResource.IsOtherHidden;
+                using (Transaction trans = new Transaction(document, "hide other elements"))
                 {
-                    document.ActiveView.UnhideElements(ids);
+                    trans.Start();
+                    if (GlobalResource.IsOtherHidden)
+                    {
+                        document.ActiveView.HideElements(ids);
+                    }
+                    else
+                    {
+                        document.ActiveView.UnhideElements(ids);
+                    }
+                    trans.Commit();
                 }
-                trans.Commit();
+            }
+            catch (Exception ex)
+            {
+                //TaskDialog.Show("閿欒", "鏄鹃殣澶辫触锛屽彲鑳藉瓨鍦ㄤ笉鑳借缃殣钘忕殑鏋勪欢锛�");
             }
         }
     }

--
Gitblit v1.9.3