田草博客





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

邮箱:tiancao1001x126.com
日志首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范
-电信用户-|-网通用户-
-博客论坛-|-软件下载-
-网站导航-|-建筑书店-
-BelovedFLash欣赏-
-来路-|-随机-|-分布-

用户登陆
用户:
密码:
 

站点日历
73 2018 - 1 48
 123456
78910111213
14151617181920
21222324252627
28293031


站点统计

最新评论

日志搜索

 标题   内容 评论


Creating an AutoCAD Wipeout using .NET IntersectWith
未知 用PL2将PL1线打断后,删除PL2内部部分,保留外部部分   [ 日期:2017-09-12 ]   [ 来自:本站原创 ]  HTML


'用PL2将PL1线打断后,删除PL2内部部分,保留外部部分
    <CommandMethod("PLBreak")> _
    Public Sub PLBreak()
        On Error Resume Next
        Dim acDoc As Document = Application.DocumentManager.MdiActiveDocument
        Dim acCurDb As Database = acDoc.Database
        Using acTrans As Transaction = acCurDb.TransactionManager.StartTransaction()
            Dim acTypValAr(0) As TypedValue
            acTypValAr.SetValue(New TypedValue(DxfCode.Start, "LWPOLYLINE"), 0)
            Dim acSelFtr As SelectionFilter = New SelectionFilter(acTypValAr)
            Dim acSSPrompt As PromptSelectionResult = acDoc.Editor.GetSelection(acSelFtr)
            If acSSPrompt.Status = PromptStatus.OK Then '选择成功
                Dim acSSet As SelectionSet = acSSPrompt.Value
                Dim Pts As Point3dCollection = New Point3dCollection
                Dim PL1 As Polyline = acTrans.GetObject(acSSet.Item(0).ObjectId, OpenMode.ForWrite) '打断PL1
                Dim PL2 As Polyline = acTrans.GetObject(acSSet.Item(1).ObjectId, OpenMode.ForWrite)
                PL1.IntersectWith(PL2, Intersect.ExtendBoth, New Plane, Pts, 0, 0)
                Dim Dbs As DBObjectCollection = PL1.GetSplitCurves(Pts)
                '打断后,删除PL2内的部分,保留PL2外部部分
                For Each E As Entity In Dbs
                    If E.GeometricExtents.MinPoint.X < PL2.GeometricExtents.MinPoint.X _
                         Or E.GeometricExtents.MinPoint.Y < PL2.GeometricExtents.MinPoint.Y _
                         Or E.GeometricExtents.MaxPoint.X > PL2.GeometricExtents.MaxPoint.X _
                         Or E.GeometricExtents.MaxPoint.Y > PL2.GeometricExtents.MaxPoint.Y Then
                        AddEnt(E)
                    End If
                Next
                PL1.Erase()
                acTrans.Commit()
            End If
        End Using
        If Err.Number > 0 Then
            MsgBox(Err.Description)
        End If
    End Sub





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

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

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
版权所有:田草博客
tiancao1001&126.com网友交流QQ群:11740834
Powered by L-Blog V1.08 (SE) Final© 2007-2009