乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 51|回复: 2

将图块开

[复制链接]

75

主题

306

帖子

10

银币

中流砥柱

Rank: 25

铜币
606
发表于 2013-1-29 13:37:00 | 显示全部楼层 |阅读模式
'''
    ''' 根据名称来炸碎块
    '''
    ''' 块名称
    ''' 是否删除原来的块
    '''
    '''
    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
    '''
    ''' 炸开图块
    '''
    '''
    ''' 是否删除原来的块
    '''
    '''
    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
回复

使用道具 举报

1

主题

16

帖子

9

银币

初来乍到

Rank: 1

铜币
22
发表于 2014-11-17 15:08:00 | 显示全部楼层
我收藏了,谢谢!
回复

使用道具 举报

14

主题

64

帖子

4

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
120
发表于 2014-11-24 12:58:00 | 显示全部楼层
学习了,先收藏再说
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-14 13:18 , Processed in 0.368227 second(s), 58 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表