Files
ShrlAlgoToolkit/ShrlAlgo.Addin.Test/CheckCollision.cs

94 lines
3.5 KiB
C#
Raw Normal View History

2024-10-08 16:21:39 +08:00
using System.IO;
2024-09-22 11:05:41 +08:00
using System.Text;
using Autodesk.Revit.Attributes;
using Autodesk.Revit.DB;
using Autodesk.Revit.UI;
namespace ShrlAlgo.Addin.Test
2024-09-22 11:05:41 +08:00
{
[Transaction(TransactionMode.Manual)]
[Regeneration(RegenerationOption.Manual)]
internal class CheckCollision : IExternalCommand
{
public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
{
//程序UI界面
2024-10-08 16:21:39 +08:00
var uiapp = commandData.Application;
2024-09-22 11:05:41 +08:00
//获取元素(选择) 显示元素 视图(活动视图)管理(对象)
2024-10-08 16:21:39 +08:00
var uidoc = uiapp.ActiveUIDocument;
2024-09-22 11:05:41 +08:00
//获取位置和场地 视图(多个视图)管理 获取元素Revit 项目里的全部元素)
2024-10-08 16:21:39 +08:00
var doc = uidoc.Document;
2024-09-22 11:05:41 +08:00
//当前视图
2024-10-08 16:21:39 +08:00
var view = doc.ActiveView;
var collector = new FilteredElementCollector(doc, view.Id)
2024-09-22 11:05:41 +08:00
.OfClass(typeof(MEPCurve))
.WhereElementIsNotElementType().ToList();
// 检查管线之间的碰撞
2024-10-08 16:21:39 +08:00
var collisions = CheckPipeCollisionsParallel(doc, collector);
2024-09-22 11:05:41 +08:00
// 显示碰撞结果
ShowCollisionResults(collisions);
return Result.Succeeded;
}
public List<Tuple<Element, Element>> CheckPipeCollisionsParallel(Document doc, List<Element> pipes)
{
2024-10-08 16:21:39 +08:00
var collisions = new List<Tuple<Element, Element>>();
2024-09-22 11:05:41 +08:00
// 使用 Parallel.For 并行检查碰撞
Parallel.For(0, pipes.Count, i =>
{
2024-10-08 16:21:39 +08:00
for (var j = i + 1; j < pipes.Count; j++)
2024-09-22 11:05:41 +08:00
{
2024-10-08 16:21:39 +08:00
var pipe1 = pipes[i];
var pipe2 = pipes[j];
2024-09-22 11:05:41 +08:00
// 使用 ElementIntersectsElementFilter 检查碰撞
2024-10-08 16:21:39 +08:00
var filter = new ElementIntersectsElementFilter(pipe1);
var collector = new FilteredElementCollector(doc, [pipe2.Id]);
2024-09-22 11:05:41 +08:00
collector.WherePasses(filter);
if (collector.Any())
{
// 如果检测到碰撞,记录下来
lock (collisions)
{
collisions.Add(new Tuple<Element, Element>(pipe1, pipe2));
}
}
}
});
return collisions;
}
public void ShowCollisionResults(List<Tuple<Element, Element>> collisions)
{
if (collisions.Count == 0)
{
TaskDialog.Show("碰撞检查", "未发现碰撞");
}
else
{
2024-10-08 16:21:39 +08:00
var message = new StringBuilder();
2024-09-22 11:05:41 +08:00
message.AppendLine("发现碰撞:");
2024-10-08 16:21:39 +08:00
foreach (var collision in collisions)
2024-09-22 11:05:41 +08:00
{
message.AppendLine($"管线 {collision.Item1.Id} 与管线 {collision.Item2.Id} 发生碰撞");
}
ExportCollisionResultsToFile(message.ToString());
//TaskDialog.Show("碰撞检查", message.ToString());
}
}
public void ExportCollisionResultsToFile(string content)
{
// 获取桌面路径
2024-10-08 16:21:39 +08:00
var desktopPath = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
2024-09-22 11:05:41 +08:00
// 创建文件路径
2024-10-08 16:21:39 +08:00
var filePath = Path.Combine(desktopPath, "碰撞检查.txt");
2024-09-22 11:05:41 +08:00
// 写入文件
File.WriteAllText(filePath, content);
}
}
}