【Revit API】梁的净高分析
原理就是,先从梁的LocationCurve上取点,然后向板的上表面投影。如果有投影点,再从投影点(板上)向梁的底面投影,这时候如果有投影点的话就能得到距离了。
运用该分析的第一条件是梁是在板的上方,勿忘哈!

var beamBottomFaces = FaceUtils.GetBottomFaces(beam); //这个方法是自己封装的
if (null != beamBottomFaces && beamBottomFaces.Any())
{
var beamLocationCurve = beam.Location as LocationCurve;
var beamCurve = beamLocationCurve.Curve;
if (beamCurve != null)
{
if (beamCurve is Line)
{
beamCurve = GetExtLocationCurve(beamCurve); //如果LocationCurve是Line,最好做个延伸算法来延长,不然有些梁因为扣减的话,locationCurve容易缺少一部分
}
var beamPoints = GetPoints(beamCurve, pointRange); //pointRange是取点间隔
if (beamPoints != null && beamPoints.Any())
{
var floorDataList = GetBeamFloorsPairCore(beamBottomFaces, beamPoints, floors); //floors为建筑板
}
}
}
LocationCurve的延伸:
private Curve GetExtLocationCurve(Curve curve)
{
XYZ dir0 = XYZ.Zero;
XYZ dir1 = XYZ.Zero;
if (curve is Line)
{
dir0 = (curve as Line).Direction.Negate();
dir1 = (curve as Line).Direction;
}
Curve extCurve = Line.CreateBound(curve.GetEndPoint() + 1E3 * dir0, curve.GetEndPoint() + 1E3 * dir1);
return extCurve;
}
在Curve上按PointRange选取点位:
private List<XYZ> GetPoints(Curve curve, double pointRange)
{
var points = new List<XYZ>();
var beamLength = curve.Length;
var pointsNumber = beamLength % pointRange == ? ((beamLength / pointRange) - ) : Math.Floor((beamLength / pointRange)); for(var i = ; i <= pointsNumber; i++)
{
var point = curve.Evaluate(pointRange * i, false);
points.Add(point);
}
return points;
}
获取距离:
private List<KeyValuePair<Element, List<KeyValuePair<XYZ, double>>>> GetBeamFloorsPairCore(List<PlanarFace> beamBottomFaces, IEnumerable<XYZ> beamPoints, List<Element> floors)
{
var floorDataList = new List<KeyValuePair<Element, List<KeyValuePair<XYZ, double>>>>();
//寻找每一块结构梁下的板
foreach (var floor in constructionFloors)
{
//获取该板的最上点坐标
var floorTopFaces = FaceUtils.GetTopFaces(floor);
if (null != floorTopFaces && floorTopFaces.Any())
{
var defaultFloorOriginZ = floorTopFaces.FirstOrDefault().Origin.Z;
foreach (var tf in floorTopFaces)
{
var originZ = tf.Origin.Z;
if (defaultFloorOriginZ <= originZ)
{
defaultFloorOriginZ = originZ;
}
} var defaultBeamOriginZ = beamBottomFaces.FirstOrDefault().Origin.Z;
foreach (var bf in beamBottomFaces)
{
var originZ = bf.Origin.Z;
if (defaultBeamOriginZ >= originZ)
{
defaultBeamOriginZ = originZ;
}
}
//板在梁下面
var isLower = defaultFloorOriginZ < defaultBeamOriginZ; if (isLower)
{
var datalist = new List<KeyValuePair<XYZ, double>>();
//梁上一点能投影到板上
foreach (var point in beamPoints)
{
foreach (var tf in floorTopFaces)
{
var isProject = tf.Project(point);
if (null != isProject)
{
//投影到板上点的坐标
var projectPoint = isProject.XYZPoint; //投影点到梁上点的距离
foreach (var bf in beamBottomFaces)
{
var bp = bf.Project(projectPoint);
if (null != bp)
{
var distance = bp.Distance;
distance = UnitUtils.ConvertFromInternalUnits(distance, DisplayUnitType.DUT_MILLIMETERS);
distance = Math.Floor(distance); var pointAndDistance = new KeyValuePair<XYZ, double>(projectPoint, distance);
datalist.Add(pointAndDistance);
break;
}
}
}
}
} if (datalist != null && datalist.Any())
{
var floorAndData = new KeyValuePair<Element, List<KeyValuePair<XYZ, double>>>(floor, datalist);
floorDataList.Add(floorAndData);
}
}
}
}
return floorDataList;
}
【Revit API】梁的净高分析的更多相关文章
- 【Revit API】梁构件支座检查算法
一.前言 应该是第二次写关于Revit API的博文了.虽然在BIM企业中工作,从事桌面BIM软件开发,但是我是不怎么喜欢写Revit API相关的代码.平时更多的是在写界面展示,架构 ...
- Revit API 判断一个构件在某个视图中的可见性
查看 Revit API.发现有Element::IsHidden这个方法.通过UI创建一个element,注意要使得这个element在某些视图可见,但是在另一些视图不可见.运行下面的方法,你会发现 ...
- Revit API 操作共享参数和项目参数
1.获取共享参数 private string GetSharInfo(Autodesk.Revit.ApplicationServices.Application revitApp) { Strin ...
- Revit API射线法读取空间中相交的元素
Revit API提供根据射线来寻找经过的元素.方法是固定模式,没什么好说.关键代码:doc.FindReferencesWithContextByDirection(ptStart, (ptEnd ...
- Revit API 加载族并生成实例图元
在Revit API中加载族可以使用Doc.LoadFamily方法,传入要加载的族文件路径名,但是这种方式有一种缺点,就是如果族文件在当前工程中没有加载的话则返回成功,如果已经加载过,则返回失败,也 ...
- 【Revit API】调用Revit内部命令PostableCommand
Revit内置了一些命令,直接调用Revit操作方式. 可以去API文档查询PostableCommand枚举,还是很多的. 话不多说,直接上代码 var commandId = RevitComma ...
- 【Revit API】创建相机视角
在Revit中有一个相机功能可以以相机视角产生一个视图.一开始我在Revit2016的API文档中找关键词Camera,但是没什么收获. 其实这个相机功能的真正核心是创建透视视图:View3D.Cre ...
- Revit API判断是不是柱族模板
OwnerFamily即族模板.获取类别的方法:Document.Settings.Categories.get_Item(BuiltInCategory.OST_Columns); //判断是不是柱 ...
- revit API 生成墙图元
由于Revit的版本问题,在网上找的生成墙图元的代码,在我机器上的Revit 2016中编译不能通过,通过多次调试,终于找到在revit 2016中使用API生成墙图元的代码,现在贴出来. 下面的代码 ...
随机推荐
- 1.4《想成为黑客,不知道这些命令行可不行》(Learn Enough Command Line to Be Dangerous)——编辑命令
在编辑模式中,命令行包括几个重复之前命令的功能.这些以及其他很多命令功能时常设计键盘上的特殊键,所以给出Table 1作为参考,给出了许多键在典型的Macintosh键盘上的标记符号.若你的键盘不太一 ...
- 使用selenium进行自动化测试
selenium 支持多个客户端:ruby,Java,python.可以用来对网页进行全面测试,支持真实浏览器测试. firefox IE chrome safari 支持多操作系统: Linux w ...
- 20155325 Exp8 Web基础
实验要求 (1).Web前端HTML(0.5分) 能正常安装.启停Apache.理解HTML,理解表单,理解GET与POST方法,编写一个含有表单的HTML. (2).Web前端javascipt(0 ...
- 20155325 Exp5 MSF基础应用
目录 实验内容 遇到的问题 基础问题问答 老师!!!我实验三的C代码已经删除了,请求评分~~~ 实验内容 1.Windows服务渗透攻击--MS08-067 系统 虚拟机 参考博客 Windows X ...
- 利用RMAN转移裸设备到文件系统
本文只是为了个人备忘. 参考eagyle的:http://www.eygle.com/archives/2005/12/oracle_howto_move_datafile_raw.html 我首先挂 ...
- python3 str或bytes转换函数
str或bytes始终返回为str #!/usr/bin/env python # -*- coding: utf-8 -*- def to_str(bytes_or_str): if isinsta ...
- service手动实例化(new)导致类中的spring对象无法注入的问题解决
下面说的这个画横线的可能是错误的,因为我之前用controller继承父类的注解对象的时候成功了,所以可能这次的唯一原因就是 不该把本该从ioc容器中拿出的对象通过new的方式实例化,至于继承注解对象 ...
- C# Language Specification 5.0 (翻译)第三章 基本概念
应用程序启动 拥有进入点(entry point)的程序集称应用程序(application).当运行一应用程序时,将创建一新应用程序域(application domain).同一个应用程序可在同一 ...
- pandas 初识(二)
基本统计 pivot_table(数据透视表 ): 使用appfunc, 按不同index分类统计各特征values的值 df.pivot_table(index="Pclass" ...
- Dive查看docker镜像层信息
1.主要采用docker运行dive的方式,不然宿主机还要安装go那些挺麻烦的.具体用法可查看官方: https://github.com/wagoodman/dive 2.拉取dive镜像 dock ...