AutoCAD 二次开发:获取填充边界

本文探讨了在AutoCAD二次开发中如何有效地获取填充边界的详细步骤和技术,适用于C++编程环境,为AutoCAD插件开发提供关键指导。
摘要由CSDN通过智能技术生成

AutoCAD 二次开发:获取填充边界

//遍历填充对象的边界信息。
bool CAcUiSelDialog::OpenDwgFile(const ACHAR* fileName)
{
    Acad::ErrorStatus es;
    //AcDbObjectIdArray objectIds ;         //边界id数组
    AcGeVector3d normal;                    //填充平面
    bool bAssociative;                      //关联型
    AcDbHatch::HatchPatternType patternType;//填充图案类型
    const ACHAR *patternName;               //填充图案名
    AcDbHatch::HatchStyle   hatchStyle;
    //2.读取.dwg文件
    AcDbDatabase *pDb = new AcDbDatabase(Adesk::kFalse); 
    es=pDb->readDwgFile(_T("D:\\***.dwg")); //.dwg文件路径
    if (Acad::eOk!=es)
    {
        acedAlert(_T("临时数据库打开失败"));
        delete pDb;
        return false;
    }
    //3.获取块表
    AcDbBlockTable *pBlkTbl; 
    es=pDb->getSymbolTable(pBlkTbl, AcDb::kForRead); 
    if (Acad::eOk!=es)
    {
        acedAlert(_T("获取块表错误!"));
        delete pDb;
        pBlkTbl->close();
        return false;
    }
    //4.获取块表记录
    AcDbBlockTableRecord *pBlkTblRcd; 
    es=pBlkTbl->getAt(ACDB_MODEL_SPACE, pBlkTblRcd,AcDb::kForRead); 
    if (Acad::eOk!=es)
    {
        delete pDb;
        pBlkTbl->close();
        pBlkTblRcd->close();
        acedAlert(_T("获取块表记录错误!"));
        return false;
    }
    pBlkTbl->close(); 

    //5.创建块表记录迭代器,遍历模型空间块表记录
    CString hClass;  
    AcDbBlockTableRecordIterator *pBlkTblRcdItr; 
    pBlkTblRcd->newIterator(pBlkTblRcdItr); 

    AcGePoint3d *pPt3D = new AcGePoint3d();
    if (NULL == pPt3D)
    {
        pBlkTblRcd->close();
        delete pDb;
        //delete pHatch;
        delete pBlkTblRcdItr;
        return false;
    }
    //遍历块表记录中的实体
    for (pBlkTblRcdItr
以下是C#二次开发CAD填充代码的示例: ```csharp using Autodesk.AutoCAD.ApplicationServices; using Autodesk.AutoCAD.DatabaseServices; using Autodesk.AutoCAD.EditorInput; using Autodesk.AutoCAD.Runtime; using Autodesk.AutoCAD.Geometry; using System; namespace FillPolyline { public class Commands { [CommandMethod("FillPolyline")] public void FillPolyline() { Document doc = Application.DocumentManager.MdiActiveDocument; Database db = doc.Database; Editor ed = doc.Editor; // 选择多段线 PromptEntityOptions peo = new PromptEntityOptions("\n选择多段线: "); peo.SetRejectMessage("\n必须选择一个多段线!"); peo.AddAllowedClass(typeof(Polyline), true); PromptEntityResult per = ed.GetEntity(peo); if (per.Status != PromptStatus.OK) return; using (Transaction tr = db.TransactionManager.StartTransaction()) { Polyline pline = tr.GetObject(per.ObjectId, OpenMode.ForWrite) as Polyline; if (pline == null) return; // 创建填充对象 Hatch hatch = new Hatch(); hatch.SetDatabaseDefaults(); hatch.Layer = pline.Layer; hatch.ColorIndex = pline.ColorIndex; hatch.PatternScale = 1.0; // 设置填充类型 hatch.PatternType = HatchPatternType.PreDefined; hatch.PatternName = "SOLID"; // 获取多段线边界 Point3dCollection pts = new Point3dCollection(); for (int i = 0; i < pline.NumberOfVertices; i++) { pts.Add(pline.GetPoint3dAt(i)); } // 添加填充边界 hatch.AppendLoop(HatchLoopTypes.Outermost, pts); // 将填充对象添加到模型空间 BlockTableRecord btr = tr.GetObject(db.CurrentSpaceId, OpenMode.ForWrite) as BlockTableRecord; btr.AppendEntity(hatch); tr.AddNewlyCreatedDBObject(hatch, true); // 关联填充对象和多段线 hatch.Associative = true; hatch.AppendLoop(HatchLoopTypes.Default, new ObjectIdCollection() { pline.ObjectId }); hatch.EvaluateHatch(true); tr.Commit(); } } } } ``` 上述代码中,通过 `PromptEntityOptions` 和 `ed.GetEntity` 方法选择了一个多段线,然后创建了一个填充对象并将其添加到模型空间。最后,通过将填充对象与多段线关联,实现了填充功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值