007集—— 自动获取图形的外边界(外轮廓)(CAD—C#二次开发入门)

本文只适用于闭合多段线组成的图像,其他情况(圆、弧、椭圆、未封闭line)暂不免费提供。

效果如下图所示:

 原始图:

 代码运行后图:

 

附代码:

 public class 外轮廓
 {
     Database db = HostApplicationServices.WorkingDatabase;
     [CommandMethod("xx")]
     public void Demo()
     {
         try
         {
             //ObjectId obj =  db.GetCenterPl();
             // return;
             // List<DBText> dbtext = db.SelectEntities<DBText>();
             // return;
             // db.GetEntities(out List<Curve> curve, "aa");
             // return;
             if (!db.GetEntities(out List<Curve> curve, "框选识别外轮廓的图像"))
                 return;
             List<Line> lines = new List<Line>();
             foreach (var item in curve)
             {
                 if (item is Line) lines.Add(item as Line);
                 else if (item is Polyline pl)
                 {
                     List<Curve> cus = PmPolyLineMethod.ExplodePolyLine(pl);
                     foreach (var cu in cus)
                     {
                         if (cu is Line) lines.Add(cu as Line);
                     }
                 }
             }
             //lines.ForEach(line => line.ColorIndex = 1);
             //foreach (var item in lines)
             //{
             //    db.AddEntityToModeSpace(item);
             //}

             //return;
             Dictionary<Line, List<Point3d>> pointsOnLine = new Dictionary<Line, List<Point3d>>();
             foreach (var item in lines)
             {
                 pointsOnLine.Add(item, new List<Point3d>());
             }
             for (int i = 0; i < lines.Count - 1; i++)
             {
                 for (int j = i + 1; j < lines.Count; j++)
                 {
                     Point3dCollection pos = new Point3dCollection();
                     lines[i].IntersectWith(lines[j], Intersect.OnBothOperands, pos, IntPtr.Zero, IntPtr.Zero);
                     if (pos.Count > 0)
                     {
                         foreach (Point3d item in pos)
                         {
                             pointsOnLine[lines[i]].Add(item);
                             pointsOnLine[lines[j]].Add(item);
                         }
                     }
                 }
             }
             lines.Clear();
             foreach (var item in pointsOnLine)
             {
                 Line line = item.Key;
                 List<Point3d> points = item.Value;
                 if (points.Count == 0)
                 {
                     lines.Add(line);
                 }
                 else
                 {
                     if (points.Count > 1)
                     {
                         points = points.OrderBy(x => line.GetParameterAtPoint(x)).ToList();//点排序
                     }
                     Point3dCollection pos = new Point3dCollection();
                     points.ForEach(x => pos.Add(x));//点集合加点
                     DBObjectCollection dbs = line.GetSplitCurves(pos);//打断线
                     foreach (var dbobject in dbs)
                     {
                         if (dbobject is Line)
                         {
                             lines.Add(dbobject as Line);//最终线段list
                         }
                     }
                 }
             }
             //lines.ForEach(line => line.ColorIndex = 1);
             //lines.ForEach(line => db.AddEntityToModeSpace(line));
             //return;
             if (!PmPolyLineMethod.GetPoint(out Point3d point, "请选择外面一点")) return;
             Line firstLine = lines.OrderBy(x => x.GetClosestPointTo(point, false).DistanceTo(point)).First();
             //firstLine.ColorIndex = 1;
             //db.AddEntityToModeSpace(firstLine);
             //return;
             lines.Remove(firstLine);
             Polyline polyline = new Polyline();
             polyline.AddVertexAt(0, firstLine.StartPoint.Convert2d(new Plane()), 0, 0, 0);
             polyline.AddVertexAt(1, firstLine.EndPoint.Convert2d(new Plane()), 0, 0, 0);
             Vector3d v1 = firstLine.StartPoint - point;
             Vector3d v2 = firstLine.EndPoint - point;
             if (v1.CrossProduct(v2).Z > 0) polyline.ReverseCurve();
             //polyline.ColorIndex = 1;
             //db.AddEntityToModeSpace(polyline);
             //return;
             while (true)
             {
                 List<Line> tmps = new List<Line>();
                 foreach (var item in lines)
                 {
                     if (item.StartPoint == polyline.EndPoint)
                     {
                         tmps.Add(item);
                     }

                     else if (item.EndPoint == polyline.EndPoint)
                     {
                         item.ReverseCurve();
                         tmps.Add(item);
                     }
                 }
                 if (tmps.Count == 0) break;
                 Vector3d vector = -polyline.GetFirstDerivative(polyline.EndPoint);//顺时针
                 double maxAngle = 0;
                 Line bigLine = new Line();
                 foreach (var item in tmps)//
                 {
                     double angle = vector.GetAngleTo(item.Delta, -Vector3d.ZAxis);
                     if (angle > maxAngle)
                     {
                         maxAngle = angle;
                         bigLine = item;
                     }
                 }
                 polyline.JoinEntity(bigLine);
                 lines.Remove(bigLine);
                 if (polyline.EndPoint == polyline.StartPoint) break;
             }
             polyline.ColorIndex = 1;
             db.AddEntityToModeSpace(polyline);
             return;
         }

         catch (System.Exception)
         {
             throw;
         }

     }
 }

 说明:插件获取联系下方↓↓↓

 

这个错误是由于无法连接到本地主机的10248端口导致的。这个端口通常是kubelet进程监听的端口,用于健康检查。出现这个错误可能是由于kubelet进程没有正确启动或者配置错误导致的。 解决这个问题的方法是检查kubelet进程的状态和配置。你可以按照以下步骤进行操作: 1. 检查kubelet进程是否正在运行。你可以使用以下命令检查kubelet进程的状态: ```shell systemctl status kubelet ``` 如果kubelet进程没有运行,你可以使用以下命令启动它: ```shell systemctl start kubelet ``` 2. 检查kubelet的配置文件。你可以使用以下命令查看kubelet的配置文件路径: ```shell kubelet --kubeconfig /etc/kubernetes/kubelet.conf --config /var/lib/kubelet/config.yaml --bootstrap-kubeconfig /etc/kubernetes/bootstrap-kubelet.conf config view ``` 确保配置文件中的端口号和地址正确,并且与你的环境相匹配。 3. 检查网络连接。你可以使用以下命令检查是否可以连接到localhost的10248端口: ```shell curl -sSL http://localhost:10248/healthz ``` 如果无法连接,请确保端口没有被防火墙或其他网络配置阻止。 4. 检查docker的配置。有时候,kubelet进程依赖于docker进程。你可以按照以下步骤检查docker的配置: - 创建/etc/docker目录: ```shell sudo mkdir /etc/docker ``` - 编辑/etc/docker/daemon.json文件,并添加以下内容: ```json { "exec-opts": ["native.cgroupdriver=systemd"], "log-driver": "json-file", "log-opts": { "max-size": "100m" }, "storage-driver": "overlay2", "storage-opts": [ "overlay2.override_kernel_check=true" ], "registry-mirrors": ["https://tdhp06eh.mirror.aliyuncs.com"] } ``` - 重启docker进程: ```shell systemctl restart docker ``` 请注意,以上步骤是一种常见的解决方法,但具体解决方法可能因环境而异。如果以上步骤无法解决问题,请提供更多的错误信息和环境配置,以便我们能够更好地帮助你。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山水CAD插件定制

你的鼓励是我创作最大的动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值