田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

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


站点统计

最新评论



Extents3d.AddExtents 隐藏日志,无权浏览
未知 Bounding Boxes around Blocks.   [ 日期:2018-01-16 ]   [ 来自:本站原创 ]  HTML
https://forums.autodesk.com/t5/net/bou ... und-blocks/td-p/3822317
   <CommandMethod("BBO")> _
    Public Sub testBlockBound()
        Dim doc As Document = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument
        Dim db As Database = doc.Database
        Dim ed As Editor = doc.Editor
        'Matrix3d ucs = ed.CurrentUserCoordinateSystem;
        Dim clon As BlockReference = Nothing
        doc.TransactionManager.EnableGraphicsFlush(True)
        Try
            Dim peo As New PromptEntityOptions(vbLf & "Select block: ")
            peo.SetRejectMessage("Only a block instance !")
            peo.AddAllowedClass(GetType(BlockReference), False)
            Dim per As PromptEntityResult = ed.GetEntity(peo)
            If per.Status <> PromptStatus.OK Then
                Return
            End If
            Dim id As ObjectId = per.ObjectId
            Using tr As Transaction = db.TransactionManager.StartTransaction()
                Dim ent As Entity = CType(tr.GetObject(id, OpenMode.ForRead), Entity)
                If ent Is Nothing Then
                    Return
                End If
                Dim bref As BlockReference = TryCast(ent, BlockReference)
                If bref Is Nothing Then
                    Return
                End If
                clon = TryCast(bref.Clone(), BlockReference)
                clon.Rotation = 0
                clon.TransformBy(ed.CurrentUserCoordinateSystem)
                tr.TransactionManager.QueueForGraphicsFlush()
                Dim ext As Extents3d = clon.GeometryExtentsBestFit(ed.CurrentUserCoordinateSystem)
                ext.TransformBy(ed.CurrentUserCoordinateSystem)
                Dim pl As New Polyline(4)
                Dim p1 As Point3d = ext.MinPoint.TransformBy(ed.CurrentUserCoordinateSystem)
                Dim p3 As Point3d = ext.MaxPoint.TransformBy(ed.CurrentUserCoordinateSystem)
                Dim p2 As Point3d = New Point3d(p3.X, p1.Y, p1.Z).TransformBy(ed.CurrentUserCoordinateSystem)
                Dim p4 As Point3d = New Point3d(p1.X, p3.Y, p1.Z).TransformBy(ed.CurrentUserCoordinateSystem)
                pl.AddVertexAt(0, New Point2d(p1.X, p1.Y), 0.0, 0.0, 0.0)
                pl.AddVertexAt(1, New Point2d(p2.X, p2.Y), 0.0, 0.0, 0.0)
                pl.AddVertexAt(2, New Point2d(p3.X, p3.Y), 0.0, 0.0, 0.0)
                pl.AddVertexAt(3, New Point2d(p4.X, p4.Y), 0.0, 0.0, 0.0)
                pl.Closed = True
                pl.ColorIndex = 121
                pl.TransformBy(ed.CurrentUserCoordinateSystem)
                Dim rot As Matrix3d = Matrix3d.Rotation(bref.Rotation, bref.Normal.GetNormal(), bref.Position)
                pl.TransformBy(rot)
                Dim btr As BlockTableRecord = CType(tr.GetObject(db.CurrentSpaceId, OpenMode.ForWrite), BlockTableRecord)
                btr.AppendEntity(pl)
                tr.AddNewlyCreatedDBObject(pl, True)
                tr.TransactionManager.QueueForGraphicsFlush()
                doc.TransactionManager.FlushGraphics()
                tr.Commit()
            End Using
        Catch e As System.Exception
            ed.WriteMessage(vbLf & "Error: {0}" & vbLf & "{1}", e.Message, e.StackTrace)
        Finally
            If Not clon.IsDisposed Then
                clon.Dispose()
                'optional
            End If
        End Try
    End Sub




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

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

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