田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

站点日历
73 2025 - 10 48
   1234
567891011
12131415161718
19202122232425
262728293031


站点统计

最新评论



这八个CAD命令只要会了一半就可以称为大咖了,全部都会的人据说全国不到百分之一(上) 隐藏日志,无权浏览
未知 Zooming to a window or entity inside AutoCAD   [ 日期:2019-03-30 ]   [ 来自:本站原创 ]  HTML
https://through-the-interface.typepad.com/thro ... 2008/06/zooming-to-a-wi.html

Zooming to a window or entity inside AutoCAD with .NET

程序代码:
Imports Autodesk.AutoCAD.Interop
Imports Autodesk.AutoCAD.Geometry
Imports Autodesk.AutoCAD.Runtime
Imports Autodesk.AutoCAD.EditorInput
Imports Autodesk.AutoCAD.DatabaseServices
Imports Autodesk.AutoCAD.ApplicationServices

Namespace ZoomZoom
    Public Class Commands
        ' Zoom to a window specified by the user
        <CommandMethod("ZW")> _
        Public Shared Sub ZoomWindow()
            Dim doc As Document = Application.DocumentManager.MdiActiveDocument
            Dim db As Database = doc.Database
            Dim ed As Editor = doc.Editor

            ' Get the window coordinates

            Dim ppo As New PromptPointOptions(vbLf & "Specify first corner:")
            Dim ppr As PromptPointResult = ed.GetPoint(ppo)
            If ppr.Status <> PromptStatus.OK Then
                Return
            End If
            Dim min As Point3d = ppr.Value
            Dim pco As New PromptCornerOptions(vbLf & "Specify opposite corner: ", ppr.Value)
            ppr = ed.GetCorner(pco)
            If ppr.Status <> PromptStatus.OK Then
                Return
            End If
            Dim max As Point3d = ppr.Value
            
            ' Call out helper function
            ' [Change this to ZoomWin2 or WoomWin3 to
            ' use different zoom techniques]
            ZoomWin(ed, min, max)
        End Sub

        ' Zoom to the extents of an entity
        <CommandMethod("ZE")> _
        Public Shared Sub ZoomToEntity()
            Dim doc As Document = Application.DocumentManager.MdiActiveDocument
            Dim db As Database = doc.Database
            Dim ed As Editor = doc.Editor
            ' Get the entity to which we'll zoom
            Dim peo As New PromptEntityOptions(vbLf & "Select an entity:")
            Dim per As PromptEntityResult = ed.GetEntity(peo)
            If per.Status <> PromptStatus.OK Then
                Return
            End If
            ' Extract its extents
            Dim ext As Extents3d
            Dim tr As Transaction = db.TransactionManager.StartTransaction()
            Using tr
                Dim ent As Entity = CType(tr.GetObject(per.ObjectId, OpenMode.ForRead), Entity)
                ext = ent.GeometricExtents
                tr.Commit()
            End Using
            ext.TransformBy(ed.CurrentUserCoordinateSystem.Inverse())
            ' Call our helper function
            ' [Change this to ZoomWin2 or WoomWin3 to
            ' use different zoom techniques]
            ZoomWin(ed, ext.MinPoint, ext.MaxPoint)
        End Sub
        ' Helper functions to zoom using different techniques
        ' Zoom using a view object
        Private Shared Sub ZoomWin(ed As Editor, min As Point3d, max As Point3d)
            Dim min2d As New Point2d(min.X, min.Y)
            Dim max2d As New Point2d(max.X, max.Y)
            Dim view As New ViewTableRecord()
            view.CenterPoint = min2d + ((max2d - min2d) / 2.0)
            view.Height = max2d.Y - min2d.Y
            view.Width = max2d.X - min2d.X
            ed.SetCurrentView(view)
        End Sub

        ' Zoom via COM
        Private Shared Sub ZoomWin2(ed As Editor, min As Point3d, max As Point3d)
            Dim app As AcadApplication = CType(Application.AcadApplication, AcadApplication)
            Dim lower As Double() = New Double(3) {min.X, min.Y, min.Z}
            Dim upper As Double() = New Double(3) {max.X, max.Y, max.Z}
            app.ZoomWindow(lower, upper)
        End Sub
        ' Zoom by sending a command
        Private Shared Sub ZoomWin3(ed As Editor, min As Point3d, max As Point3d)
            Dim lower As String = min.ToString().Substring(1, min.ToString().Length - 2)
            Dim upper As String = max.ToString().Substring(1, max.ToString().Length - 2)
            Dim cmd As String = "_.ZOOM _W " + lower + " " + upper + " "
            ' Call the command synchronously using COM
            Dim app As AcadApplication = CType(Application.AcadApplication, AcadApplication)
            app.ActiveDocument.SendCommand(cmd)
            ' Could also use async command calling:
            'ed.Document.SendStringToExecute(
            '  cmd, true, false, true
            ');
        End Sub
    End Class
End Namespace


[本日志由 tiancao1001 于 2019-03-30 09:07 AM 编辑]


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

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

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