Revit二开--管线分布 功能解密

Revit二开–管线分布 功能解密

唐僧解瓦 项目 github地址:https://github.com/binbinstrong/tangsengjiewa
在这里插入图片描述

本案例以 按管中心排列的方式 来用代码实现 ,按管外壁的原理是一样的在此不做赘述。

本例以 esc 键 来结束选择 如果要实现上图效果可以在 一键分布按钮里面 向revit主窗口发送esc按键即可,时间有限不再多说,好了上代码!

	[Transaction(TransactionMode.Manual)]
    [Regeneration(RegenerationOption.Manual)]
    [Journaling(JournalingMode.UsingCommandData)]
    class Cmd_MepCurveRank : IExternalCommand
    {
        public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
        {
            UIApplication uiapp = commandData.Application;
            UIDocument uidoc = commandData.Application.ActiveUIDocument;
            Document doc = uidoc.Document;
            Selection sel = uidoc.Selection;
            View acview = uidoc.ActiveView;

            var toolwin = MepcurveRank.Instance;
            toolwin.helper().Owner = RevitWindowHelper.GetRevitHandle();
            toolwin.Show(); //显示窗体 当点击窗体的 一键分布的时候 向revit窗体发送esc按键 结束 while循环
            var elelist = new List<ElementId>();
            while (true)
            {
                try
                {
                    var eleref = sel.PickObject(ObjectType.Element, doc.GetSelectionFilter(m => m is MEPCurve));
                    elelist.Add(eleref.ElementId);
                }
                catch (Exception e)
                {
                    break;
                }
            }
            var dis = default(double);
            var parseresult = double.TryParse(toolwin.horizontalDis.Text, out dis);
            if (!parseresult)
            {
                MessageBox.Show("间距设置错误");
                return Result.Cancelled;
            }
            //以第一根管不动 其他管 紧跟第一根管排列
            var meplist = elelist.Select(m => m.GetElement(doc) as MEPCurve).ToList();
            var stablemep = meplist.First();
            Transaction ts = new Transaction(doc, "***********");
            try
            {
                ts.Start();
                for (int i = 0; i < meplist.Count; i++)
                {
                    if (i == 0) continue;
                    var temdis = dis.MetricToFeet() * i;
                    var originaldir = -getprojectdir(meplist[i], stablemep);
                    var originaldis = getHorizontalDis(meplist[i], stablemep);
                    var moveVec = (temdis - originaldis) * originaldir;
                    ElementTransformUtils.MoveElement(doc, meplist[i].Id, moveVec);
                }
                ts.Commit();
            }
            catch (Exception e)
            {
                MessageBox.Show(e.ToString());
                if (ts.GetStatus() == TransactionStatus.Started)
                {
                    ts.RollBack();
                }
                //throw;
            }
            return Result.Succeeded;
        }
        /// <summary>
        /// 两条管线须平行
        /// </summary>
        /// <param name="mep"></param>
        /// <param name="mep2"></param>
        /// <returns></returns>
        XYZ getprojectdir(MEPCurve mep, MEPCurve mep2)
        {
            var line1 = mep.LocationLine();
            var line2 = mep2.LocationLine();
            var origin = line1.StartPoint();
            var originprojectonline2 = origin.ProjectToXLine(line2);
            var dir = originprojectonline2 - origin;
            var horizontaldir = dir.xyComponent().Normalize();
            return horizontaldir;
        }
        double getHorizontalDis(MEPCurve mep, MEPCurve mep2)
        {
            var line1 = mep.LocationLine();
            var line2 = mep2.LocationLine();
            var origin = line1.Origin;
            var originprojectonline2 = origin.ProjectToXLine(line2);
            var dir = originprojectonline2 - origin;
            var horizontaldir = dir.xyComponent();
            return horizontaldir.GetLength();
        }
    }

窗体代码很简单,就不贴了,如果有看不懂的朋友欢迎进群讨论,另外里面有几个方法是我自己封装的,不明白的欢迎切磋讨论。

  • 实现效果

    在这里插入图片描述
更多解密尽在唐僧课堂!


在这里插入图片描述

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值