zoukankan      html  css  js  c++  java
  • 根据块名删除块和根据块名删除块引用 的区别

    ** 删除块后,块引用如果有那么依然存在,打开文件时会报错
    ** 删除块引用后块一定存在
     最好的办法是先全部删除块引用,然后再删除块,这样在打开图纸时才不会报错
     以下是写好的现成的两个方法

    //根据块名删除块引用
            internal static void DeleteBlockRefByBlockName(Database db, string strBlockName, string strBlockName1)
            {
                Transaction tr = db.TransactionManager.StartTransaction();
                using (tr)
                {
                    BlockTable bt = tr.GetObject(db.BlockTableId, OpenMode.ForWrite) as BlockTable;
                    BlockTableRecord btr = (BlockTableRecord)tr.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForWrite);
                    foreach (ObjectId objId in btr)
                    {
                        DBObject dbObj = tr.GetObject(objId, OpenMode.ForWrite);
                        if (dbObj is BlockReference )
                        {
                            BlockReference refEnt=dbObj as BlockReference ;
                            BlockTableRecord mtbtr = (BlockTableRecord)tr.GetObject(refEnt.BlockTableRecord , OpenMode.ForWrite);
                            if (mtbtr.Name.Equals(strBlockName) || (mtbtr.Name.Equals(strBlockName1)))
                            {
                                refEnt.Erase();
                            }
                        }
                    }
                    tr.Commit();
                }
            }

     


            //根据块名删除块
            internal static void DeleteBlockByBlockName(Database db,string strBlockName, string strBlockName1)
            {
                Transaction tr = db.TransactionManager.StartTransaction();
                using (tr)
                {
                    BlockTable bt = tr.GetObject(db.BlockTableId, OpenMode.ForWrite) as BlockTable;
                    foreach (ObjectId objId in bt)
                    {
                        BlockTableRecord bbtr = tr.GetObject(objId, OpenMode.ForWrite) as BlockTableRecord;
                        if (bbtr.Name.Equals(strBlockName) || (bbtr.Name.Equals(strBlockName1)))
                        {
                            bbtr.Erase();
                        }
                    }
                    tr.Commit();
                }
            }

  • 相关阅读:
    【赵强老师】使用Docker Compose进行服务编排
    【赵强老师】Weblogic域和域的组成
    【赵强老师】管理Docker镜像
    3. 清理统一审计 AUD$UNIFIED 基表部份数据
    4. AUD$UNIFIED 基表及 分区键创建索引
    2.更改统一审计AUD$UNIFIED基表 默认表空间
    1.更改统一审计AUD$UNIFIED 分区为1天
    9. 将APEX18.2 升级到 APEX19.2 详细步骤
    1.2 安装中文语言包
    通过VBOX 导入系统工具 搭建APEX开发环境
  • 原文地址:https://www.cnblogs.com/houlinbo/p/1563210.html
Copyright © 2011-2022 走看看