田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

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


站点统计

最新评论



圆外一点到圆的切线 AutoCAD直线删除保护和对象删除监视
未知 VB.NET中将圆转成多段线   [ 日期:2011-12-25 ]   [ 来自:转帖 ]  HTML
Imports Autodesk.AutoCAD.Runtime
Imports Autodesk.AutoCAD.Geometry
Imports Autodesk.AutoCAD.ApplicationServices
Imports Autodesk.AutoCAD.DatabaseServices
Imports Autodesk.AutoCAD.EditorInput
Namespace CADTest
    Public Class Class1
        <CommandMethod("c2p")> _
        Public Sub CircleToPloyline()
            Dim doc As Document = Application.DocumentManager.MdiActiveDocument
            Dim db As Database = doc.Database
            Dim ed As Editor = doc.Editor
            Dim trans As Transaction = db.TransactionManager.StartTransaction()
            Dim bt As BlockTable = DirectCast(trans.GetObject(db.BlockTableId, OpenMode.ForRead), BlockTable)
            Dim btr As BlockTableRecord = DirectCast(trans.GetObject(db.CurrentSpaceId, OpenMode.ForWrite), BlockTableRecord)
            Dim psr As PromptSelectionResult = ed.GetSelection()
            '获取选择集,这里就不过滤了
            Dim ss As SelectionSet = Nothing
            If psr.Status = PromptStatus.OK Then
                ss = psr.Value
                For Each so As SelectedObject In ss
                    Dim c As Circle = TryCast(trans.GetObject(so.ObjectId, OpenMode.ForWrite), Circle)
                    Dim r As Double = c.Radius
                    Dim cc As Point3d = c.Center
                    Dim p1 As New Point2d(cc.X + r, cc.Y)
                    Dim p2 As New Point2d(cc.X - r, cc.Y)
                    Dim poly As New Polyline()
                    poly.AddVertexAt(0, p1, 1, 0, 0)
                    poly.AddVertexAt(1, p2, 1, 0, 0)
                    poly.AddVertexAt(2, p1, 1, 0, 0)
                    btr.AppendEntity(poly)
                    trans.AddNewlyCreatedDBObject(poly, True)
                    c.[Erase](True)
                Next
            End If
            trans.Commit()
            trans.Dispose()
        End Sub
        <CommandMethod("GET")> _
        Public Sub GetEntityType()
            Dim doc As Document = Application.DocumentManager.MdiActiveDocument
            Dim db As Database = doc.Database
            Dim ed As Editor = doc.Editor
            Dim peo As New PromptEntityOptions("请选择一个实体")
            Dim per As PromptEntityResult = Nothing
            Try
                per = ed.GetEntity(peo)
                If per.Status = PromptStatus.OK Then
                    Dim id As ObjectId = per.ObjectId
                    Dim trans As Transaction = db.TransactionManager.StartTransaction()
                    Dim ent As Entity = DirectCast(trans.GetObject(id, OpenMode.ForRead, True), Entity)
                    ed.WriteMessage("实体ObjectId为:" & ent.ObjectId.ToString & "实体类型为:" & ent.[GetType]().FullName)
                    trans.Commit()
                    trans.Dispose()
                End If
            Catch exc As Autodesk.AutoCAD.Runtime.Exception
                ed.WriteMessage("发生异常,原因为:" + exc.Message)
            End Try
        End Sub
    End Class
End Namespace

C#代码和VB.Net代码

【.NET中将圆转成多义线.pdf】点击下载此文件

【VB.NET中将圆转成多义线.rar】点击下载此文件

[本日志由 tiancao1001 于 2011-12-26 09:33 PM 编辑]


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

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

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