乐筑天下

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

[编程交流] 多段线顶点数查询

[复制链接]

15

主题

76

帖子

62

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
75
发表于 2022-7-6 06:08:21 | 显示全部楼层 |阅读模式
我想知道某个角的多段线的顶点数。使用对象属性和滚动顶点需要时间。
伙计们,能让我们Lisp程序。。通过单击多段线的角点,它将为您提供该角点的顶点数。
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-6 06:15:59 | 显示全部楼层
试试看,让我知道它对你有什么作用。。。
 
  1. (defun unit ( v )
  2. (mapcar '(lambda ( x ) (/ x (distance '(0.0 0.0 0.0) v))) v)
  3. )
  4. (defun mxv ( m v )
  5. (mapcar '(lambda ( r ) (apply '+ (mapcar '* r v))) m)
  6. )
  7. (defun v^v ( u v )
  8. (mapcar '(lambda ( n ) (- (* (nth (car n) u) (nth (cadr n) v)) (* (nth (cadr n) u) (nth (car n) v)))) '((1 2) (2 0) (0 1)))
  9. )
  10. (defun transptucs ( pt p1 p2 p3 / ux uy uz )
  11. (setq uz (unit (v^v (mapcar '- p2 p1) (mapcar '- p3 p1))))
  12. (setq ux (unit (mapcar '- p2 p1)))
  13. (setq uy (unit (mapcar '- p3 p1)))
  14. (mxv (list ux uy uz) (mapcar '- pt p1))
  15. )
  16. (defun transptwcs ( pt pt1 pt2 pt3 / pt1n pt2n pt3n )
  17. (setq pt1n (transptucs '(0.0 0.0 0.0) pt1 pt2 pt3))
  18. (setq pt2n (transptucs '(1.0 0.0 0.0) pt1 pt2 pt3))
  19. (setq pt3n (transptucs '(0.0 1.0 0.0) pt1 pt2 pt3))
  20. (transptucs pt pt1n pt2n pt3n)
  21. )
  22. (defun hplv ( pl / el uz v vl ux uy )
  23. (if (and (eq (cdr (assoc 0 (entget pl))) "POLYLINE") (< -1 (cdr (assoc 70 (entget pl))) 6))
  24.    (progn
  25.      (setq el (last (cdr (assoc 10 (entget pl)))))
  26.      (setq uz (cdr (assoc 210 (entget pl))))
  27.      (setq v pl)
  28.      (while (eq (cdr (assoc 0 (entget (setq v (entnext v))))) "VERTEX")
  29.        (setq vl (cons (list (car (cdr (assoc 10 (entget v)))) (cadr (cdr (assoc 10 (entget v)))) el) vl))
  30.      )
  31.      (if (equal uz '(0.0 0.0 1.0) 1e- (setq ux '(1.0 0.0 0.0) uy '(0.0 1.0 0.0)))
  32.      (if (equal uz '(0.0 0.0 -1.0) 1e- (setq ux '(-1.0 0.0 0.0) uy '(0.0 1.0 0.0)))
  33.      (if (not (or (equal uz '(0.0 0.0 1.0) 1e- (equal uz '(0.0 0.0 -1.0) 1e-)) (setq ux (unit (v^v '(0.0 0.0 1.0) uz))))
  34.      (if (not uy) (setq uy (unit (v^v uz ux))))
  35.      (setq vl (mapcar '(lambda ( p ) (transptwcs p '(0.0 0.0 0.0) ux uy)) vl))
  36.      (reverse vl)
  37.    )
  38.    (progn
  39.      (prompt "\nNot valid pl agument supplied to function")
  40.      (princ)
  41.    )
  42. )
  43. )
  44. (defun lplv ( pl / el uz vl ux uy )
  45. (if (eq (cdr (assoc 0 (entget pl))) "LWPOLYLINE")
  46.    (progn
  47.      (setq el (cdr (assoc 38 (entget pl))))
  48.      (setq uz (cdr (assoc 210 (entget pl))))
  49.      (setq vl (mapcar 'cdr (vl-remove-if-not '(lambda ( p ) (= (car p) 10)) (entget pl))))
  50.      (setq vl (mapcar '(lambda ( p ) (list (car p) (cadr p) el)) vl))
  51.      (if (equal uz '(0.0 0.0 1.0) 1e- (setq ux '(1.0 0.0 0.0) uy '(0.0 1.0 0.0)))
  52.      (if (equal uz '(0.0 0.0 -1.0) 1e- (setq ux '(-1.0 0.0 0.0) uy '(0.0 1.0 0.0)))
  53.      (if (not (or (equal uz '(0.0 0.0 1.0) 1e- (equal uz '(0.0 0.0 -1.0) 1e-)) (setq ux (unit (v^v '(0.0 0.0 1.0) uz))))
  54.      (if (not uy) (setq uy (unit (v^v uz ux))))
  55.      (setq vl (mapcar '(lambda ( p ) (transptwcs p '(0.0 0.0 0.0) ux uy)) vl))
  56.      vl
  57.    )
  58.    (progn
  59.      (prompt "\nNot valid pl agument supplied to function")
  60.      (princ)
  61.    )
  62. )
  63. )
  64. (defun c:plvertnumb (/ osm pt pl vl i)
  65. (setq osm (getvar 'osmode))
  66. (setvar 'osmode 1)
  67. (setq pt (getpoint "\nPick vertex point on pline to retrieve its position number : "))
  68. (setq pl (ssname (ssget "_C" pt pt) 0))
  69. (setq pt (trans pt 1 0))
  70. (if (eq (cdr (assoc 0 (entget pl))) "LWPOLYLINE")
  71.    (progn
  72.      (setq vl (lplv pl))
  73.      (setq i (vl-position pt vl))
  74.    )
  75.    (progn
  76.      (setq vl (hplv pl))
  77.      (setq i (vl-position pt vl))
  78.    )
  79. )
  80. (prompt "\nPicked vertex is on the ") (princ (itoa (+ i 1))) (prompt " position")
  81. (setvar 'osmode osm)
  82. (princ)
  83. )
M.R。
回复

使用道具 举报

15

主题

76

帖子

62

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
75
发表于 2022-7-6 06:23:09 | 显示全部楼层
ThanX!M、 R.干杯!!
如果你还有时间,你能让程序一直运行到我按“Esc”键吗。
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-6 06:32:01 | 显示全部楼层
虽然我认为你可以很容易地做到这一点,这是它。。。
 
  1. (defun unit ( v )
  2. (mapcar '(lambda ( x ) (/ x (distance '(0.0 0.0 0.0) v))) v)
  3. )
  4. (defun mxv ( m v )
  5. (mapcar '(lambda ( r ) (apply '+ (mapcar '* r v))) m)
  6. )
  7. (defun v^v ( u v )
  8. (mapcar '(lambda ( n ) (- (* (nth (car n) u) (nth (cadr n) v)) (* (nth (cadr n) u) (nth (car n) v)))) '((1 2) (2 0) (0 1)))
  9. )
  10. (defun transptucs ( pt p1 p2 p3 / ux uy uz )
  11. (setq uz (unit (v^v (mapcar '- p2 p1) (mapcar '- p3 p1))))
  12. (setq ux (unit (mapcar '- p2 p1)))
  13. (setq uy (unit (mapcar '- p3 p1)))
  14. (mxv (list ux uy uz) (mapcar '- pt p1))
  15. )
  16. (defun transptwcs ( pt pt1 pt2 pt3 / pt1n pt2n pt3n )
  17. (setq pt1n (transptucs '(0.0 0.0 0.0) pt1 pt2 pt3))
  18. (setq pt2n (transptucs '(1.0 0.0 0.0) pt1 pt2 pt3))
  19. (setq pt3n (transptucs '(0.0 1.0 0.0) pt1 pt2 pt3))
  20. (transptucs pt pt1n pt2n pt3n)
  21. )
  22. (defun hplv ( pl / el uz v vl ux uy )
  23. (if (and (eq (cdr (assoc 0 (entget pl))) "POLYLINE") (< -1 (cdr (assoc 70 (entget pl))) 6))
  24.    (progn
  25.      (setq el (last (cdr (assoc 10 (entget pl)))))
  26.      (setq uz (cdr (assoc 210 (entget pl))))
  27.      (setq v pl)
  28.      (while (eq (cdr (assoc 0 (entget (setq v (entnext v))))) "VERTEX")
  29.        (setq vl (cons (list (car (cdr (assoc 10 (entget v)))) (cadr (cdr (assoc 10 (entget v)))) el) vl))
  30.      )
  31.      (if (equal uz '(0.0 0.0 1.0) 1e- (setq ux '(1.0 0.0 0.0) uy '(0.0 1.0 0.0)))
  32.      (if (equal uz '(0.0 0.0 -1.0) 1e- (setq ux '(-1.0 0.0 0.0) uy '(0.0 1.0 0.0)))
  33.      (if (not (or (equal uz '(0.0 0.0 1.0) 1e- (equal uz '(0.0 0.0 -1.0) 1e-)) (setq ux (unit (v^v '(0.0 0.0 1.0) uz))))
  34.      (if (not uy) (setq uy (unit (v^v uz ux))))
  35.      (setq vl (mapcar '(lambda ( p ) (transptwcs p '(0.0 0.0 0.0) ux uy)) vl))
  36.      (reverse vl)
  37.    )
  38.    (progn
  39.      (prompt "\nNot valid pl agument supplied to function")
  40.      (princ)
  41.    )
  42. )
  43. )
  44. (defun lplv ( pl / el uz vl ux uy )
  45. (if (eq (cdr (assoc 0 (entget pl))) "LWPOLYLINE")
  46.    (progn
  47.      (setq el (cdr (assoc 38 (entget pl))))
  48.      (setq uz (cdr (assoc 210 (entget pl))))
  49.      (setq vl (mapcar 'cdr (vl-remove-if-not '(lambda ( p ) (= (car p) 10)) (entget pl))))
  50.      (setq vl (mapcar '(lambda ( p ) (list (car p) (cadr p) el)) vl))
  51.      (if (equal uz '(0.0 0.0 1.0) 1e- (setq ux '(1.0 0.0 0.0) uy '(0.0 1.0 0.0)))
  52.      (if (equal uz '(0.0 0.0 -1.0) 1e- (setq ux '(-1.0 0.0 0.0) uy '(0.0 1.0 0.0)))
  53.      (if (not (or (equal uz '(0.0 0.0 1.0) 1e- (equal uz '(0.0 0.0 -1.0) 1e-)) (setq ux (unit (v^v '(0.0 0.0 1.0) uz))))
  54.      (if (not uy) (setq uy (unit (v^v uz ux))))
  55.      (setq vl (mapcar '(lambda ( p ) (transptwcs p '(0.0 0.0 0.0) ux uy)) vl))
  56.      vl
  57.    )
  58.    (progn
  59.      (prompt "\nNot valid pl agument supplied to function")
  60.      (princ)
  61.    )
  62. )
  63. )
  64. (defun c:plvertnumb (/ *error* osm pt pl vl i)
  65. (defun *error* (msg)
  66.    (if osm (setvar 'osmode osm))
  67.    (if msg (prompt msg))
  68.    (princ)
  69. )
  70. (setq osm (getvar 'osmode))
  71. (setvar 'osmode 1)
  72. (while (and
  73.           (not (initget 128))
  74.           (setq pt (getpoint "\nPick vertex point on pline to retrieve its position number : "))
  75.           (listp pt)
  76.         )
  77.        (setq pl (ssname (ssget "_C" pt pt) 0))
  78.        (setq pt (trans pt 1 0))
  79.        (if (eq (cdr (assoc 0 (entget pl))) "LWPOLYLINE")
  80.          (progn
  81.            (setq vl (lplv pl))
  82.            (setq i (vl-position pt vl))
  83.          )
  84.          (progn
  85.            (setq vl (hplv pl))
  86.            (setq i (vl-position pt vl))
  87.          )
  88.        )
  89.        (prompt "\nPicked vertex is on the ") (princ (itoa (+ i 1))) (prompt " position")
  90. )
  91. (*error* nil)
  92. (princ)
  93. )
M.R。
回复

使用道具 举报

15

主题

76

帖子

62

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
75
发表于 2022-7-6 06:34:37 | 显示全部楼层
非常感谢。
M、 R.,你很善良,很棒!!
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 06:44:18 | 显示全部楼层
另一种选择:
  1. (defun c:vn ( / p s )
  2.    (while (setq p (getpoint "\nPick vertex <Exit>: "))
  3.        (if (setq s (ssget p '((0 . "*POLYLINE"))))
  4.            (princ
  5.                (strcat "\nVertex number: "
  6.                     (rtos (1+ (vlax-curve-getparamatpoint (ssname s 0)  (vlax-curve-getclosestpointto (ssname s 0) (trans p 1 0)))) 2 0)
  7.                )
  8.            )
  9.            (princ "\nNo polyline found at the selected point.")
  10.        )
  11.    )
  12.    (princ)
  13. )
  14. (vl-load-com) (princ)
回复

使用道具 举报

15

主题

76

帖子

62

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
75
发表于 2022-7-6 06:46:32 | 显示全部楼层
M、 R.,你的Lisp程序对我的工作很有用。我在多段线顶点附近随机标记。使用lisp,我使用它进行查询,并使用cad命令手动标记。在我看来,如果在查询后它会询问“pick the text location”,并且它会标记该查询的多段线的顶点数,直到我按下“Esc”或取消它,那么对我来说就容易多了。谢谢你给我一点时间。
回复

使用道具 举报

15

主题

76

帖子

62

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
75
发表于 2022-7-6 06:52:32 | 显示全部楼层
五十、 你简化了程序:)。非常感谢。如果你还有时间,请帮我把我上面问的问题包括进去。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 06:59:28 | 显示全部楼层
请尝试以下操作:
  1. (defun c:vn ( / a n p q s )
  2.    (setq n (trans '(0.0 0.0 1.0) 1 0 t)
  3.          a (angle '(0.0 0.0 0.0) (trans (getvar 'ucsxdir) 0 n t))
  4.    )
  5.    (while (setq p (getpoint "\nPick vertex <Exit>: "))
  6.        (if
  7.            (setq s
  8.                (ssget p
  9.                   '(
  10.                        (0 . "*POLYLINE")
  11.                        (-4 . "<NOT")
  12.                            (-4 . "<AND")
  13.                                (0 . "POLYLINE") (-4 . "&") (70 . 80)
  14.                            (-4 . "AND>")
  15.                        (-4 . "NOT>")
  16.                    )
  17.                )
  18.            )
  19.            (if (setq q (getpoint "\nPick point for text: "))
  20.                (entmake
  21.                    (list
  22.                       '(0 . "TEXT")
  23.                        (cons 010 (trans q 1 n))
  24.                        (cons 007 (getvar 'textstyle))
  25.                        (cons 040 (getvar 'textsize))
  26.                        (cons 001 (rtos (1+ (vlax-curve-getparamatpoint (ssname s 0) (vlax-curve-getclosestpointto (ssname s 0) (trans p 1 0)))) 2 0))
  27.                        (cons 050 a)
  28.                        (cons 210 n)
  29.                    )
  30.                )
  31.            )
  32.            (princ "\nNo polyline found at the selected point.")
  33.        )
  34.    )
  35.    (princ)
  36. )
  37. (vl-load-com) (princ)

 
上述内容也应适用于所有UCS和视图。
回复

使用道具 举报

15

主题

76

帖子

62

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
75
发表于 2022-7-6 07:04:40 | 显示全部楼层
:庆祝:Big Big thanx!!五十、 M。。这对我的工作有很大帮助。感谢您与我们分享您的知识!!
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-10 18:24 , Processed in 0.399929 second(s), 72 queries .

© 2020-2025 乐筑天下

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