明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3764|回复: 18

[提问] lisp批量自身旋转,求大神修改

[复制链接]
发表于 2021-7-17 06:11:04 | 显示全部楼层 |阅读模式
(defun C:ZR ()
(setvar "cmdecho" 0) ;指令执行过程不响应
(princ "\n自身旋转")
(setq ss (ssget))
(repeat (setq i (sslength ss))
(setq i (1- i) a (vlax-ename->vla-object (ssname ss i)))
(vla-getboundingbox a 'minpt 'maxpt)
(mapcar 'set '(minpt maxpt) (mapcar 'vlax-safearray->list (list minpt maxpt)))
(setq p (mapcar '(lambda (x y) (/ (+ x y) 2.0)) minpt maxpt))
(command "_.rotate" ss "" p 90.0)
)
(princ)
)
(目前选择一个对象可以,批量就不行)

发表于 2021-7-17 08:13:34 | 显示全部楼层

(defun C:ZR ()
    (setvar "cmdecho" 0) ;指令执行过程不响应
    (setq osm (getvar "osmode"))
    (setvar "osmode" 0)
    (princ "\n自身旋转")
    (If (setq ss (ssget))
        (repeat (setq i (sslength ss))
            (setq i (1- i))
            (setq ent (ssname ss i))
            (vla-getboundingbox
                 (vlax-ename->vla-object ent)
                 'minpt
                 'maxpt
            )
            (mapcar 'set '(minpt maxpt) (mapcar 'vlax-safearray->list (list minpt maxpt)))
            (setq p (mapcar '(lambda (x y) (/ (+ x y) 2.0)) minpt maxpt))
            (command "_.rotate" ent "" p 90.0)
         )
     )
     (setvar "osmode" osm)
     (setvar "cmdecho" 1)
     (princ)
)
回复 支持 1 反对 0

使用道具 举报

发表于 2021-7-17 08:31:02 | 显示全部楼层
本帖最后由 lee50310 于 2021-7-17 08:48 编辑

試試看:


  1. (defun C:ZR ()
  2. (setvar "cmdecho" 0) ;指令执行过程不回应
  3. (princ "\n自身旋转")
  4. (setq ss (ssget))
  5. (setq sel(vl-remove-if 'listp (mapcar 'cadr (ssnamex ss))))
  6. (foreach x sel
  7.          (vla-getboundingbox (vlax-ename->vla-object x) 'minpt 'maxpt)
  8.          (mapcar 'set '(minpt maxpt) (mapcar 'vlax-safearray->list (list minpt maxpt)))
  9.          (setq p (mapcar '(lambda (x y) (/ (+ x y) 2.0)) minpt maxpt))
  10.          (command "_.rotate" x "" p 90.0)
  11. );end_forecch
  12. (princ)
  13. )
回复 支持 0 反对 1

使用道具 举报

发表于 2021-7-17 07:17:58 | 显示全部楼层
command那句错了,不是SS而是A
回复 支持 1 反对 0

使用道具 举报

发表于 2021-7-26 11:06:06 | 显示全部楼层
  刚好我也用到,感谢各位
回复 支持 1 反对 0

使用道具 举报

发表于 2021-7-17 10:44:51 | 显示全部楼层
(defun C:ZR ()
  (vl-load-com)
  (setq ss (ssget))
  (setq sel (vl-remove-if 'listp (mapcar 'cadr (ssnamex ss))))
  (foreach x sel
    (vla-getboundingbox
      (vlax-ename->vla-object x)
      'minpt
      'maxpt
    )
    (mapcar 'set
            '(minpt maxpt)
            (mapcar 'vlax-safearray->list (list minpt maxpt))
    )
    (setq p (mapcar '* '(0.5 0.5) (mapcar '+ minpt maxpt)))
    (vla-Rotate (vlax-ename->vla-object x) (vlax-3D-point p)  (* 0.5 pi))
  )
  (princ)
)
 楼主| 发表于 2021-7-17 10:49:52 来自手机 | 显示全部楼层
烟盒迷唇 发表于 2021-7-17 07:17
command那句错了,不是SS而是A

谢谢大佬指点
 楼主| 发表于 2021-7-17 10:50:10 来自手机 | 显示全部楼层
yshf 发表于 2021-7-17 08:13
(defun C:ZR ()
    (setvar "cmdecho" 0) ;指令执行过程不响应
    (setq osm (getvar "osmode"))

谢谢大佬指点
 楼主| 发表于 2021-7-17 10:51:08 来自手机 | 显示全部楼层
lee50310 发表于 2021-7-17 08:31
試試看:

谢谢,我试试看
 楼主| 发表于 2021-7-17 10:51:55 来自手机 | 显示全部楼层
kkq0305 发表于 2021-7-17 10:44
(defun C:ZR ()
  (vl-load-com)
  (setq ss (ssget))

感谢大神指点
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-3-12 10:04 , Processed in 0.175528 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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