明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1606|回复: 5

Brep brep = new Brep(region );//出现异常

[复制链接]
发表于 2015-5-28 21:17:34 | 显示全部楼层 |阅读模式
using Autodesk.AutoCAD.ApplicationServices;
using Autodesk.AutoCAD.Runtime;
using Autodesk.AutoCAD.DatabaseServices;
using Autodesk.AutoCAD.EditorInput;
using Autodesk.AutoCAD.Windows;
using Autodesk.AutoCAD.ViewModel;
using Autodesk.AutoCAD.Publishing;
using Autodesk.AutoCAD.PlottingServices;
using Autodesk.AutoCAD.LivePreview;
using Autodesk.AutoCAD.LayerManager;
using Autodesk.AutoCAD.Interop;
using Autodesk.AutoCAD.Internal;
using Autodesk.AutoCAD.GraphicsSystem;
using Autodesk.AutoCAD.GraphicsInterface;
using Autodesk.AutoCAD.Geometry;
using Autodesk.AutoCAD.ComponentModel;
using Autodesk.AutoCAD.BoundaryRepresentation;
using Autodesk.AutoCAD.AcInfoCenterConn;

entity和entity2 为选中的相交的2个封闭polyline
using (Transaction tr = tm.StartTransaction())
                    {
                        BlockTable bt = (BlockTable)tr.GetObject(db.BlockTableId, OpenMode.ForRead);
                        BlockTableRecord btr = (BlockTableRecord)tr.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForWrite);
                        Entity entity = tr.GetObject(entityID, OpenMode.ForWrite) as Entity;
                        //MgGeometry geometry = EntityToGeometryConverter.EntityToGeometry(entity);
                        Entity entity2 = tr.GetObject(entityID2, OpenMode.ForWrite) as Entity;
                        DBObjectCollection curveSegments = new DBObjectCollection();
                        curveSegments.Add(entity);
                        DBObjectCollection regions = Region.CreateFromCurves(curveSegments);  
                        Region region = regions[0] as Region;
                        DBObjectCollection curveSegments2 = new DBObjectCollection();
                        curveSegments2.Add(entity2);
                        DBObjectCollection regions2 = Region.CreateFromCurves(curveSegments);
                        Region region2 = regions2[0] as Region;
                        region.BooleanOperation(BooleanOperationType.BoolSubtract, region2);
                        DBObjectCollection cvs =new DBObjectCollection();
                        //region.Explode(cvs);
                     
                        ObjectId id1 = cadLayer.AddLayer("冲突图斑");
                       // Entity en = region as Entity;
                        Brep brep = new Brep(region );//出现异常
                        BrepEdgeCollection elp = brep.Edges;
                        foreach (Edge edge in elp)
                        {
                            NurbCurve3d c3d = edge.GetCurveAsNurb();
                            Curve cv = Curve.CreateFromGeCurve(c3d);
                            cv.ColorIndex = 1;
                            cv.Layer = "冲突图斑";
                            btr.AppendEntity(cv);
                            tr.AddNewlyCreatedDBObject(cv, true);
                  
                        }
                                               
                        tr.Commit();
                    }
发表于 2015-5-28 21:38:55 来自手机 | 显示全部楼层
最好先用简单的例子测试下 brep库用的人很少
 楼主| 发表于 2015-5-28 21:49:34 | 显示全部楼层
这个是最简单的,选择2个entity 裁剪得到结果 解析
发表于 2015-5-29 09:35:26 | 显示全部楼层

  1.         [CommandMethod("testregion")]
  2.         public void RegionSubstr()
  3.         {
  4.             var doc = Application.DocumentManager.MdiActiveDocument;
  5.             var db = doc.Database;
  6.             var ed = doc.Editor;
  7.             var ent1 = ed.GetEntity("\nSelect Curve");
  8.             var ent2 = ed.GetEntity("\nSelect Curve");
  9.             using (var tr = db.TransactionManager.StartTransaction())
  10.             {
  11.                 var btr = (BlockTableRecord) tr.GetObject(db.CurrentSpaceId, OpenMode.ForWrite);
  12.                 var id1 = ent1.ObjectId;
  13.                 var id2 = ent2.ObjectId;
  14.                 var entity = tr.GetObject(id1, OpenMode.ForWrite) as Entity;
  15.                 var entity2 = tr.GetObject(id2, OpenMode.ForWrite) as Entity;
  16.                 var curveSegments = new DBObjectCollection {entity,entity2};

  17.                 var regions = Region.CreateFromCurves(curveSegments);

  18.                 var region = regions[0] as Region;
  19.                 var region1 = regions[1] as Region ;

  20.                 if (region != null)
  21.                 {
  22.                     region.BooleanOperation(BooleanOperationType.BoolSubtract, region1);

  23.                     var brep = new Brep(region);  
  24.                     var elp = brep.Edges;
  25.                     foreach (var cv in elp.Select(edge => edge.GetCurveAsNurb()).Select(c3d => Curve.CreateFromGeCurve(c3d)))
  26.                     {
  27.                         cv.ColorIndex = 1;
  28.                         //cv.Layer = "冲突图斑";
  29.                         btr.AppendEntity(cv);
  30.                         tr.AddNewlyCreatedDBObject(cv, true);
  31.                     }
  32.                 }
  33.                 tr.Commit();
  34.             }
  35.         }
发表于 2021-6-15 14:42:03 来自手机 | 显示全部楼层
为什么用edge.curve 得到的曲线 不能用createfromgecurve 生成db曲线呢
发表于 2021-6-15 14:42:46 来自手机 | 显示全部楼层
只能用edge.GetCurveAsNurb得到dbcurve
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 04:31 , Processed in 0.143948 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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