乐筑天下

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

[编程交流] “交换”lisp不';t工作

[复制链接]

4

主题

11

帖子

7

银币

初来乍到

Rank: 1

铜币
20
发表于 2022-7-6 11:12:13 | 显示全部楼层 |阅读模式
大家好,
 
我从LukewarmCoffee网站下载了这个lisp——它是杰夫·雷霍恩(JeffRayhorn)的作品。它加载成功,但当我在控制行键入“swap”时,会收到一条“未知命令”错误消息。代码中是否有任何明显的东西可能导致问题,或者我是否需要更深入地查看它是否与我加载的其他Lisp冲突?
 
任何帮助都将不胜感激。
 
  1. ;  c. 2006 Jeff Rayhorn & LukewarmCoffee.co_
  2. (defun swap ()
  3. (setvar "cmdecho" 0)
  4. (command "undo" "be")
  5. (prompt "\nSelect first group of objects, [ENTER] when done...")
  6. (setq frstset(ssget))
  7. (setq frstpnt(getpoint "\nPick base point for the first group of objects..."))
  8. (prompt "\nSelect second group of objects, [ENTER] when done...")
  9. (setq scndset(ssget))
  10. (setq scndpnt(getpoint "\nPick base point for the second group of objects..."))
  11. (command "move" frstset "" frstpnt scndpnt)
  12. (command "move" scndset "" scndpnt frstpnt)
  13. (command "undo" "e")
  14. (princ)
  15. )
回复

使用道具 举报

4

主题

940

帖子

961

银币

初来乍到

Rank: 1

铜币
12
发表于 2022-7-6 11:24:23 | 显示全部楼层
在命令行尝试(交换)。。。未经测试
或者编辑代码,使第一行读取(defun c:swap()
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 11:33:18 | 显示全部楼层
另一种可能的书写方式:
 
  1. (defun c:swap (/ *error* Move s1 s2 p1 p2 )
  2. ;; Lee Mac  ~  12.05.10
  3. (vl-load-com)
  4. (defun *error* ( msg )
  5.    (and flag (vla-EndUndoMark doc))
  6.    (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*")
  7.        (princ (strcat "\n** Error: " msg " **")))
  8.    (princ))
  9. (defun Move ( ss p1 p2 / v1 v2 )
  10.    (mapcar (function set) '(v1 v2)
  11.      (mapcar (function vlax-3D-point) (list p1 p2)))
  12.    
  13.    (
  14.      (lambda ( n / e obj )
  15.        (while (setq e (ssname ss (setq n (1+ n))))
  16.          (if (vlax-method-applicable-p
  17.                (setq obj (vlax-ename->vla-object e)) 'Move)
  18.            (vla-move obj v1 v2)
  19.          )
  20.        )
  21.      )
  22.      -1
  23.    )
  24. )
  25. (if
  26.    (and
  27.      (princ "\nSelect First Group of Objects...")
  28.      (setq s1 (ssget "_:L"))
  29.      (setq p1 (getpoint "\nPick First Base Point: "))
  30.      (princ "\nSelect Second Group of Objects...")
  31.      (setq s2 (ssget "_:L"))
  32.      (setq p2 (getpoint "\nPick Second Base Point: "))
  33.      (setq flag
  34.        (not
  35.          (vla-StartUndoMark
  36.            (setq doc
  37.              (vla-get-ActiveDocument
  38.                (vlax-get-acad-object)
  39.              )
  40.            )
  41.          )
  42.        )
  43.      )
  44.    )
  45.    (progn
  46.      (mapcar (function Move)
  47.        (list s1 s2) (list p1 p2) (list p2 p1)
  48.      )
  49.      (setq flag (vla-EndUndomark doc))
  50.    )
  51. )
  52. (princ)
  53. )
  54.    
回复

使用道具 举报

4

主题

11

帖子

7

银币

初来乍到

Rank: 1

铜币
20
发表于 2022-7-6 11:49:56 | 显示全部楼层
用(defun c:swap()编辑它有效。谢谢
 
李,视觉lisp版本看起来也不错。我是lisp的相对noob;多年来,我更像是一名黑客,让现有的Lisp按我想要的方式工作。我会研究你的,并将其与原件进行比较,以供我自己“学习”。
 
再次感谢!
-克里斯
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 11:52:46 | 显示全部楼层
 
不用担心,它只是得到了更多的错误捕捉,也许会运行得更快一点。
 

 
忘了提一下-旧的LISP会弄乱CMDECHO系统变量,并且不会将其设置回原位。
回复

使用道具 举报

54

主题

3755

帖子

3583

银币

后起之秀

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

铜币
438
发表于 2022-7-6 12:09:39 | 显示全部楼层
哈哈,李,真不错。
实际上,我更新了前几天写的一篇旧文章。它只会将一个对象与另一个对象交换(我使用它交换两个块或一个文本对象)。
 
  1. (defun c:EW (/ *error* lst f)
  2. ;; Entity Swap
  3. ;; Alan J. Thompson, 06.05.08 / 07.10.08 / 05.01.10
  4. (defun *error* (msg)
  5.    (and f *AcadDoc* (vla-EndUndoMark *AcadDoc*))
  6.    (and msg
  7.         (not (wcmatch (strcase msg) "*BREAK*,*CANCEL*,*QUIT*"))
  8.         (princ (strcat "\nError: " msg))
  9.    )
  10. )
  11. (if (and (car (setq lst (cons (car (entsel "\nSelect first object: ")) lst)))
  12.           (cadr (vl-remove nil (setq lst (cons (car (entsel "\nSelect second object: ")) lst))))
  13.      )
  14.    ((lambda (pts)
  15.       (setq f (not (vla-StartUndoMark
  16.                      (cond (*AcadDoc*)
  17.                            ((setq *AcadDoc* (vla-get-activedocument (vlax-get-acad-object))))
  18.                      )
  19.                    )
  20.               )
  21.       )
  22.       (mapcar (function (lambda (o a b) (vl-catch-all-apply (function vla-move) (list o a b))))
  23.               (mapcar (function vlax-ename->vla-object) lst)
  24.               pts
  25.               (reverse pts)
  26.       )
  27.     )
  28.      (mapcar (function (lambda (x) (vlax-3d-point (cdr (assoc 10 (entget x))))))
  29.              lst
  30.      )
  31.    )
  32. )
  33. (*error* nil)
  34. (princ)
  35. )
回复

使用道具 举报

54

主题

3755

帖子

3583

银币

后起之秀

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

铜币
438
发表于 2022-7-6 12:20:23 | 显示全部楼层
实际上,我在启动时将我的设置为零。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-7-4 11:36 , Processed in 0.555952 second(s), 67 queries .

© 2020-2025 乐筑天下

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