Revit API风管对齐
start
[Transaction(TransactionMode.Manual)]
[Regeneration(RegenerationOption.Manual)]
public class cmd : IExternalCommand
{
/// <summary>
/// 取得风管两端连接器
/// </summary>
/// <param name="duct"></param>
/// <returns></returns>
private List<Connector> getConn(Duct duct)
{
List<Connector> listConn = new List<Connector>();
ConnectorSetIterator csi = duct.ConnectorManager.Connectors.ForwardIterator();
while (csi.MoveNext())
{
Connector conn = csi.Current as Connector;
if (ConnectorType.End == conn.ConnectorType)
{
listConn.Add(conn);
}
else if (ConnectorType.Curve == conn.ConnectorType)
{
//return conn;
}
}
return listConn;
}
public Result Execute(ExternalCommandData cmdData, ref string msg, ElementSet elements)
{
UIDocument uiDoc = cmdData.Application.ActiveUIDocument;
UIApplication uiApp = cmdData.Application;
Document doc = uiDoc.Document;
Selection sel = uiDoc.Selection; Transaction ts = new Transaction(doc, "http://revit.5d6d.com");
ts.Start();
try
{
Element elDuct0 = doc.GetElement(sel.PickObject(ObjectType.Element, "选择风管1:"));
Element elDuct1 = doc.GetElement(sel.PickObject(ObjectType.Element, "选择风管2:"));
Duct duct0 = elDuct0 as Duct;
Duct duct1 = elDuct1 as Duct;
List<Connector> listConn0 = getConn(duct0);
List<Connector> listConn1 = getConn(duct1);
Line line0 = Line.get_Bound(listConn0[].Origin, listConn0[].Origin);
Line line1 = Line.get_Bound(listConn1[].Origin, listConn1[].Origin);
double dDis = line1.Distance(line0.get_EndPoint());//直接间距
XYZ xyzVector = GetXYVector(line0, line1);
LocationCurve lc = elDuct1.Location as LocationCurve;
lc.Move(dDis * xyzVector);
ts.Commit();
}
catch (Autodesk.Revit.Exceptions.OperationCanceledException)
{
ts.RollBack();
return Result.Cancelled;
}
catch (Exception ex)
{
ts.RollBack();
} return Result.Succeeded;
} /// <summary>
/// 取得平行线的单位向量
/// </summary>
/// <param name="line0"></param>
/// <param name="line1"></param>
/// <returns></returns>
public XYZ GetXYVector(Line line0, Line line1)
{
//基准
XYZ startPoint0 = line0.get_EndPoint();
XYZ endPoint0 = line0.get_EndPoint();
//参照
XYZ startPoint1 = line1.get_EndPoint();
XYZ endPoint1 = line1.get_EndPoint();
//
XYZ resultVector = new XYZ(, , ); XYZ zStart = new XYZ(startPoint1.X, startPoint1.Y, );
XYZ zEnd = new XYZ(endPoint1.X, endPoint1.Y, ); Line line = Line.get_Bound(new XYZ(startPoint0.X, startPoint0.Y, ), new XYZ(endPoint0.X, endPoint0.Y, ));
line.MakeUnbound(); //取得一条直线所在直线相垂直的直线
XYZ tPoint = zStart - zEnd;
XYZ zVector = new XYZ(, , );
XYZ nPoint = tPoint.CrossProduct(zVector).Normalize() + zStart;
Line lineN = Line.get_Bound(zStart, nPoint);
lineN.MakeUnbound(); //与另外一条风管的交点
IntersectionResultArray intersectionR = new IntersectionResultArray();
SetComparisonResult comparisonR; comparisonR = line.Intersect(lineN, out intersectionR); if (SetComparisonResult.Disjoint != comparisonR)
{
if (!intersectionR.IsEmpty)
{
resultVector = intersectionR.get_Item().XYZPoint;
}
} if (!zStart.IsAlmostEqualTo(resultVector))
{
resultVector = (resultVector - zStart).Normalize();
} return resultVector;
}
}
url:http://greatverve.cnblogs.com/p/revit-api-duct-alignment.html
Revit API风管对齐的更多相关文章
- Revit API判断直线相交关系移动风管
start ) ); )) )) ); XYZ xyz12 = lCurve1.Curve.get_EndPoint(); XY ...
- Revit利用对正工具快速修改风管对齐方式
绘制风管的时候,可以对风管的对正方式进行设置,水平方向可以设置左对齐或者中心对齐或者右对齐,垂直方向可以设置为顶对齐或者中心对齐或者低对齐,如果需要对原来的对齐方式进行修改的时候应该如何操作呢?比如, ...
- 【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 Family API 添加对齐
没测试成功,留待以后研究. [TransactionAttribute(Autodesk.Revit.Attributes.TransactionMode.Manual)] ; ; i < nV ...
- Revit API画垂直于风管的风管
start /// <summary> /// 选择风管与风管外一点,画与风管垂直的风管. /// </summary> [Transaction(TransactionMod ...
随机推荐
- ACM数据对拍程序
#include<cstdio> #include<cstdlib> #include<ctime> int main() { long s,t; while(1) ...
- MYSQL问题解决
1. MySQL错误日志里出现: 140331 10:08:18 [ERROR] Error reading master configuration 140331 10:08:18 [ERROR] ...
- NET调用Com组件事例
http://blog.csdn.net/shizhiyingnj/article/details/1507948 在程序设计中,往往通过键盘的某个按键来完成相关操作! 下面就来说明如何实现: 1.引 ...
- Android 6.0 API
Android 6.0 (M) 为用户和应用开发者提供了新功能.本文旨在介绍其中最值得关注的 API. 着手开发 要着手开发 Android 6.0 应用,您必须先获得 Android SDK,然后使 ...
- 网络图片转换到本地并转换成base64位
/** * 网络图片转换到本地并转换成base64位 * @param $url * @return string */ public function imgzhuanhuan($url) { // ...
- Java编程的逻辑 (18) - 为什么说继承是把双刃剑
本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http: ...
- Mybatis输入映射和输出映射
本节内容: 输入参数映射 输出映射 resultMap Mapper.xml映射文件中定义了操作数据库的sql,每个sql是一个statement,映射文件是mybatis的核心. 一.环境准备 复制 ...
- 【AtCoder】ARC088
C - Multiple Gift 题解 首项是X,每次乘个2,暴力统计 代码 #include <bits/stdc++.h> #define fi first #define se s ...
- MapReduce原理2
MapReduce的shuffle机制 1.概述 mapreduce中,map阶段处理的数据如何传递给reduce阶段,是mapreduce框架中最关键的一个流程,这个流程就叫shuffle: shu ...
- oracle用户名小写时,利用sqlplus连接
[oracle@upright92 ~]$ sqlplus / as sysdba SQL*Plus: Release 11.2.0.4.0 Production on Tue May 22 10:3 ...