根据块名删除块和根据块名删除块引用 的区别

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

//根据块名删除块引用
        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();
            }
        }

转载于:https://www.cnblogs.com/houlinbo/archive/2009/09/09/1563210.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值