乐筑天下

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

请问大家:如何取得一条多段线的多个顶点坐标

[复制链接]
lhr

9

主题

21

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
57
发表于 2004-8-16 10:44:00 | 显示全部楼层 |阅读模式
请问大家:如何取得一条多段线的多个顶点坐标,(例如一条线有6个顶点坐标)
回复

使用道具 举报

13

主题

72

帖子

5

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
124
发表于 2004-8-16 11:15:00 | 显示全部楼层
试试vla-get-coordinates函数
回复

使用道具 举报

pwf

1

主题

9

帖子

1

银币

初来乍到

Rank: 1

铜币
13
发表于 2004-8-16 15:01:00 | 显示全部楼层
不好意思,我也是从别人那里学来的,不过我改正了一下,
取得多义线第M个顶点的坐标
(defun Passoc (m Entname / x Entlist PLlist)
         (if Entname
                         (progn
                                         (setq Entlist (entget Entname))
                                         (foreach x Entlist
                                                         (if (equal (car x) 10)
                                                                         (setq PLlist (cons (cdr x) PLlist))
                                                         );end if
                                         );end foreach
                                         (nth (- m 1) PLlist)
                         );end progn
         );end if
);end defun
回复

使用道具 举报

lhr

9

主题

21

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
57
发表于 2004-8-17 07:31:00 | 显示全部楼层
Thank you!
回复

使用道具 举报

20

主题

872

帖子

10

银币

中流砥柱

Rank: 25

铜币
952
发表于 2004-8-17 22:05:00 | 显示全部楼层
(vl-remove-if '(lambda(x)(/= 10 (car x))) (entget(car(entsel "\n选取多义线:"))))
回复

使用道具 举报

6

主题

71

帖子

8

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
95
发表于 2004-8-29 18:20:00 | 显示全部楼层
有疑问,X、Y值太大时,会出现科学计数的格式,怎么办哟?
回复

使用道具 举报

2

主题

10

帖子

3

银币

初来乍到

Rank: 1

铜币
18
发表于 2004-9-1 07:26:00 | 显示全部楼层
;;这是本人在网上学来的!
;取得多义线顶点坐标,并输出到文本文件
(defun c:zbdc()
         (setvar "cmdecho" 0)
         (setq ffn (getfiled "选取文件" "" "doc" 1))
         (setq ff (open ffn "w"))
         (close ff)
         (princ "\n选择多义线")
         (setq ss (ssget))
         (setq i 0)
         (setvar "pdmode" 33)
         (repeat (sslength ss)
                         (setq ssn (ssname ss i))
                         (setq endata (entget ssn))
                         (setq n 0)
                         (repeat (length endata)
                                         (setq pp(nth n endata))
                                         (setq key (car pp))
                                         (if (= key 10)
        (progn
                 (setq p (trans (cdr pp) 0 1))
                 (setq a (car p) )
                 (setq b (cadr p))
                 ;(command "point" (list a b))
                 (setq x (rtos a 2 3))
                                                                         (setq y (rtos b 2 3))
                 (setq ff (open ffn "a"))
                 (princ x ff)
                 (princ "                                 " ff)
                 (princ y ff)
                 (princ "\n" ff)
                 (close ff)
                 )
        )
                                         (setq n (1+ n))
                                         )
                         (setq ff (open ffn "a"))
                         (princ "end\n" ff)
                         (close ff)
                         (setq i (1+ i))
                         )
         (princ)
         )
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-8-19 17:52 , Processed in 1.810615 second(s), 67 queries .

© 2020-2025 乐筑天下

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