start

[Transaction(TransactionMode.Manual)]
[Regeneration(RegenerationOption.Manual)]
public class cmdFloorOpening : IExternalCommand
{
    public Result Execute(ExternalCommandData cmdData, ref string msg, ElementSet elements)
    {
        UIDocument uiDoc = cmdData.Application.ActiveUIDocument;
        Document doc = uiDoc.Document;
        Selection sel = uiDoc.Selection;
        Autodesk.Revit.Creation.Application aCreate = cmdData.Application.Application.Create;         Transaction ts = new Transaction(doc, "www");
        ts.Start();
        //楼板
        Reference refFloor = sel.PickObject(ObjectType.Element, "floor");
        Floor floor = doc.GetElement(refFloor) as Floor;
        Face face = FindFloorFace(floor);
        CurveArray curves = aCreate.NewCurveArray();
        //风管
        Reference refDuct = sel.PickObject(ObjectType.Element, "duct");
        Duct duct = doc.GetElement(refDuct) as Duct;
        Curve curve = FindDuctCurve(duct);
        //求交点
        XYZ xyz = FindFaceCurve(face, curve);
        /*开矩形洞*/
        XYZ xyz1 = xyz + new XYZ(1, 1, 0) * 200 / 304.8;
        XYZ xyz2 = xyz + new XYZ(1, -1, 0) * 200 / 304.8;
        XYZ xyz3 = xyz + new XYZ(-1, -1, 0) * 200 / 304.8;
        XYZ xyz4 = xyz + new XYZ(-1, 1, 0) * 200 / 304.8;
        Curve c1 = aCreate.NewLine(xyz1, xyz2, true);
        Curve c2 = aCreate.NewLine(xyz2, xyz3, true);
        Curve c3 = aCreate.NewLine(xyz3, xyz4, true);
        Curve c4 = aCreate.NewLine(xyz4, xyz1, true);
        curves.Append(c1);
        curves.Append(c2);
        curves.Append(c3);
        curves.Append(c4);         /*开圆形洞
        double startAngle = 0;
        double midAngle = Math.PI;
        double endAngle = 2 * Math.PI;         XYZ xAxis = XYZ.BasisX;
        XYZ yAxis = XYZ.BasisY;
        double radius = 180 / 304.8;         Arc arc1 = aCreate.NewArc(xyz, radius, startAngle, midAngle, xAxis, yAxis);
        Arc arc2 = aCreate.NewArc(xyz, radius, midAngle, endAngle, xAxis, yAxis);         curves.Append(arc1);
        curves.Append(arc2);*/         doc.Create.NewOpening(floor, curves, true);         ts.Commit();         return Result.Succeeded;
    }
    //求线和面的交点
    public XYZ FindFaceCurve(Face face, Curve curve)
    {
        //求交点
        IntersectionResultArray intersectionR = new IntersectionResultArray();//交点集合
        SetComparisonResult comparisonR;//Comparison比较
        comparisonR = face.Intersect(curve, out intersectionR);
        XYZ intersectionResult = null;//交点坐标
        if (SetComparisonResult.Disjoint != comparisonR)//Disjoint不交
        {
            if (!intersectionR.IsEmpty)
            {
                intersectionResult = intersectionR.get_Item(0).XYZPoint;
            }
        }
        return intersectionResult;
    }
    //找到风管对应的曲线
    public Curve FindDuctCurve(Duct duct)
    {
        //得到风管曲线
        IList<XYZ> list = new List<XYZ>();
        ConnectorSetIterator csi = duct.ConnectorManager.Connectors.ForwardIterator();
        while (csi.MoveNext())
        {
            Connector conn = csi.Current as Connector;
            list.Add(conn.Origin);
        }
        Curve curve = Line.get_Bound(list.ElementAt(0), list.ElementAt(1)) as Curve;
        curve.MakeUnbound();
        return curve;
    }
    //找到楼板的面
    public Face FindFloorFace(Floor floor)
    {
        Face normalFace = null;
        //
        Options opt = new Options();
        opt.ComputeReferences = true;
        opt.DetailLevel = Autodesk.Revit.DB.DetailLevels.Medium;
        //
        GeometryElement e = floor.get_Geometry(opt);
        /*下版改进
        IEnumerator<GeometryObject> enm = e.GetEnumerator();
        while (enm.MoveNext())
        {
            Solid solid = enm.Current as Solid;
        }*/
        foreach (GeometryObject obj in e.Objects)//待改2013
        {
            Solid solid = obj as Solid;
            if (solid != null && solid.Faces.Size > 0)
            {
                foreach (Face face in solid.Faces)
                {
                    PlanarFace pf = face as PlanarFace;
                    if (pf != null)
                    {
                        if (pf.Normal.AngleTo(new XYZ(0, 0, -1)) < 0.01)//数值在0到PI之间
                        {
                            normalFace = face;
                        }
                    }
                }
            }
        }
        return normalFace;
    }
}

