• 最短路径——通过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工具栏中一样的功能,下面展示的是核心代码:

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

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

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

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

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

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

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

  • 相关阅读:
    [UVMC]UVM Connect基础教程
    SpringBoot+Vue实现前后端分离的员工日志管理信息系统
    软件代码坏味道之滥用switch
    10.(Python数模)(预测模型二)LSTM回归网络(1→1)
    消息队列--入门篇
    万应案例精选|抓紧抓实抓细,万应为安全生产全域监管护航
    矩阵分析与应用+张贤达
    RabbitMQ学习总结-延迟消息
    [Spring Cloud] Hystrix通过配置文件统一设置参数/与OpenFeign结合使用
    Redis中的数据类型及与Mysql数据库同步方法
  • 原文地址:https://blog.csdn.net/qq_34366481/article/details/136303451