批量改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();
     }
 }

插件联系↓↓↓

相关推荐
这个DBA有点耶14 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶16 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
镜舟科技17 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend18 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence21 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说2 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils2 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
Databend2 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent
这个DBA有点耶2 天前
SQL改写进阶:标量子查询的“隐形代价”与消除实战
数据库·mysql·架构
smallyoung2 天前
数据库乐观锁深度解析:MySQL、PostgreSQL 实战 + Spring Boot 集成指南
数据库·mysql·postgresql