Revit二次开发之递归实现查找相连接的管道系统

2023-10-30 05:50

本文主要是介绍Revit二次开发之递归实现查找相连接的管道系统,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近有人提出一个问题 ,就是根据选择的一根管道 ,获得与这根管道相连接的管道系统中的其他图元,包括弯头,闸阀等管道附件及管件,那么对于这个问题,我们第一时间想到的就是根据管道和管道附件特有的连接件属性来做判断,从一根管道获得它的一段的连接件,根据连接件获得它的Owner 再根据Owner获得所属的连接件 以此类推的向下查找 直到某个连接件下再也没有其他可连接的图元,这是典型的递推原理,代码和示例图如下:

 

using Autodesk.Revit.UI;

using Autodesk.Revit.DB;

using Autodesk.Revit.Attributes;

using Autodesk.Revit.UI.Selection;

using Autodesk.Revit.DB.Plumbing;

namespace autoMake

{

    [Transaction(TransactionMode.Manual)]

    [Regeneration(RegenerationOption.Manual)]

    class PipeFind : IExternalCommand

    {

        IList(ElementId) listId = new List(ElementId)();

        public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)

        {

            UIApplication uiapp = commandData.Application;

            UIDocument uidoc = uiapp.ActiveUIDocument;

            Document doc = uidoc.Document;

 

            Reference refer = uidoc.Selection.PickObject(ObjectType.Element, "");

            Element elem = doc.GetElement(refer);

            listId.Add(elem.Id);

            Pipe pipe = elem as Pipe;

            XYZ xyz = refer.GlobalPoint;

            Curve curve = (pipe.Location as LocationCurve).Curve;

            XYZ project = curve.Project(xyz).XYZPoint;

            Connector connector = BackPipeNearConnectors(elem, xyz);

            BackAlrefsConnectors(connector);

            uidoc.Selection.SetElementIds(listId);

            return Result.Succeeded;

        }

        ///

        /// 返回管道连接件原点与鼠标拾取点在管道上的投影点最近的那个

        ///

        ///

        ///

        ///

        private Connector BackPipeNearConnectors(Element elem, XYZ xyz)

        {

            Connector conn = null;

            MEPCurve mep = elem as MEPCurve;

            SortedDictionary(double, Connector) dictionary = new SortedDictionary(double, Connector)();

            ConnectorSetIterator connectorSetIterator = mep.ConnectorManager.Connectors.ForwardIterator();

            while (connectorSetIterator.MoveNext())

            {

                Connector connector = connectorSetIterator.Current as Connector;

                if (connector.AllRefs.Size > 0)

                {

                    dictionary.Add(connector.Origin.DistanceTo(xyz), connector);

                }

            }

 

            return dictionary.Values.ElementAt(0);

        }

        ///

        /// 获得连接件上的连接的所有连接件 根据连接件获得图元 根据图元获得连接件 实现递归查询

        ///

        ///

        private void BackAlrefsConnectors(Connector connector)

        {

            Element elem = null;

            ConnectorSetIterator connectorSetIterator = connector.AllRefs.ForwardIterator();

            while (connectorSetIterator.MoveNext())

            {

                Connector connref = connectorSetIterator.Current as Connector;

                if (connref.Origin.IsAlmostEqualTo(connector.Origin))

                {

                    elem = connref.Owner;

                    break;

                }

            }

 

            if (elem.GetType().ToString() == "Autodesk.Revit.DB.Plumbing.Pipe")

            {

                listId.Add(elem.Id);

 

                Connector connector1 = BackPipeConnectors(elem, connector);

                if (connector1.IsConnected)

                {

                    BackAlrefsConnectors(connector1);

                }

            }

            else if (elem.GetType().ToString() == "Autodesk.Revit.DB.FamilyInstance")

            {

                listId.Add(elem.Id);

                Connector connector1 = BackInstanceConnectors(elem as FamilyInstance, connector);

                if (connector1.IsConnected)

                {

                    BackAlrefsConnectors(connector1);

                }

            }

 

        }

        ///

        /// 返回管道上指定连接件

        ///

        ///

        ///

        ///

        private Connector BackPipeConnectors(Element elem, Connector conn)

        {

            Connector connector = null;

            MEPCurve mep = elem as MEPCurve;

            ConnectorSetIterator connectorSetIterator = mep.ConnectorManager.Connectors.ForwardIterator();

            while (connectorSetIterator.MoveNext())

            {

                Connector connectorset = connectorSetIterator.Current as Connector;

                if (connectorset.AllRefs.Size > 0)

                {

                    if (!connectorset.Origin.IsAlmostEqualTo(conn.Origin))

                    {

                        connector = connectorset;

                        break;

                    }

                }

            }

 

            return connector;

        }

        ///

