035集——BOUNDARY获取图形外轮廓(CAD—C#二次开发入门)

通过使用类似命令行输入boundary的方法获取图形外轮廓,使用函数如下:

var pls = Z.ed.TraceBoundary(new Point3d(box0 - 100, box1-100,0),true);

效果如下:

cs 复制代码
 public void XX()
 {
     Point3d pt = new Point3d(0, 0, 0);
     List<Curve> ents = Z.db.SelectEntities<Curve>();
     //Z.DrawBigBox<Curve>(ents);
     List<double> box = Z.Getbox<Curve>(ents);
     if (ents == null || ents.Count == 0) return;
     Entity temp=  Z.DrawBigBoxAdd(ents);
     List<Entity> plr = new List<Entity>();  //   
     var pls = Z.ed.TraceBoundary(new Point3d(box[0] - 100, box[1]-100,0),true);
     foreach (Entity item in pls)//不能var,否则没bounds属性
     {
         if (item.Bounds.Value.MinPoint.X != box[0]-1000)
         {
             item.Color = Color.FromRgb(255, 0, 0);
             plr.Add(item);
         }
     }
     Z.db.AddEntityToModeSpace(plr.ToArray());
     Z.db.Erase(temp);
 }
cs 复制代码
 public static List<double> Getbox<T>(List<T> entities)where T : Entity
 {
     List<double> lis = new List<double>();
     if (entities.Count == 0)
     {
         return lis;
     }
     double minx = entities.Min(x => x.Bounds.Value.MinPoint.X);
     double miny = entities.Min(x => x.Bounds.Value.MinPoint.Y);
     double maxx = entities.Max(x => x.Bounds.Value.MaxPoint.X);
     double maxy = entities.Max(x => x.Bounds.Value.MaxPoint.Y);
     lis.Add(minx);
     lis.Add(miny);
     lis.Add(maxx);
     lis.Add(maxy);
     return lis;
 }

  public static Entity DrawBigBoxAdd(List<Curve> entities)
  {//传进来一个list,画list的总包围盒
      List<double> lis = new List<double>();
      if (entities.Count == 0)
      {
          return null;
      }
      double minx = entities.Min(x => x.Bounds.Value.MinPoint.X - 1000);
      double miny = entities.Min(x => x.Bounds.Value.MinPoint.Y - 1000);
      double maxx = entities.Max(x => x.Bounds.Value.MaxPoint.X + 1000);
      double maxy = entities.Max(x => x.Bounds.Value.MaxPoint.Y + 1000);
      lis.Add(minx);
      lis.Add(miny);
      lis.Add(maxx);
      lis.Add(maxy);
      Autodesk.AutoCAD.DatabaseServices.Polyline pl = new Autodesk.AutoCAD.DatabaseServices.Polyline();
      pl.AddVertexAt(0, new Point2d(minx, miny), 0, 0, 0);
      pl.AddVertexAt(0, new Point2d(maxx, miny), 0, 0, 0);
      pl.AddVertexAt(0, new Point2d(maxx, maxy), 0, 0, 0);
      pl.AddVertexAt(0, new Point2d(minx, maxy), 0, 0, 0);
      pl.Closed = true;
      pl.ColorIndex = 1;
      db.AddEntityToModeSpace(pl);
      return pl;
  }
相关推荐
To_OC3 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
风止何安啊4 小时前
网课倍速痛点解决:一套前端代码实现自由控速播放器
前端·javascript·node.js
光影少年5 小时前
原生DOM操作在React 中的注意事项
前端·javascript·react.js
糖拌西瓜皮5 小时前
Node.js核心模块实战:文件、路径、HTTP与流处理
javascript·node.js
糖拌西瓜皮5 小时前
NestJS入门指南:Java开发者的Spring Boot体验
javascript·node.js
糖拌西瓜皮6 小时前
Express框架快速上手:中间件、路由与错误处理
javascript·node.js
唐青枫8 小时前
线程不是越多越快:C#.NET Thread 生命周期、同步与后台工作线程实战
c#·.net
半个落月8 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小兔崽子去哪了8 小时前
Vue3 + Pinia 集成 IGV.js 实现 BAM 文件在线浏览
javascript·vue.js·后端
小月土星9 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试