田草博客

互联网田草博客


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

微信 公众号:ByCAD

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

用户登陆
用户:
密码:
 

站点日历
73 2024 - 11 48
     12
3456789
10111213141516
17181920212223
24252627282930


站点统计

最新评论



vba 命令管理成功实现 隐藏日志,无权浏览
未知 点集的边界   [ 日期:2008-07-16 ]   [ 来自:本站原创 ]  HTML
'点集的边界
Sub PListToPLine()
    Dim objSelected As Object
    Dim P As AcadPoint
    Dim PS As AcadSelectionSet
    Dim PList() As Double
    Dim PXY() As PointXY
    Dim A() As Double
    Dim L As AcadLine
    Dim i As Long
    Dim j As Long
    On Error Resume Next
    
    Dim o As Variant
    o = ThisDrawing.Utility.GetPoint(, "指定边界内部一点")
    
    Set PS = ThisDrawing.SelectionSets.Add("XXX")

    '定义过滤机制
    Dim filterType(0) As Integer
    Dim filterData(0) As Variant
    filterType(0) = 0
    filterData(0) = "POINT"
    
    PS.SelectOnScreen filterType, filterData
    
    ReDim PList(PS.Count * 2 - 1)
    ReDim A(PS.Count - 1)
    ReDim PXY(PS.Count - 1)
    'Prompt str(UBound(PList))
    For Each objSelected In PS
        If TypeOf objSelected Is AcadPoint Then
            Set P = objSelected
            PXY(i).x = P.Coordinates(0)
            PXY(i).Y = P.Coordinates(1)
            Set L = ThisDrawing.ModelSpace.AddLine(o, P.Coordinates)
            '极角数组
            A(i) = L.angle
            i = i + 1
            L.Delete
        Else
            '删除选择集
            ThisDrawing.SelectionSets.item("XXX").Delete
        End If
    Next
    Dim Atemp As Double
    Dim Ptemp As PointXY
    '按照顺时针对点进行排序
    '根据极角排序
    For i = 0 To UBound(A) - 1
        For j = i To UBound(A)
        If A(i) < A(j) Then
            Atemp = A(i)
            A(i) = A(j)
            A(j) = Atemp
            Ptemp = PXY(i)
            PXY(i) = PXY(j)
            PXY(j) = Ptemp
        End If
        Next j
    Next i
    For i = 0 To UBound(A)
        PList(i * 2) = PXY(i).x
        PList(i * 2 + 1) = PXY(i).Y
    Next i
    Dim Pl As AcadLWPolyline
    Set Pl = ThisDrawing.ModelSpace.AddLightWeightPolyline(PList)
    Pl.Closed = True
    ThisDrawing.SelectionSets.item("XXX").Delete
    
    Exit Sub

ErrControl:
    MsgBox Err.Description
End Sub




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

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

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