url:http://greatverve.cnblogs.com/p/revit-api-FloorOpening.html

Revit API 楼板开洞的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. Revit API根据链接文件开洞

    开洞信息数据: ]);             ;                     ;                     ;                     ;          ...

  7. Revit API遍历全部风管,找到与风管相关的墙开洞

    涉及向量计算,求相交等相关技术. )                 {                     foreach (Face face in solid.Faces)          ...

  8. Revit API 获取某墙上洞口的尺寸和位置

    [Transaction(TransactionMode.Manual)] [Regeneration(RegenerationOption.Manual)] public class cmd2012 ...

  9. 【Revit API】调用Revit内部命令PostableCommand

    Revit内置了一些命令,直接调用Revit操作方式. 可以去API文档查询PostableCommand枚举,还是很多的. 话不多说,直接上代码 var commandId = RevitComma ...

随机推荐

  1. iOS.AppThinning-iOS9-new-feature-for-app-thinning-bitcode-odr-slicing

    Bitcode 0. Introduction to Bitcode 1. Build static library or framework via Xcode 7, while user buil ...

  2. ABP的数据过滤器(Data Filters)

    http://www.aspnetboilerplate.com/Pages/Documents/Data-Filters 我们在数据库开发中,一般会运用软删除 (soft delete)模式 ,即不 ...

  3. T60上安装Gentoo笔记

    T60虽然已经很老了,也过了服役期限.但是从入手之后,相比与家里放着的几个其他的高配置"后辈",依然是手中的挚爱.4:3的屏幕,方方正正的内敛模型,很结实的钢筋铁骨,无论是性格还是 ...

  4. [linux] 线程和wait命令,sleep命令

    在linux脚本编程中使用多线程编程,其中wait命令可以实现shell的多线程同步控制. 1. 启动后台子任务 在执行命令后加&操作符,表示将命令放在子shell中异步执行.可以达到多线程效 ...

  5. 图解CSS的padding,margin,border属性

    原文出处:http://hi.baidu.com/sonan/item/af05cf8759810d1cc31627d5 觉得不错,保存以备用. --------------------------- ...

  6. 地址标记,SpringMVC转发与调用相关知识存档

    1.mytest_mavenprj1中,index的 <a href="login/login.html">点击登录</a> 与 <a href=&q ...

  7. Android中轴旋转特效实现,制作别样的图片浏览器

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/10766017 Android API Demos中有很多非常Nice的例子,这些例 ...

  8. 解决Failed to load class "org.slf4j.impl.StaticLoggerBinder"

    Hibernate使用SLF4J API记录日志,所以在Hibernate的lib中,不再提供Log4J的包,而大部分框架依然使用Log4J记录日志,这样导致了兼容性问题. 解决办法,两步: 一.在编 ...

  9. Android性能优化方法(六)

    ContentProvider优化改进 1.索引简单的说,索引就像书本的目录,目录可以快速找到所在页数,数据库中索引可以帮助快速找到数据,而不用全表扫描,合适的索引可以大大提高数据库查询的效率.(1) ...

  10. MyEclipse 10 中如何更改字体

    打开Myeclipse软件.window->preferences->General->Appearance->Colors and Fonts然后在窗口的右边会显示一些如下图 ...