最短路径——通过Dynamo批量创建行进路线

今天我们来聊聊Revit2020新增的一个功能——布线分析,这个功能还是挺有意思的,只是需要”桌子“以后多开放点API就好了,今天我们就简单的试用一下这个功能。
 

打开Revit2020我们在分析选项卡下,最右侧可以找到布线分析功能栏,里面有行进路径功能,我们点击这命令,随便在两个房间点两个点,他会自动生成两点间的最短行进路线。

从上图我们看到,他会自动穿过房间的门,连接点击的两个点,并计算最短路径。因为在布线分析的默认设置里,不考虑门作为障碍物,是可以穿过的,而其他类别的图元,都作为障碍物,必须躲避。

由上图,我们可以看到,默认是勾选了门类别不作为障碍物,并且这里可以设置障碍物高度的影响范围,在上图最底部。

————华丽的分割线—————

前面我们介绍的是Revit2020新增的功能,这样一个一个点,肯定是满足不了我们的需求的,所以嘛,重复操作,当然是通过Dynamo来完成。

第一步,我们要查下API手册,看看这个新增的功能,有哪些可用的API。

打开前几次文章介绍的apidocs.co页面,搜索pathoftravel,我们可以快速找到PathOfTravel Class类,在它下面的Member里展示了他的所有Methods,如下图:

这里我们看到有个

图标的,就是创建的方法,这里我们选择一个最简答的方法来介绍,就是Create Method (View, XYZ, XYZ),在视图中通过两个点来创建行进路线。

第二步,我们看下他的基本语法:

由上图可以看到,语法也很简单,PathOfTravel .Create(View, XYZ, XYZ)。

第三步,我们创建一个Python Script节点,给两个点的输入,然后获取当前打开的Document就行了。

第四步,获取两个点作为输入点就行,我选个房间中点,然后在放置一个人,分别获取他俩的location即可。

如下图:

运行结果如下图:

到这里,我们实现了Revit2020工具栏中一样的功能,下面展示的是核心代码:

# Copyright(c) 2010, 九哥BIMer
doc = DocumentManager.Instance.CurrentDBDocument
firstPoint = IN[0].ToXyz()
roomPoints = IN[1].ToXyz()
TransactionManager.Instance.EnsureInTransaction(doc)
path = PathOfTravel.Create(doc.ActiveView,firstPoint,roomPoints)
TransactionManager.Instance.TransactionTaskDone()
OUT = path

至于如何批量操作,只需要在代码里加一个for循环即可,这里我就不再赘述了,作为大家自己练习的内容吧,有不明白的,小伙伴们可以给我留言哦~~
 

接下来给大家展示下最终效果:

如上图,大家可以看到,我这里生成的行进路线是彩色,因为我们可以对它添加过滤器,我是根据路径的长短设置了不同的颜色,这里大家可以根据需求设置,如下图:

接下来,我们还可以制作行进路线的明细表,它在线类别下面,可以选择的属性目目前还比较少,如下图:

我这里随便选择了几个,生成了一个明细表,如下图:

好了,我今天的就分享就到这里了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

九哥BIMer

予人玫瑰,手有余香

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值