田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

站点日历
73 2024 - 4 48
 123456
78910111213
14151617181920
21222324252627
282930


站点统计

最新评论



天正过期限制去除补丁 VB.NET中将圆转成多段线
未知 圆外一点到圆的切线   [ 日期:2011-12-25 ]   [ 来自:本站原创 ]  HTML
按此在新窗口打开图片
Imports Autodesk.AutoCAD.Geometry
Imports Autodesk.AutoCAD.EditorInput
Imports Autodesk.AutoCAD.DatabaseServices
Imports Autodesk.AutoCAD.Runtime
Imports Autodesk.AutoCAD.ApplicationServices
Public Class 切线
    '以点P到圆C圆心的线段为直径的圆NewC与圆C的两个交点即为点P到圆C的两个切点
    <CommandMethod("qieXian")> _
    Public Sub test()
        Dim acDoc As Document = Application.DocumentManager.MdiActiveDocument
        Dim acDb As Database = acDoc.Database
        Dim acEd As Editor = acDoc.Editor
        Dim acTrans As Transaction = acDb.TransactionManager.StartTransaction()
        Dim Bt As BlockTable = TryCast(acTrans.GetObject(acDb.BlockTableId, OpenMode.ForRead), BlockTable)
        Dim Btr As BlockTableRecord = TryCast(acTrans.GetObject(Bt(BlockTableRecord.ModelSpace), OpenMode.ForWrite), BlockTableRecord)
        Dim C As New Circle()
        Dim P As New Point3d()
        '选取一个圆
        Dim acTypedValue As TypedValue() = New TypedValue(0) {}
        acTypedValue.SetValue(New TypedValue(0, "CIRCLE"), 0)
        Dim acSelFtr As New SelectionFilter(acTypedValue)
        Dim acPromptSelectionResult As PromptSelectionResult = acEd.GetSelection(acSelFtr)
        If acPromptSelectionResult.Status = PromptStatus.OK Then
            Dim Ss As SelectionSet = acPromptSelectionResult.Value
            C = TryCast(acTrans.GetObject(Ss(0).ObjectId, OpenMode.ForRead), Circle)
        End If
        '选取一个点
        Dim acPromptPointResult As PromptPointResult
        Dim acPromptPointOptions As PromptPointOptions = New PromptPointOptions("圆外选取一点:")
        acPromptPointResult = acDoc.Editor.GetPoint(acPromptPointOptions)
        If acPromptPointResult.Status = PromptStatus.OK Then
            P = acPromptPointResult.Value
        End If

        Dim P2PCenter As New Point3d((P.X + C.Center.X) / 2, (P.Y + C.Center.Y) / 2, 0) ' 点到圆心的中点
        Dim V As Vector3d = P.GetVectorTo(P2PCenter)
        Dim R As Double = V.Length
        If R <= C.Radius Then
            acEd.WriteMessage(vbLf & "点在圆内,不存在圆切线,请重新选择点:")
        End If
        Dim NewC As New Circle()
        NewC.SetDatabaseDefaults()
        NewC.Radius = R
        NewC.Center = P2PCenter
        '切点
        Dim QieDians As New Point3dCollection()
        NewC.IntersectWith(C, Intersect.OnBothOperands, QieDians, 0, 0)
        '画切线
        For Each QD As Point3d In QieDians
            Dim L As New Line(QD, P)
            Btr.AppendEntity(L)
            acTrans.AddNewlyCreatedDBObject(L, True)
        Next
        acTrans.Commit()
        acTrans.Dispose()
    End Sub
End Class

【圆外一点到圆的切线.rar】点击下载此文件




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

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

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