明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 759|回复: 2

请各位大大改一下程序,实现批量循环执行

[复制链接]
发表于 2024-5-5 18:43:38 | 显示全部楼层 |阅读模式
3明经币
这程序是个对齐命令,只能单次执行,请帮忙加上循环,实现批量执行。框选完第一个实体后,再框选第二个封闭实体,将第一个实体居中放在后面选择的封闭实体内,封闭实体会有多个。

(defun ss::boundingbox (sel / idx llp ls1 ls2 obj urp)
    (repeat (setq idx (sslength sel))
      (setq obj (vlax-ename->vla-object (ssname sel (setq idx (1- idx)))))
      (if
    (and
      (vlax-method-applicable-p obj 'getboundingbox)
      (not (vl-catch-all-error-p (vl-catch-all-apply 'vla-getboundingbox (list obj 'llp 'urp))))
    )
     (setq ls1 (cons (vlax-safearray->list llp) ls1)
           ls2 (cons (vlax-safearray->list urp) ls2)
     )
      )
    )
    (if (and ls1 ls2)
      (mapcar '(lambda (a b) (apply 'mapcar (cons a b))) '(min max) (list ls1 ls2))
    )
)

(defun c:dq ()        (setvar "OSMODE" 0)
       (princ "\n选择要移动的对象")
        (while (setq ss1 (ssget))                        
         (setq obj1 (ss::boundingbox ss1))         
        (setq x (/ (+ (caar obj1) (caadr obj1)) 2))
        (setq y (/ (+ (cadar obj1) (cadadr obj1)) 2))
        (setq mid1 (list x y 0.0))
   (princ "\n选择对齐的对象")
          (setq ss2 (ssget))
         (setq obj2 (ss::boundingbox ss2))
         (setq x1 (/ (+ (caar obj2) (caadr obj2)) 2))
         (setq y1 (/ (+ (cadar obj2) (cadadr obj2)) 2))
         (setq mid2 (list x1 y1 0.0))
          (princ "\n中心对齐")

      (command "_.move" ss1 "" mid1 mid2))
     (setvar "OSMODE" 11)
    (princ)     
  )

附件: 您需要 登录 才可以下载或查看,没有账号?注册

最佳答案

查看完整内容

(defun c:dq (/ en i mid1 mid2 obj1 obj2 ss1 ss2 ss3 x x1 y y1) (setvar "OSMODE" 0) (princ "\n选择要移动的对象") (while (setq ss1 (ssget)) (setq obj1 (ss::boundingbox ss1)) (setq x (/ (+ (caar obj1) (caadr obj1)) 2)) (setq y (/ (+ (cadar obj1) (cadadr obj1)) 2)) (setq mid1 (list x y 0.0)) (princ "\n选择对齐的对象") (setq ss2 (ssget)) (setq i -1) (while (setq en (ssname ...
发表于 2024-5-5 18:43:39 | 显示全部楼层
(defun c:dq (/ en i mid1 mid2 obj1 obj2 ss1 ss2 ss3 x x1 y y1)
        (setvar "OSMODE" 0)
        (princ "\n选择要移动的对象")
        (while (setq ss1 (ssget))
                (setq obj1 (ss::boundingbox ss1))
                (setq x (/ (+ (caar obj1) (caadr obj1)) 2))
                (setq y (/ (+ (cadar obj1) (cadadr obj1)) 2))
                (setq mid1 (list x y 0.0))
                (princ "\n选择对齐的对象")
                (setq ss2 (ssget))
                (setq i -1)
                (while (setq en (ssname ss2 (setq i (1+ i))))
                        (setq ss3 (ssadd) ss3 (ssadd en ss3))
                        (setq obj2 (ss::boundingbox ss3))
                        (setq x1 (/ (+ (caar obj2) (caadr obj2)) 2))
                        (setq y1 (/ (+ (cadar obj2) (cadadr obj2)) 2))
                        (setq mid2 (list x1 y1 0.0))
                        (command "copy" ss1 "" mid1 mid2)
                )
                (princ "\n中心对齐")
        )
        (setvar "OSMODE" 11)
        (princ)
)
回复

使用道具 举报

 楼主| 发表于 2024-5-6 09:50:50 | 显示全部楼层
感谢大大的出手相助,问题解决,我得研究研究怎么把赏分给你
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-22 23:14 , Processed in 0.169533 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表