批量改CAD图层颜色——CAD c#二次开发

一个文件夹下大量图纸(几百甚至几千个文件)需要改图层颜色时,可采用插件实现,效果如下:

转换前:

转换后:

使用方式如下:netload加载此dll插件,输入xx运行。

附部分代码如下:

cs 复制代码
 public void ProcessDwgFile(string filePath, string savePath, string layerName, short colorIndex)
 {
     Database db = new Database(false, true); // 无文档模式

     try
     {
         // 读取DWG文件
         db.ReadDwgFile(filePath, FileOpenMode.OpenForReadAndAllShare, false, null);

         using (Transaction tr = db.TransactionManager.StartTransaction())
         {
             LayerTable lt = (LayerTable)tr.GetObject(db.LayerTableId, OpenMode.ForRead);

             // 用于存储找到的图层ID
             ObjectId layerId = ObjectId.Null;

             // 遍历所有图层名,进行不区分大小写的比较
             foreach (ObjectId id in lt)
             {
                 LayerTableRecord ltr = (LayerTableRecord)tr.GetObject(id, OpenMode.ForRead);
                 if (ltr.Name.Equals(layerName, StringComparison.OrdinalIgnoreCase))
                 {
                     layerId = id;
                     break;
                 }
             }

             // 如果未找到图层,跳过该文件
             if (layerId.IsNull)
             {
                 tr.Commit();
                 return;
             }

             LayerTableRecord ltrToModify = (LayerTableRecord)tr.GetObject(layerId, OpenMode.ForWrite);

             // 设置图层颜色(如果选择的不是ByLayer则设置图层颜色)
             if (colorIndex != 256)
             {
                 ltrToModify.Color = Color.FromColorIndex(ColorMethod.ByAci, colorIndex);
             }

             // 修改所有图元的颜色属性
             BlockTable bt = (BlockTable)tr.GetObject(db.BlockTableId, OpenMode.ForRead);
             BlockTableRecord btr = (BlockTableRecord)tr.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForRead);

             foreach (ObjectId entId in btr)
             {
                *****省略部分代码
             tr.Commit();
         }

         // 保存文件
         string fileName = Path.GetFileName(filePath);
         string saveFile = Path.Combine(savePath, fileName);
         db.SaveAs(saveFile, DwgVersion.Current);
     }
     catch (Exception ex)
     {
         MessageBox.Show($"处理文件 {filePath} 时出错: {ex.Message}");
     }
     finally
     {
         db.Dispose();
     }
 }

插件联系↓↓↓

相关推荐
王有品2 小时前
Spring MVC 多个拦截器的执行顺序
数据库·spring·mvc
极小狐2 小时前
如何使用极狐GitLab 的外部状态检查功能?
数据库·ci/cd·gitlab·devops·mcp
Leo.yuan3 小时前
数据仓库建设全解析!
大数据·数据库·数据仓库·数据分析·spark
闪电麦坤953 小时前
SQL:子查询(subqueries)
数据库·sql
活跃的煤矿打工人3 小时前
【星海出品】分布式存储数据库etcd
数据库·分布式·etcd
文牧之3 小时前
PostgreSQL的扩展 pgcrypto
运维·数据库·postgresql
程序员JerrySUN3 小时前
驱动开发硬核特训 · Day 22(下篇): # 深入理解 Power-domain 框架:概念、功能与完整代码剖析
linux·开发语言·驱动开发·嵌入式硬件
游离状态的猫14 小时前
JavaScript性能优化实战:从瓶颈定位到极致提速
开发语言·javascript·性能优化
GeekABC4 小时前
FastAPI系列06:FastAPI响应(Response)
开发语言·python·fastapi·web
小彭努力中4 小时前
7.Three.js 中 CubeCamera详解与实战示例
开发语言·前端·javascript·vue.js·ecmascript