revit二次开发管线T型连接

在这里插入图片描述

[Transaction(TransactionMode.Manual)]
[Regeneration(RegenerationOption.Manual)]
[Journaling(JournalingMode.NoCommandData)]
internal class Class13 : IExternalCommand
{
    public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
    {
        UIDocument uIDocument = commandData.Application.ActiveUIDocument;
        Document revitDoc = uIDocument.Document;
        try
        {
            Reference reference1 = uIDocument.Selection.PickObject(ObjectType.Element, new PipeFilter());
            Reference reference2 = uIDocument.Selection.PickObject(ObjectType.Element, new PipeFilter());

            Pipe pipe1 = revitDoc.GetElement(reference1) as Pipe;
            Pipe pipe2 = revitDoc.GetElement(reference2) as Pipe;

            double parameter1 = pipe1.get_Parameter(BuiltInParameter.RBS_OFFSET_PARAM).AsDouble();
            double parameter2 = pipe2.get_Parameter(BuiltInParameter.RBS_OFFSET_PARAM).AsDouble();

            Line line1 = (pipe1.Location as LocationCurve).Curve as Line;
            Line line2 = (pipe2.Location as LocationCurve).Curve as Line;

            XYZ intersectionPoint1 = line1.Project(line2.GetEndPoint(0)).XYZPoint;

            line2.MakeUnbound();

            XYZ intersectionPoint2 = line2.Project(intersectionPoint1).XYZPoint;
            if (parameter1 == parameter2)
            {

                using (Transaction tr = new Transaction(revitDoc, "tt1"))
                {
                    tr.Start();
                    MEPCurve mEPCurve = revitDoc.GetElement(PlumbingUtils.BreakCurve(revitDoc, reference1.ElementId, intersectionPoint1)) as MEPCurve;
                    //TaskDialog.Show("提示", $"{mEPCurve.Id}");
                    ThreeMEPCurveCeateElbow(revitDoc, mEPCurve, pipe1, pipe2);
                    tr.Commit();
                }
            }
            else
            {
                using (Transaction tr = new Transaction(revitDoc, "tt"))
                {
                    tr.Start();
                    Pipe newPipe = revitDoc.GetElement(ElementTransformUtils.CopyElement(revitDoc, reference1.ElementId, XYZ.Zero).FirstOrDefault()) as Pipe;
                    Line newLine = Line.CreateBound(intersectionPoint1, intersectionPoint2);
                    (newPipe.Location as LocationCurve).Curve = newLine;
                    TwoMEPCurveCeateElbow(revitDoc, pipe2, newPipe);

                    MEPCurve mEPCurve = revitDoc.GetElement(PlumbingUtils.BreakCurve(revitDoc, reference1.ElementId, intersectionPoint1)) as MEPCurve;
                    //TaskDialog.Show("提示", $"{mEPCurve.Id}");
                    ThreeMEPCurveCeateElbow(revitDoc, mEPCurve, pipe1, newPipe);

                    tr.Commit();
                }
            }
        }
        catch (Exception)
        {
            return Result.Failed;
        }
            return Result.Succeeded;
    }
    private void TwoMEPCurveCeateElbow(Document doc, MEPCurve curve1, MEPCurve curve2)
    {
        double distance = double.MaxValue;
        Connector connector1 = null, connector2 = null;
        foreach (Connector item1 in curve1.ConnectorManager.Connectors)
        {
            foreach (Connector item2 in curve2.ConnectorManager.Connectors)
            {

                double d = item1.Origin.DistanceTo(item2.Origin);
                if (d < distance)
                {
                    distance = d;
                    connector1 = item1;
                    connector2 = item2;
                }
            }
        }
        if (connector1 != null && connector2 != null)
        {
            doc.Create.NewElbowFitting(connector1, connector2);
        }
    }
    private void ThreeMEPCurveCeateElbow(Document doc, MEPCurve curve1, MEPCurve curve2, MEPCurve curve3)
    {
        double distance = double.MaxValue;
        Connector connector1 = null, connector2 = null, connector3 = null;
        foreach (Connector item1 in curve1.ConnectorManager.Connectors)
        {
            foreach (Connector item2 in curve2.ConnectorManager.Connectors)
            {
                double d = item1.Origin.DistanceTo(item2.Origin);
                if (d < distance)
                {
                    distance = d;
                    connector1 = item1;
                    connector2 = item2;
                }
            }
        }

        distance = double.MaxValue;
        foreach (Connector item in curve3.ConnectorManager.Connectors)
        {
            double d = item.Origin.DistanceTo(connector1.Origin);
            if (d < distance)
            {
                distance = d;
                connector3 = item;
            }
        }
        if (connector1 != null && connector2 != null && connector3 != null)
        {
            doc.Create.NewTeeFitting(connector1, connector2, connector3);
        }
    }
}
internal class PipeFilter : ISelectionFilter
{
    public bool AllowElement(Element elem)
    {
        if (elem.Category.Name == "管道")
        {
            return true;
        }
        return false;
    }

    public bool AllowReference(Reference reference, XYZ position)
    {
        return false;
    }
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值