田草博客

互联网田草博客


网友交流QQ群:11740834 需注明申请加入原因

微信 公众号:ByCAD

邮箱:tiancao1001x126.com
ByCAD,微信公众号
首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范 | 软件 | ID
-随机-|-分布-
-博客论坛-|-﨣﨤﨧﨨-
-网站导航-|-规范下载-
-BelovedFLash欣赏-

用户登陆
用户:
密码:
 

站点日历
73 2024 - 12 48
1234567
891011121314
15161718192021
22232425262728
293031


站点统计

最新评论



VBA有GetBoundingBox到.net有GeometricExtents .Net 让窗体成为AutoCAD的子窗体
未知 快速创建块(将选择的对象创建成一个块,在原来的位置插入盖参照块)   [ 日期:2009-10-26 ]   [ 来自:本站原创 ]  HTML

'快速创建块(将选择的对象创建成一个块,在原来的位置插入盖参照块)
Public Class Class6
    <CommandMethod("NiMingBlock")> _
    Public Sub NiMingBlock()
        Dim acDoc As Document = Application.DocumentManager.MdiActiveDocument
        Dim acCurDb As Database = acDoc.Database

        Dim acEditor As Editor = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Editor
        Dim Record As BlockTableRecord = New BlockTableRecord
        Dim Name As String
        Name = Replace("TC_" & System.DateTime.Now.ToString, " ", "")
        Name = Replace(Name, "-", "")
        Name = Replace(Name, ":", "")
        Record.Name = Name
        Using acTrans As Transaction = acCurDb.TransactionManager.StartTransaction()
            Dim BlockTable As BlockTable = acTrans.GetObject(acCurDb.BlockTableId, _
                                         OpenMode.ForWrite)
            Dim acSSPrompt As PromptSelectionResult = acDoc.Editor.GetSelection()
            If acSSPrompt.Status = PromptStatus.OK Then '选择成功
                Dim acSSet As SelectionSet = acSSPrompt.Value
                Dim acEnt As Entity = acTrans.GetObject(acSSet.Item(0).ObjectId, _
                                                  OpenMode.ForRead)
                '得到第一个对象的一个角点
                Dim P3D As Point3d = acEnt.GeomExtents.MinPoint
                Record.Origin = P3D
                '创建一个块
                For Each acSSObj As SelectedObject In acSSet
                    Dim Ent As Entity = acTrans.GetObject(acSSObj.ObjectId, OpenMode.ForWrite)
                    Dim NewEnt As Entity = Ent.Clone
                    Ent.Erase()
                    Record.AppendEntity(NewEnt)
                Next
                BlockTable.Add(Record)
                acTrans.AddNewlyCreatedDBObject(Record, True)
                '插入参照块
                Dim acBlkTblRec As BlockTableRecord
                acBlkTblRec = acTrans.GetObject(BlockTable(BlockTableRecord.ModelSpace), _
                                                OpenMode.ForWrite)
                Dim BlockRef As BlockReference = New BlockReference(P3D, Record.ObjectId)
                acBlkTblRec.AppendEntity(BlockRef)
                acTrans.AddNewlyCreatedDBObject(BlockRef, True)
            End If
            acTrans.Commit()
        End Using
    End Sub
End Class




暂时没有评论
发表评论 - 不要忘了输入验证码哦!
作者: 用户:  密码:   注册? 验证:  防止恶意留言请输入问题答案:2*6=?  
评论:

禁止表情
禁止UBB
禁止图片
识别链接
识别关键字

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
Tiancao Blog All Rights Reserved 田草博客 版权所有
Copyright ©