乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 63|回复: 3

[VBA]

[复制链接]
pmq

14

主题

61

帖子

6

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
117
发表于 2004-8-10 17:15:00 | 显示全部楼层 |阅读模式
[VBA]如何利用vba提取polyline中各顶点的坐标?亿万分感谢!
下面这段程序只能获得坐标,只能获得第一个点的高程,无法获得每个点的高程。
Sub        RevPline()
                                Dim        ent        As        AcadEntity
                                Dim        pnt        As        Variant
                                Dim        NewCoord()        As        Double
                                Dim        i        As        Integer
                                On        Error        Resume        Next
                                Do
                                                                ThisDrawing.Utility.GetEntity        ent,        pnt,        "选择多段线:"
                                                                If        Err        Then        Exit        Sub
                                                                If        TypeName(ent)        Like        "IAcad*Polyline"        Then        Exit        Do
                                Loop
                                Dim        Coord        As        Variant
                                Dim        CoordCount        As        Integer
                                Dim        Bulge()        As        Double        '凸度
                                If        TypeName(ent)        =        "IAcadLWPolyline"        Then
                                                                Coord        =        ent.Coordinates        '获取顶点坐标数组
                                                                CoordCount        =        (UBound(Coord)        +        1)        /        2        '顶点数
                                                                '定义新的顶点坐标数组
                                                                ReDim        NewCoord(UBound(Coord))        As        Double
                                                                For        i        =        0        To        UBound(Coord)        -        1        Step        2
                                                                                                NewCoord(UBound(Coord)        -        i        -        1)        =        Coord(i)
                                                                                                NewCoord(UBound(Coord)        -        i)        =        Coord(i        +        1)
                                                                Next
                                                                ReDim        Bulge(CoordCount        -        1)        As        Double
                                                                For        i        =        0        To        CoordCount        -        1
                                                                                                Bulge(i)        =        ent.GetBulge(i)
                                                                Next
                                                                ent.Coordinates        =        NewCoord
                                                                For        i        =        0        To        CoordCount        -        2
                                                                                                ent.SetBulge        i,        -Bulge(CoordCount        -        2        -        i)
                                                                Next
                                                                ThisDrawing.Regen        acActiveViewport
                                ElseIf        TypeName(ent)        =        "IAcadPolyline"        Then
                                                                Coord        =        ent.Coordinates
                                                                CoordCount        =        (UBound(Coord)        +        1)        /        3
                                                                ReDim        NewCoord(UBound(Coord))        As        Double
                                                                For        i        =        0        To        UBound(Coord)        -        1        Step        3
                                                                                                NewCoord(UBound(Coord)        -        i        -        2)        =        Coord(i)
                                                                                                NewCoord(UBound(Coord)        -        i        -        1)        =        Coord(i        +        1)
                                                                                                NewCoord(UBound(Coord)        -        i)        =        Coord(i        +        2)
                                                                Next
                                                                If        ent.Type        =        acSimplePoly        Then
                                                                                                ReDim        Bulge(CoordCount        -        1)        As        Double
                                                                                                For        i        =        0        To        CoordCount        -        1
                                                                                                                                Bulge(i)        =        ent.GetBulge(i)
                                                                                                Next
                                                                End        If
                                                                ent.Coordinates        =        NewCoord
                                                                If        ent.Type        =        acSimplePoly        Then
                                                                                                For        i        =        0        To        CoordCount        -        2
                                                                                                                                ent.SetBulge        i,        -Bulge(CoordCount        -        2        -        i)
                                                                                                Next
                                                                End        If
                                                        ThisDrawing.Regen        acActiveViewport
                                End        If
                               
End        Sub
回复

使用道具 举报

3

主题

24

帖子

1

银币

初来乍到

Rank: 1

铜币
36
发表于 2004-8-10 21:03:00 | 显示全部楼层
这东些最好把多段线的点位坐标转成坐标结构数组(可以三、二维),算法简单
回复

使用道具 举报

21

主题

166

帖子

7

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
250
发表于 2004-8-10 21:33:00 | 显示全部楼层
二维多段线、轻便多段线每个顶点的高程(Z值)相同,若要每个顶点的高程不一样,则要用三维多段线(这才是真三维的)
回复

使用道具 举报

pmq

14

主题

61

帖子

6

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
117
发表于 2004-8-11 13:00:00 | 显示全部楼层
谢谢版主
但怎样绘制三维多线段,我是刚学用VBA编程的人。
------------------------------------
笨鸟先问
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-1 01:57 , Processed in 1.251471 second(s), 61 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表