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风管对齐的更多相关文章

  1. Revit API判断直线相交关系移动风管

    start )             );         )) )) );         XYZ xyz12 = lCurve1.Curve.get_EndPoint();         XY ...

  2. Revit利用对正工具快速修改风管对齐方式

    绘制风管的时候,可以对风管的对正方式进行设置,水平方向可以设置左对齐或者中心对齐或者右对齐,垂直方向可以设置为顶对齐或者中心对齐或者低对齐,如果需要对原来的对齐方式进行修改的时候应该如何操作呢?比如, ...

  3. 【Revit API】梁构件支座检查算法

    一.前言         应该是第二次写关于Revit API的博文了.虽然在BIM企业中工作,从事桌面BIM软件开发,但是我是不怎么喜欢写Revit API相关的代码.平时更多的是在写界面展示,架构 ...

  4. Revit API 判断一个构件在某个视图中的可见性

    查看 Revit API.发现有Element::IsHidden这个方法.通过UI创建一个element,注意要使得这个element在某些视图可见,但是在另一些视图不可见.运行下面的方法,你会发现 ...

  5. Revit API 操作共享参数和项目参数

    1.获取共享参数 private string GetSharInfo(Autodesk.Revit.ApplicationServices.Application revitApp) { Strin ...

  6. Revit API射线法读取空间中相交的元素

    Revit API提供根据射线来寻找经过的元素.方法是固定模式,没什么好说.关键代码:doc.FindReferencesWithContextByDirection(ptStart, (ptEnd  ...

  7. Revit API 加载族并生成实例图元

    在Revit API中加载族可以使用Doc.LoadFamily方法,传入要加载的族文件路径名,但是这种方式有一种缺点,就是如果族文件在当前工程中没有加载的话则返回成功,如果已经加载过,则返回失败,也 ...

  8. Revit Family API 添加对齐

    没测试成功,留待以后研究. [TransactionAttribute(Autodesk.Revit.Attributes.TransactionMode.Manual)] ; ; i < nV ...

  9. Revit API画垂直于风管的风管

    start /// <summary> /// 选择风管与风管外一点,画与风管垂直的风管. /// </summary> [Transaction(TransactionMod ...

随机推荐

  1. CSS Pseudo-classes

    先来一条金科玉律: 伪类的效果可以通过添加一个实际的类来达到:伪元素的效果可以通过添加一个实际的元素来达到. 第一部分,Pseudo-classes,伪类 一.链接系 (这个应该是最熟悉的啦.) a: ...

  2. linux笔记_day09

    1.运算器.控制器.存储器.输入输出(IO) 地址总线:内存寻址 数据总线:传输数据 控制总线:控制指令 寄存器:cpu暂时存储器 2.系统设定 默认输出设备:标准输出,STDOUT,1(描述符)(显 ...

  3. Spring bean 配置

    1.传统的创建对象的方式:JedisMall tardition=new JedisMall(); 这样是在程序运行时创建,表示当前模块已经不知不觉和new出的对象耦合了,而我们通常都是更高层次的抽象 ...

  4. 替换openjdk的版本时遇到报错Transaction check error

    x想要使用jmap对jvm内存进行排查问题,但是默认安装的openjdk包中并不带有这个命令,需要新升级到新版本才有 而在安装新的版本时,遇到报错: :   file /usr/lib64/libns ...

  5. 解决chrome运行报错unknown error: cannot get automation extension

    今天把默认浏览器改成chrome,结果一运行脚本就报错,具体错误信息如下. FAILED CONFIGURATION: @BeforeClass beforeClassorg.openqa.selen ...

  6. css-实现图标在输入框中显示

    一:JavaScript 是脚本语言 JavaScript 是一种轻量级的编程语言. JavaScript 是可插入 HTML 页面的编程代码. JavaScript 插入 HTML 页面后,可由所有 ...

  7. 今天我碰到了由于web.xml文件表头信息导致润乾报表启动失败的问题,解决方案如下

    下面是从2.3,2.4.2.5 3.0集中版本的web.xml头信息的细节,当发现系统启动不报错但是该生成的功能没有正常生成,特别是在这次配置润乾报表的时候发现用2.4版本的时候,在web.xml中配 ...

  8. CSS之外边距折叠

    外边距折叠 Collapsing margins,即外边距折叠,指的是毗邻的两个或多个外边距 (margin) 会合并成一个外边距. 其中所说的 margin 毗邻,可以归结为以下两点: 这两个或多个 ...

  9. 深刻理解this的指向和var 定义的变量的问题

    一般来说,在编程语言里我们常见的变量作用域就是词法作用域与动态作用域(Dynamic Scope),绝大部分的编程语言都是使用的词法作用域.词法作用域注重的是所谓的Write-Time,即编程时的上下 ...

  10. P2651 添加括号III

    P2651 添加括号III无论怎么添加,a2一定是分母,其他的可以是分子,所以最后看看,(a1*a3*..*an)%a2==0即可 #include<iostream> #include& ...