欢迎来到我的博客
Civil 3D开发与应用,欢迎加入QQ群:484124761
AutoCAD开发,欢迎加入QQ群:193522571

AutoCAD Geometry库中的CurveCurveIntersector3d获取的交点坐标不正确

复制代码
        /// <summary>
        /// 2022年10月17日 Author:Myzw
        /// 
        /// </summary>
        [CommandMethod("Test14")]
        public void C_Test14()
        {
            var per1 = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Editor.GetEntity("\nPick Polyline 1");
            if (per1.Status != PromptStatus.OK) return;
            var per2 = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Editor.GetEntity("\nPick Polyline 2");
            if (per2.Status != PromptStatus.OK) return;
            using (Transaction tr = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.TransactionManager.StartTransaction())
            {
                BlockTable bt = (BlockTable)tr.GetObject(Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Database.BlockTableId, OpenMode.ForRead, false);
                BlockTableRecord btr = (BlockTableRecord)tr.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForWrite, false);
                var cur1 = (per1.ObjectId.GetObject(OpenMode.ForRead) as Curve).GetGeCurve();
                var cur2 = (per2.ObjectId.GetObject(OpenMode.ForRead) as Curve).GetGeCurve();
                var cci = new CurveCurveIntersector3d(cur1, cur2, Vector3d.ZAxis);
                for (int i = 0; i < cci.NumberOfIntersectionPoints ; i++)
                {
                    var pt = new DBPoint(cci.GetPointOnCurve1(i).Point);
                    btr.AppendEntity(pt);
                    tr.AddNewlyCreatedDBObject(pt, true);
                }
                tr.Commit();
            }
        }
复制代码

测试代码如上

当curve1为下图中的线段、curve2为多段线时,

得到的交点是错误的。

当curve1为多段线、curve2为线段时,

在附件的测试图中,

能得到正确的结果,

但在我的实际项目代码中,

即使我交换多段线和线段的顺序,

也无法获取正确的交点。

 

 

解决方法:

当曲线是线段或圆弧时,

将其拆分,

创建新的组合曲线,

之后用新建的组合曲线求交点,

可以得到正确的结果。

 

posted @   david96007  阅读(165)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?
点击右上角即可分享
微信分享提示