找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1089|回复: 2

[原创]: 示例:连接直线为优化多义线

[复制链接]
发表于 2006-7-2 12:42:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
[php]
Sub jline()
    Dim obj As AcadLine, pnt
    Dim objs As New Collection
    Dim selobj As AcadLine
    Dim pnts As New Collection
    Dim i, j
    ThisDrawing.Utility.GetEntity obj, pnt
    Dim ss As New TlsSelectionSet
    pnts.Add obj.StartPoint
    pnts.Add obj.EndPoint
    objs.Add obj
   
    '从选择线起点找起,一直到没有连接的直线或一个以上的直线为止
    Do While True
        ss.Init
        ss.Filter.SetData 0, "line", -4, "<or", 10, pnts(1), 11, pnts(1), -4, "or>"
        ss.SelectObject acSelectionSetAll
        If ss.Count = 2 Then
            If ss.Item(0) Is obj Then
                Set obj = ss.Item(1)
            Else
                Set obj = ss.Item(0)
            End If
            If isChild(objs, obj) Then Exit Do
            
            If obj.StartPoint(0) = pnts(1)(0) And obj.StartPoint(1) = pnts(1)(1) Then
                pnts.Add obj.EndPoint, , 1
            Else
                pnts.Add obj.StartPoint, , 1
            End If
            objs.Add obj, , 1
        Else
            Exit Do
        End If
    Loop
   
    '从选择线终点找起,一直到没有连接的直线或一个以上的直线为止
    Set obj = selobj
    Do While True
        ss.Init
        ss.Filter.SetData 0, "line", -4, "<or", 10, pnts(pnts.Count), 11, pnts(pnts.Count), -4, "or>"
        ss.SelectObject acSelectionSetAll
        If ss.Count = 2 Then
            If ss.Item(0) Is obj Then
                Set obj = ss.Item(1)
            Else
                Set obj = ss.Item(0)
            End If
            If isChild(objs, obj) Then Exit Do
            
            If obj.StartPoint(0) = pnts(pnts.Count)(0) And obj.StartPoint(1) = pnts(pnts.Count)(1) Then
                pnts.Add obj.EndPoint
            Else
                pnts.Add obj.StartPoint
            End If
            objs.Add obj
        Else
            Exit Do
        End If
    Loop

    Dim dots() As Double
    ReDim dots(pnts.Count * 2 - 1)
    For i = 1 To pnts.Count
        For j = 0 To 1
            dots((i - 1) * 2 + j) = pnts(i)(j)
        Next
    Next
    ThisDrawing.ModelSpace.AddLightWeightPolyline dots
    For Each i In objs
        i.Delete
    Next i
End Sub


Function isChild(objs As Variant, obj As Object)
Dim i
For Each i In objs
    If i Is obj Then isChild = True: Exit For
Next
End Function

[/php]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2006-7-10 13:48:13 | 显示全部楼层
如果支持框选若干线
自动连接就好了。(可能包含一条以上独立线)
还有不支持PLINE
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-7-11 23:17:21 | 显示全部楼层
呵呵,几乎就是消除伪节点,不过这个例子简单多了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-12-23 01:19 , Processed in 0.375430 second(s), 35 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表