明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
123
返回列表 发新帖
楼主: 小毛草

[源码] 将各种线型反向——多选版

[复制链接]
发表于 2025-7-25 16:41:44 | 显示全部楼层

     样条曲线这样就对了。
    ;;━━━━━━ 样条曲线处理 ━━━━━━
          ((= (cdr (assoc 0 ENT)) "SPLINE")
           (command "SPLINEDIT" ENT1 "r" "")
           (command "pedit" e "x" "")
           ;;(command "")暂时注释
          )
回复 支持 反对

使用道具 举报

发表于 2025-7-25 16:43:31 | 显示全部楼层
修改后的完整程序。(defun C:FS (/ ss i ent ENT1 Q Q2 cp r os)
  (prompt "\n将各种线型反向——多选版")
  (setq os (getvar "osmode"))
  (setvar "osmode" 0)

  ;; 多选对象
  (if (setq ss (ssget '((0 . "LINE,ARC,CIRCLE,LWPOLYLINE,SPLINE"))))
    (progn
      (repeat (setq i (sslength ss))
        (setq ent (ssname ss (setq i (1- i)))
              ENT1 ent
              ENT (entget ENT1))

        (cond
          ;;━━━━━━ 多段线处理 ━━━━━━
          ((= (cdr (assoc 0 ENT)) "LWPOLYLINE")
           (reverseLwp ENT1))

          ;;━━━━━━ 直线处理 ━━━━━━
          ((= (cdr (assoc 0 ENT)) "LINE")
           (setq Q (cons 10 (cdr (assoc 11 ENT)))
                 Q2 (cons 11 (cdr (assoc 10 ENT))))
           (entmod (subst Q2 (assoc 11 ENT) (subst Q (assoc 10 ENT) ENT)))
          )

          ;;━━━━━━ 样条曲线处理 ━━━━━━
          ((= (cdr (assoc 0 ENT)) "SPLINE")
           (command "SPLINEDIT" ENT1 "r" "")
           (command "pedit" e "x" "")
           ;;(command "")暂时注释
          )

          ;;━━━━━━ 圆弧处理 ━━━━━━
          ((= (cdr (assoc 0 ENT)) "ARC")
           (command "pedit" ENT1 "y" "n")
           (reverseLwp (entlast))
           (entdel ENT1)
          )

          ;;━━━━━━ 圆处理 ━━━━━━
          ((= (cdr (assoc 0 ENT)) "CIRCLE")
           (setq cp (cdr (assoc 10 ENT))
                 r (cdr (assoc 40 ENT)))
           (entmake
             (list
               '(0 . "LWPOLYLINE")
               '(100 . "AcDbEntity")
               '(67 . 0)
               '(410 . "Model")
               '(100 . "AcDbPolyline")
               '(90 . 2)
               '(70 . 129)
               (cons 10 (polar cp 0 r))
               '(40 . 0)
               '(41 . 0)
               '(42 . -1)
               (cons 10 (polar cp pi r))
               '(40 . 0)
               '(41 . 0)
               '(42 . -1)
             )
           )
           (command "_matchprop" ENT1 (entlast) "")
           (entdel ENT1)
          )
        )
      )
    )
    (prompt "\n未选择有效对象")
  )

  (setvar "osmode" os)
  (princ)
)

;;;=======================================
;;; 多段线反转子程序(保持不变)
;;;=======================================
(defun reverseLwp (ent1 / a pl how li1 li2 li3)
  (setq pl (entget ent1 '("*")) how nil)
  (foreach an pl
    (if (setq a (member (car an) '(10 40 41 42)))
      (setq how t))
    (cond
      ((not how)
       (setq li1 (cons an li1)))
      ((and how a)
       (cond
         ((= (car an) 40) (setq an (cons 41 (cdr an))))
         ((= (car an) 41) (setq an (cons 40 (cdr an))))
         ((= (car an) 42) (setq an (cons 42 (- 0 (cdr an)))))
         (t an)
       )
       (setq li2 (cons an li2))
      )
      ((and how (not a))
       (setq li3 (cons an li3)))
    )
  )
  (entmod (append (reverse li1)
                  (append (cdddr li2) (list (car li2) (cadr li2) (caddr li2)))
                  (reverse li3)))
)
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-8-12 04:31 , Processed in 0.147749 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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