明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 852|回复: 10

[提问] 实体选择集-->旋转-->新选择集问题

[复制链接]
发表于 2019-6-12 20:08 | 显示全部楼层 |阅读模式
如题:


    1: 如果构件选择集(setq s(ssget))后,对实体旋转或移动,操作完成后,发现,其中各个实体名,是不变的。
    2:既然实体名没有变,那么继续用 选择集 S  ,进行后续编程,为什么失效呢?


如之奈何????
    如果这样不可以用  选择集 S ;那么,如何取得旋转、移动之后,这部分实体的新的选择集?  

   经验证:下面的方法亦然不会奏效。。。。。
  • ;;;;(setq ss1 (entlast)) ;;;;;;构造最后一个实体选择集
  •   ;;;;;;;(setq s (last_ent ss1))  ;;;;;;;旋转定位后,产生的选择集
"觉得好,就打赏"
还没有人打赏,支持一下
 楼主| 发表于 2019-6-12 22:15 | 显示全部楼层
看来大家不积极,那么我发段没调试成功的代码吧。希望有人能发现这段代码要解决的啥问题?解决了是很有用的。

  • ;;; ---------------------------------------------------------
  • (defun c:CCJ (/ s ss pt1 pt2 nam n p ang)
  •   (command)
  •   (setq s (ssget))
  •   (princ "\n选择要旋转的对象:")
  •   (setq pt2 (nth 1 (grread 5)))
  •   (setq pt1 90)
  •   (setq e (entlast));最后一个图元
  •   (setq ss (ssadd))
  •   (command "ROTATE" s "" pt2 pt1 "")
  •   (command "MOVE" s "" pt2)
  •   (while (setq e (entnext e))  ;把旋转后的图元,逐一加进选择集
  •     (setq ss (ssadd e ss))
  •   )
  •   ;;;;;;;;;以下更新旋转、移动后实体表,重新构件新选择集  SS
  •   ;;;;;;;(setq s (last_ent ss1))  ;;;;;;;旋转定位后,产生的选择集
  •   (setq p (sslength ss))
  •   (setq n 0)
  •   (setq p (- p 1))
  •   (while (<= n p)
  •     (setq nam (ssname ss n))
  •     (setq pt1 (entget nam))
  •     (if  (OR (="TEXT" (cdr(assoc 0 pt1)))(="MTEXT" (cdr(assoc 0 pt1))))
  •       (progn
  •         (command ".JUSTIFYTEXT" nam "" "M")
  •         (setq ang (cdr(assoc 50 pt1)))
  •         (if (and (>= ang (/ pi 2)) (<= ang pi)) ;;;;;第二象限
  •           (setq ang (+ pi ang ))
  •         )
  •         (if (and (> ang  pi) (<= ang (* 1.5 pi))) ;;;;;第三象限
  •           (setq ang (- ang pi))
  •         )
  •         (setq pt1 (subst (cons 50 ang) (assoc 50 pt1) pt1))  ;;;;;实体表更新【角度】
  •         (entmod pt1)
  •         (entupd nam)
  •         (command ".JUSTIFYTEXT" nam "" "L")  ;;;;;;改回文字为左定位
  •       )
  •     )
  •     (setq n (+ 1 n))
  •   )
  • )
 楼主| 发表于 2019-6-12 22:22 | 显示全部楼层
看来大家不积极,那么我发段没调试成功的代码吧。希望有人能发现这段代码要解决的啥问题?解决了是很有用的。
;;; ---------------------------------------------------------
(defun c:CCJ (/ s ss pt1 pt2 nam n p ang)
  (command)
(setq s (ssget))
(princ "\n选择要旋转的对象:")
(setq pt2 (nth 1 (grread 5)))
(setq pt1 90)

(setq e (entlast));最后一个图元
(setq ss (ssadd))
(command "ROTATE" s "" pt2 pt1 "")
(command "MOVE" s "" pt2)
(while (setq e (entnext e))  ;把旋转后的图元,逐一加进选择集
  (setq ss (ssadd e ss))
)
  ;;;;;;;;;以下更新旋转、移动后实体表,重新构件新选择集  SS
  ;;;;;;;(setq s (last_ent ss1))  ;;;;;;;旋转定位后,产生的选择集
  (setq p (sslength ss))
  (setq n 0)
  (setq p (- p 1))
  (while (<= n p)
    (setq nam (ssname ss n))
    (setq pt1 (entget nam))
    (if  (OR (="TEXT" (cdr(assoc 0 pt1)))(="MTEXT" (cdr(assoc 0 pt1))))
      (progn
        (command ".JUSTIFYTEXT" nam "" "M")
        (setq ang (cdr(assoc 50 pt1)))
        (if (and (>= ang (/ pi 2)) (<= ang pi)) ;;;;;第二象限
          (setq ang (+ pi ang ))
        )
        (if (and (> ang  pi) (<= ang (* 1.5 pi))) ;;;;;第三象限
          (setq ang (- ang pi))
        )
        (setq pt1 (subst (cons 50 ang) (assoc 50 pt1) pt1))  ;;;;;实体表更新【角度】
        (entmod pt1)
        (entupd nam)
        (command ".JUSTIFYTEXT" nam "" "L")  ;;;;;;改回文字为左定位
      )
    )
    (setq n (+ 1 n))
  )
)

发表于 2019-6-13 00:02 来自手机 | 显示全部楼层
试试ssget "P"

点评

经测试,成功了,谢谢。就是这么用的,。  发表于 2019-6-13 02:11
发表于 2019-6-13 08:40 | 显示全部楼层
给你参考一下

  1. (defun c:rt ( / ss  pp pt ss)(princ "快速旋转<90°逆时针>")
  2. (setq ss(ssget ":s"))
  3. (if(= ss nil)(setq ss sso)(setq sso ss))
  4. (if(= sso nil)(princ "\n没有选择对象"))
  5. (setq pt (centerp sso))       ;;;;centerp 包围盒的中心
  6. (setq pt (trans pt 0 1))
  7. (setvar 'cmdecho 0)
  8. (command "_.rotate" sso "" "NON" pt -90)
  9. (setvar 'cmdecho 1)
  10. (prin1))


发表于 2019-12-31 13:31 | 显示全部楼层

不能 用啊,缺少函数
发表于 2020-1-4 08:45 | 显示全部楼层
296715530 发表于 2019-12-31 13:31
不能 用啊,缺少函数

;;;;;centerp 包围盒的中心
没发这个函数,论坛里很多
发表于 2020-1-5 22:04 | 显示全部楼层
菜卷鱼 发表于 2020-1-4 08:45
;;;;;centerp 包围盒的中心
没发这个函数,论坛里很多

不懂函数,发个完整的呗,
发表于 2020-1-6 08:28 | 显示全部楼层
发表于 2020-1-14 13:34 | 显示全部楼层
菜卷鱼 发表于 2020-1-6 08:28
http://bbs.mjtd.com/forum.php?mod=viewthread&tid=109639&fromuid=399892

选择对象: 指定对角点:
; 错误: 参数类型错误: lentityp <Selection set: 1120>
命令:
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-3-29 02:45 , Processed in 0.214817 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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