乐筑天下

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

[编程交流] 用户在LIS内移动对象

[复制链接]

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 12:44:48 | 显示全部楼层
我正试图进一步修改这段代码,以便在循环中处理动态块。我想我需要的是一个“在这里等待,直到我告诉你重新启动”命令。
 
我尝试使用暂停,但这只适用于一个“点击事件”。
 
我累了(命令pause pause),它允许我选择动态块,单击旋转夹点并旋转到一个新角度,然后继续。但是如果我也需要翻过障碍,我就太幸运了。
 
是否有一种方法可以让LISP让用户进行一些选择,在窗口中四处单击,然后在完成后点击“重新启动”(继续运行)LISP的特定键?
 
格伦
回复

使用道具 举报

54

主题

3755

帖子

3583

银币

后起之秀

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

铜币
438
发表于 2022-7-6 12:48:17 | 显示全部楼层
当命令处于活动状态时,存在以下情况:
 
  1. (defun c:zmblk (/ *error* StrBrk _3dPoint *ACAD BPNT DOC DPNT ELST FILE
  2.                                 LST MAXP MINP NL OFILE PTS UFLAG)
  3. (vl-load-com)
  4. (defun *error* (msg)
  5.    (and uFlag (vla-EndUndoMark doc))
  6.    (and oFile (close oFile))
  7.    (or (wcmatch (strcase msg) "*BREAK,*CANCEL*,*EXIT*")
  8.        (princ (strcat "\n** Error: " msg " **")))
  9.    (princ))
  10. (defun StrBrk (str chrc / pos lst)
  11.    (while (setq pos (vl-string-position chrc str))
  12.      (setq lst (cons (substr str 1 pos) lst)
  13.            str (substr str (+ pos 2))))
  14.    (reverse (cons str lst)))
  15. [color=Red](setq _3dPoint (lambda (x) (vlax-3d-point (trans x 1 0))))[/color]
  16. (if (setq file (getfiled "Select Text File" (if *load *load "") "txt" )
  17.    (progn
  18.      (setq doc   (vla-get-ActiveDocument (setq *acad (vlax-get-acad-object)))
  19.            uflag (not (vla-startUndoMark doc)))
  20.      (setq *load file ofile (open file "r"))
  21.      
  22.      (while (setq nl (read-line ofile))
  23.        (princ nl)
  24.        (setq lst (cons (car (StrBrk nl 9)) lst)))
  25.      (setq ofile (close ofile))
  26.      
  27.      (if (setq elst (vl-remove-if 'null
  28.                       (mapcar 'handent
  29.                         (mapcar (function (lambda (x) (substr x 2))) (reverse lst)))))
  30.       
  31.        (foreach Obj (mapcar 'vlax-ename->vla-object elst)                     
  32.          (vla-getBoundingBox Obj 'Minp 'Maxp)
  33.          
  34.          (setq pts (mapcar 'vlax-safearray->list (list Minp Maxp)))
  35.          (vla-ZoomCenter *acad
  36.            (vlax-3D-point (polar (car pts) (apply 'angle pts) (/ (apply 'distance pts) 2.))) 400.)
  37.            (if (and (setq bPnt (getpoint "\nPick Base point: "))
  38.                     (setq dPnt (getpoint bPnt "\nPick Destination: ")))
  39.              ;;(vl-cmdf "_.move" (vlax-vla-object->ename obj) "" bPnt dPnt))))
  40.              [color=Red](vl-catch-all-apply 'vla-move (list obj (_3dPoint bPnt) (_3dPoint dPnt))))))[/color]
  41.      (setq uflag (vla-EndUndoMark doc)))
  42.    
  43. (princ "\n<< No File Selected >>"))
  44. (princ))
回复

使用道具 举报

13

主题

126

帖子

114

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
65
发表于 2022-7-6 12:52:35 | 显示全部楼层
 
告诉我。。。
我的储藏室里还有一些盒子,里面有很多我用lisp写的东西。。。。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 12:59:39 | 显示全部楼层
回复

使用道具 举报

2

主题

47

帖子

45

银币

初来乍到

Rank: 1

铜币
10
发表于 2022-7-6 13:02:15 | 显示全部楼层
 
Tell me...
I still have some boxes with a lot of the stuff I wrote in lisp on my storage room....
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-5 10:11 , Processed in 0.628700 second(s), 60 queries .

© 2020-2025 乐筑天下

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