找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1869|回复: 2

[原创] 练习 断开与所选线相交的线

[复制链接]

已领礼包: 859个

财富等级: 财运亨通

发表于 2014-4-26 09:58:59 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
[ 本帖最后由 csharp 于 2014-4-26 10:25 编辑 ]\n\n[ 本帖最后由 csharp 于 2014-4-26 10:20 编辑 ]
  1.         [CommandMethod("MyGroup", "MyCommand", "MyCommandLocal", CommandFlags.Modal)]
  2.         public void MyCommand() // This method can have any name
  3.         {
  4.             Document doc = Application.DocumentManager.MdiActiveDocument;
  5.             Editor ed = doc.Editor;
  6.             Database db = doc.Database;
  7.             Transaction tr = db.TransactionManager.StartTransaction();
  8.             BlockTableRecord Spase = (BlockTableRecord)tr.GetObject(db.CurrentSpaceId, OpenMode.ForWrite);
  9.             PromptSelectionOptions selectionOptions = new PromptSelectionOptions();
  10.             selectionOptions.RejectObjectsOnLockedLayers = true;
  11.             SelectionFilter selectionFilter = new SelectionFilter(
  12.                 new TypedValue[] {new TypedValue(0, "*line")}
  13.                 );
  14.             selectionOptions.MessageForAdding = "\n选择线: ";
  15.             PromptSelectionResult ssResult = ed.GetSelection(selectionOptions, selectionFilter);
  16.             if (ssResult.Status != PromptStatus.OK) return;
  17.             ObjectId oId = ssResult.Value.GetObjectIds()[0];
  18.             using (tr)
  19.             {
  20.                 try
  21.                 {
  22.                     Point3dCollection pts = new Point3dCollection();
  23.                     Entity cvEntity = (Entity) tr.GetObject(ssResult.Value.GetObjectIds()[0], OpenMode.ForRead);
  24.                     cvEntity.GetStretchPoints(pts);
  25.                     PromptSelectionResult ssSet = ed.SelectFence(pts, selectionFilter);
  26.                     if (ssSet.Status != PromptStatus.OK) return;
  27.                     SelectionSet selectionSet = ssSet.Value;
  28.                     var  ids = ssSet.Value .GetObjectIds() ;
  29.                     for (int i = 0; i < ids  .Length  ; i++)
  30.                         {
  31.                             ObjectId id = ids[i];
  32.                             if (id != oId)//排除断开线
  33.                             {
  34.                                 FenceSelectedObject fsSelectedObject = selectionSet[i] as FenceSelectedObject;
  35.                                 Point3d pt = fsSelectedObject.GetIntersectionPoints()[0].PointOnLine;
  36.                                 Curve cv = (Curve)tr.GetObject(id, OpenMode.ForWrite);
  37.                                 Point3d pt1 = cv.GetClosestPointTo(pt, true);
  38.                                 double pam = cv.GetParameterAtPoint(pt1);
  39.                                 if (pam > 1e-6)
  40.                                 {
  41.                                     DoubleCollection pamDoubleCollection = new DoubleCollection();
  42.                                     pamDoubleCollection.Add(pam);
  43.                                     DBObjectCollection cvsCollection = cv.GetSplitCurves(pamDoubleCollection);
  44.                                     foreach (DBObject o in cvsCollection)
  45.                                     {
  46.                                         Spase.AppendEntity((Entity)o);
  47.                                         tr.AddNewlyCreatedDBObject(o, true);
  48.                                     }
  49.                                 }
  50.                             }
  51.                     }
  52.                     tr.Commit();
  53.                 }
  54.                 catch (Exception)
  55.                 {
  56.                     throw;
  57.                 }
  58.             }
  59.         }
  60.     }

网上看了几个类似功能程序,都是用的IntersectWith,上面的程序用了 GetInterselectionPoints(),但是只取了一个交点,不适合有多个交点情况,以后改进,这个和 ssnamex 中取得穿越点一样,但是不适合Z值不同的 3D 线,标高要在一个平面上

另外不知道和UCS有无关系,仅在 WCS测试Ok

选择线要在可见范围内
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2014-5-14 10:57:52 | 显示全部楼层
c语言不知道如何运行操作,望指教!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 859个

财富等级: 财运亨通

 楼主| 发表于 2014-5-14 13:40:27 来自手机 | 显示全部楼层
2008以上,VS编译为DLL,用netload加载
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-12-23 10:07 , Processed in 0.184377 second(s), 31 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表