        /// 返回弯头 闸阀等实例的指定连接件

        ///

        ///

        ///

        ///

        private Connector BackInstanceConnectors(FamilyInstance instance, Connector conn)

        {

            Connector connector = null;

            MEPModel model = instance.MEPModel as MEPModel;

            ConnectorSetIterator connectorSetIterator = model.ConnectorManager.Connectors.ForwardIterator();

            while (connectorSetIterator.MoveNext())

            {

                Connector connectorset = connectorSetIterator.Current as Connector;

                if (connectorset.AllRefs.Size > 0)

                {

                    if (!connectorset.Origin.IsAlmostEqualTo(conn.Origin))

                    {

                        connector = connectorset;

                        break;

                    }

                }

            }

            return connector;

        }

    }

    public class PipeFilters : ISelectionFilter

    {

        public bool AllowElement(Element elem)

        {

            return elem is Pipe;

        }

 

        public bool AllowReference(Reference reference, XYZ position)

        {

            return false;

        }

    }

}

Revit二次开发之递归实现查找相连接的管道系统

这篇关于Revit二次开发之递归实现查找相连接的管道系统的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/305988

相关文章

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

Django中使用SMTP实现邮件发送功能

《Django中使用SMTP实现邮件发送功能》在Django中使用SMTP发送邮件是一个常见的需求,通常用于发送用户注册确认邮件、密码重置邮件等,下面我们来看看如何在Django中配置S... 目录1. 配置 Django 项目以使用 SMTP2. 创建 Django 应用3. 添加应用到项目设置4. 创建

java poi实现Excel多级表头导出方式(多级表头,复杂表头)

《javapoi实现Excel多级表头导出方式(多级表头,复杂表头)》文章介绍了使用javapoi库实现Excel多级表头导出的方法,通过主代码、合并单元格、设置表头单元格宽度、填充数据、web下载... 目录Java poi实现Excel多级表头导出(多级表头,复杂表头)上代码1.主代码2.合并单元格3.

Python读取TIF文件的两种方法实现

《Python读取TIF文件的两种方法实现》本文主要介绍了Python读取TIF文件的两种方法实现,包括使用tifffile库和Pillow库逐帧读取TIFF文件,具有一定的参考价值,感兴趣的可以了解... 目录方法 1:使用 tifffile 逐帧读取安装 tifffile:逐帧读取代码:方法 2:使用

Spring Boot实现多数据源连接和切换的解决方案

《SpringBoot实现多数据源连接和切换的解决方案》文章介绍了在SpringBoot中实现多数据源连接和切换的几种方案,并详细描述了一个使用AbstractRoutingDataSource的实... 目录前言一、多数据源配置与切换方案二、实现步骤总结前言在 Spring Boot 中实现多数据源连接

Mybatis拦截器如何实现数据权限过滤

《Mybatis拦截器如何实现数据权限过滤》本文介绍了MyBatis拦截器的使用,通过实现Interceptor接口对SQL进行处理,实现数据权限过滤功能,通过在本地线程变量中存储数据权限相关信息,并... 目录背景基础知识MyBATis 拦截器介绍代码实战总结背景现在的项目负责人去年年底离职,导致前期规

使用 Python 和 LabelMe 实现图片验证码的自动标注功能

《使用Python和LabelMe实现图片验证码的自动标注功能》文章介绍了如何使用Python和LabelMe自动标注图片验证码,主要步骤包括图像预处理、OCR识别和生成标注文件,通过结合Pa... 目录使用 python 和 LabelMe 实现图片验证码的自动标注环境准备必备工具安装依赖实现自动标注核心

使用Python实现生命之轮Wheel of life效果

《使用Python实现生命之轮Wheeloflife效果》生命之轮Wheeloflife这一概念最初由SuccessMotivation®Institute,Inc.的创始人PaulJ.Meyer... 最近看一个生命之轮的视频,让我们珍惜时间,因为一生是有限的。使用python创建生命倒计时图表,珍惜时间

python-nmap实现python利用nmap进行扫描分析

《python-nmap实现python利用nmap进行扫描分析》Nmap是一个非常用的网络/端口扫描工具,如果想将nmap集成进你的工具里,可以使用python-nmap这个python库,它提供了... 目录前言python-nmap的基本使用PortScanner扫描PortScannerAsync异

基于Redis有序集合实现滑动窗口限流的步骤

《基于Redis有序集合实现滑动窗口限流的步骤》滑动窗口算法是一种基于时间窗口的限流算法,通过动态地滑动窗口,可以动态调整限流的速率,Redis有序集合可以用来实现滑动窗口限流,本文介绍基于Redis... 滑动窗口算法是一种基于时间窗口的限流算法,它将时间划分为若干个固定大小的窗口,每个窗口内记录了该时间