明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1245|回复: 2

将图块开

[复制链接]
发表于 2013-1-29 13:37:44 | 显示全部楼层 |阅读模式
''' <summary>
    ''' 根据名称来炸碎块
    ''' </summary>
    ''' <param name="BlockName">块名称</param>
    ''' <param name="DeleteOrignialBlock">是否删除原来的块</param>
    ''' <returns></returns>
    ''' <remarks></remarks>
    Public Function ExplodeBlock(ByVal BlockName As String, Optional ByVal DeleteOrignialBlock As Boolean = True) As Boolean
        Using Trans As Transaction = DB.TransactionManager.StartTransaction
            Dim BlkT As BlockTable = Trans.GetObject(DB.BlockTableId, OpenMode.ForRead)
            If BlkT.Has(BlockName) Then
                Dim BlkR As BlockTableRecord = Trans.GetObject(BlkT(BlockName), OpenMode.ForRead)
                Dim ModelSpace As BlockTableRecord = Trans.GetObject(BlkT(BlockTableRecord.ModelSpace), OpenMode.ForWrite)
                Dim IDs As ObjectIdCollection = BlkR.GetBlockReferenceIds(True, False)
                Dim TempColl As New DBObjectCollection
                For Each ID As ObjectId In IDs
                    Dim BlkRef As BlockReference = Trans.GetObject(ID, OpenMode.ForWrite)
                    BlkRef.Explode(TempColl)
                    For Each Ent As Entity In TempColl
                        ModelSpace.AppendEntity(Ent)
                        Trans.AddNewlyCreatedDBObject(Ent, True)
                    Next
                    TempColl.Clear()
                    If DeleteOrignialBlock Then
                        BlkRef.Erase()
                    End If
                Next
                ExplodeBlock = True
            Else
                ExplodeBlock = False
            End If
            Trans.Commit()
        End Using
    End Function

    ''' <summary>
    ''' 炸开图块
    ''' </summary>
    ''' <param name="IDs"></param>
    ''' <param name="DeleteOrignialBlock">是否删除原来的块</param>
    ''' <returns></returns>
    ''' <remarks></remarks>
    Public Function ExplodeBlock(ByVal IDs() As ObjectId, Optional ByVal DeleteOrignialBlock As Boolean = True) As Boolean()
        Dim bResult(IDs.Length - 1) As Boolean
        Using Trans As Transaction = DB.TransactionManager.StartTransaction
            Dim BlkT As BlockTable = Trans.GetObject(DB.BlockTableId, OpenMode.ForRead)
            Dim BlkR As BlockTableRecord = Trans.GetObject(BlkT(BlockTableRecord.ModelSpace), OpenMode.ForWrite)
            Dim obj As DBObject = Nothing, blk As BlockReference = Nothing
            Dim TempColl As New DBObjectCollection
            For I As Integer = 0 To IDs.Length - 1
                obj = Trans.GetObject(IDs(I), OpenMode.ForWrite)
                If TypeOf obj Is BlockReference Then
                    blk = obj
                    blk.Explode(TempColl)
                    For Each Ent As Entity In TempColl
                        BlkR.AppendEntity(Ent)
                        Trans.AddNewlyCreatedDBObject(Ent, True)
                    Next
                    If DeleteOrignialBlock Then
                        blk.Erase()
                    End If
                    bResult(I) = True
                    TempColl.Clear()
                End If
            Next
            Trans.Commit()
        End Using
        ExplodeBlock = bResult
    End Function

发表于 2014-11-17 15:08:45 | 显示全部楼层
我收藏了,谢谢!
发表于 2014-11-24 12:58:31 | 显示全部楼层
学习了,先收藏再说
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-25 12:49 , Processed in 0.144055 second(s), 23 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表