Revit二次开发——创建1/4椭圆并标注参数

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Autodesk.Revit.Attributes;
using Autodesk.Revit.UI;
using Autodesk.Revit.DB;
using Autodesk.Revit.ApplicationServices;
namespace ChangChunTest
{
    [TransactionAttribute(TransactionMode.Manual)]
    class Ellipse_cmd : IExternalCommand
    {
        public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements)
        {
            UIDocument uidoc = commandData.Application.ActiveUIDocument;
            Document doc = uidoc.Document;
            double a = 1000 / 304.8;//xRadius
            double b = 600/ 304.8;//yRadius
            Revolution revolution = null;
            using (Transaction trans = new Transaction(doc, "Ellipse"))
            {
                trans.Start();
                // 定义旋转的轮廓
                CurveArrArray curveArrArray = new CurveArrArray();
                CurveArray curveArray = new CurveArray();
                // 定义点
                XYZ p0 = new XYZ(0, 0, 0);//圆?点
                XYZ p1 = new XYZ(1, 0, 0);//x单位向量
                XYZ p2 = new XYZ(0, 1, 0);//y单位向量

                XYZ p3 = new XYZ(a, 0, 0);
                XYZ p4 = new XYZ(0,b,0);

                XYZ pp = new XYZ(-10, 0, 0);
                Line axis = Line.CreateBound(XYZ.Zero, pp);//  旋转轴


                Line line1 = Line.CreateBound(p0, p3);//H横切高度  
                Curve ellipse = Ellipse.CreateCurve(p0, a, b, p1, p2, 0, Math.PI / 2);

                Line line2 = Line.CreateBound(p4, p0);//WR赤道半径
                curveArray.Append(line1);
                curveArray.Append(ellipse);
                curveArray.Append(line2);
                curveArrArray.Append(curveArray);

                Plane plane= Plane.CreateByNormalAndOrigin(new XYZ(0, 0, 1), XYZ.Zero);
                SketchPlane sketchPlane = SketchPlane.Create(doc, plane);
 
                 revolution = doc.FamilyCreate.NewRevolution(true, curveArrArray, sketchPlane, axis, -Math.PI, Math.PI);
                trans.Commit();
            }
            using (Transaction trans2 = new Transaction(doc, "Ellipse-DIM-H"))
            {
                trans2.Start();
                XYZ x1 = new XYZ(1, 0, 0);//x单位向量
                XYZ y1 = new XYZ(0, -1, 0);//x单位向量
                Reference refe1 = null;
                Reference refe2 = null;
                FamilyManager m_familyMgr = doc.FamilyManager;
                bool isInstance = false;
                FamilyParameter HparamTwH= m_familyMgr.AddParameter("赤道界面高度2", BuiltInParameterGroup.PG_GEOMETRY, ParameterType.Length, isInstance);
               // FamilyParameter HparamTwR = m_familyMgr.AddParameter("极半径长度", BuiltInParameterGroup.PG_GEOMETRY, ParameterType.Length, isInstance);
                Line line_x = null;
                Line line_y = null;
                Ellipse ellipse = null;
                ReferenceArray referencesH = new ReferenceArray();
              //  ReferenceArray referencesR = new ReferenceArray();
                foreach (CurveArray item in revolution.Sketch.Profile)
                {
                    foreach (var curve in item)
                    {
                        if (curve is Line)
                        {
                            Line line = curve as Line;
                            if ( Convert.ToInt32( line.Direction.X )== 1)
                            {
                                    line_x = line;
                                   var lineX = doc.GetElement (line.Reference) as ModelLine;
                                referencesH.Append(lineX.GeometryCurve.Reference);
                                 //  TaskDialog.Show("info",lineX.ToString());
                            }
                            if (Convert.ToInt32(line.Direction.Y) == -1)
                            {
                                line_y = line;
                                var lineY = doc.GetElement(line.Reference) as ModelLine;
                               // referencesR.Append(lineY.GeometryCurve.Reference);
                            }

                        }
                        else if (curve is Ellipse)
                        {
                            ellipse = curve as Ellipse;
                            var model_ellipse = doc.GetElement(ellipse.Reference) as ModelEllipse;
                            referencesH.Append(model_ellipse.GeometryCurve.GetEndPointReference(0));
                          //  referencesR.Append(model_ellipse.GeometryCurve.GetEndPointReference(0));
                        }

                    }
                }
 
                Dimension dimension_x = doc.FamilyCreate.NewDimension(doc.ActiveView, line_x, referencesH);
              //  Dimension dimension_y = doc.FamilyCreate.NewDimension(doc.ActiveView, line_y, referencesR);

                dimension_x.FamilyLabel = HparamTwH;
             //   dimension_y.FamilyLabel = HparamTwR;

                trans2.Commit();
            }
            using (Transaction trans3 = new Transaction(doc, "Ellipse-DIM-R"))
            {
                trans3.Start();
                XYZ x1 = new XYZ(1, 0, 0);//x单位向量
                XYZ y1 = new XYZ(0, -1, 0);//x单位向量
                
                FamilyManager m_familyMgr = doc.FamilyManager;
                bool isInstance = false;
 
                FamilyParameter HparamTwR = m_familyMgr.AddParameter("极半径长度1", BuiltInParameterGroup.PG_GEOMETRY, ParameterType.Length, isInstance);
 
                Line line_y = null;
                Ellipse ellipse = null;
                
                ReferenceArray referencesR = new ReferenceArray();
                foreach (CurveArray item in revolution.Sketch.Profile)
                {
                    foreach (var curve in item)
                    {
                        if (curve is Line)
                        {
                            Line line = curve as Line;
                           
                            if (Convert.ToInt32(line.Direction.Y) == -1)
                            {
                                line_y = line;
                                var lineY = doc.GetElement(line.Reference) as ModelLine;
                               referencesR.Append(lineY.GeometryCurve.Reference);
                            }

                        }
                        else if (curve is Ellipse)
                        {
                            ellipse = curve as Ellipse;
                            var model_ellipse = doc.GetElement(ellipse.Reference) as ModelEllipse;
                            referencesR.Append(model_ellipse.GeometryCurve.GetEndPointReference(0));
                        }

                    }
                }
                Dimension dimension_R = doc.FamilyCreate.NewDimension(doc.ActiveView, line_y, referencesR);
 
                dimension_R.FamilyLabel = HparamTwR;
                trans3.Commit();
            }
            return Result.Succeeded;
        }
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,以下是Revit二次开发角度标注创建C#的方法: 1. 首先,需要使用Revit API扩展方式,识别出Revit模型各楼层平面图的建筑构件,提取房间坐标数据信息。 2. 接着,结合SQL server,建立BIM数据库(Epplus库),存储提取的数据信息。 3. 然后,利用Visual Studio创建一个新的C#项目,将Revit API添加到项目引用中。 4. 在C#代码中,使用FilteredElementCollector类获取需要标注的元素,例如房间或者墙体。 5. 创建标注的API,可以使用Dimension类创建标注。首先需要定义标注的起点和终点,然后使用Dimension.Create方法创建标注。 6. 最后,将标注添加到所属的视图属性中,即可完成标注创建。 以下是一个简单的示例代码: ```csharp // 获取需要标注的元素 FilteredElementCollector collector = new FilteredElementCollector(doc); List<Element> elements = collector.OfClass(typeof(Room)).ToList(); // 创建标注 foreach (Element element in elements) { Room room = element as Room; XYZ point1 = room.Location.Point; XYZ point2 = new XYZ(point1.X + 10, point1.Y + 10, point1.Z); Line line = Line.CreateBound(point1, point2); Dimension dimension = Dimension.Create(doc, line, view.Id); // 将标注添加到所属的视图属性中 using (Transaction transaction = new Transaction(doc)) { transaction.Start("Add Dimension"); view.AddDimensionStyleOverride(dimension.Id, OverrideGraphicSettings()); transaction.Commit(); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值