明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1915|回复: 3

网站找到的 帮忙改改 圆分色按大小填标记号

[复制链接]
发表于 2012-6-4 00:46:35 | 显示全部楼层 |阅读模式
程序是由内到外的分色 能否给改改为: 由外到内的 反个方向 请求会的出个手 谢谢!学习 等~
;圆分色按大小填标记号 明经 ZZXXQQ 2008.1.19
(defun c:vv ()
(setvar "CMDECHO" 0)
(if (setq ss (ssget '((0 . "CIRCLE")))) (progn
  (command ".UNDO" "BE")
  (setq i -1  cirlst (list))
  (repeat (sslength ss)
   (setq r (cdr (assoc 40 (entget (setq en (ssname ss (setq i (1+ i))))))))
   (if (assoc r cirlst)
(setq cirlst (subst (cons r (1+ (cdr (assoc r cirlst)))) (assoc r cirlst) cirlst))
    (setq cirlst (cons (cons r 1) cirlst))
   )
  )
  (setq i -1 cirlst (reverse cirlst))
  (setq dwglst (list "1" "2" "3" "4" "5" "9" "10" "11" "18" "20" "24" "25" "26" "28" "31" "32"
      "34" "35" "38" "39" "40" "41" "42" "44"))
  (setq cirlst (vl-sort cirlst (function (lambda (e1 e2) (< (car e1) (car e2))))))
  (repeat (length cirlst)
   (setq r (car (nth (setq i (1+ i)) cirlst)))
   (command "select" ss "")
   (setq ss1 (ssget "P" (list (cons 0 "CIRCLE") (cons 40 r))))
   (command "chprop" ss1 "" "C" (itoa (1+ i)) "")
   (if (setq bnm (findfile (strcat (nth i dwglst) ".dwg"))) (progn
    (setq j 0)
(setq pc (cdr(assoc 10 (entget(ssname ss1 0)))))
(command "-insert" bnm pc "" "" "" "chprop" "l" "" "C" (itoa (1+ i)) "")
(setq bnm (nth i dwglst))
    (repeat (1- (sslength ss1))
     (setq pc (cdr (assoc 10 (entget(ssname ss1 (setq j (1+ j)))))))
  (command "-insert" bnm pc "" "" "" "chprop" "l" "" "C" (itoa (1+ i)) "")
    )
   ))
  )
  (command ".UNDO" "E")
))
(setvar "CMDECHO" 1)
(princ)
)
"觉得好,就打赏"
还没有人打赏,支持一下
 楼主| 发表于 2012-6-4 06:30:40 | 显示全部楼层
帮我顶哈 谢谢
发表于 2012-6-4 08:04:25 | 显示全部楼层
  1. ;; 圆按大→小分色
  2. (defun c:tt ()
  3.   (if (setq ss (ssget '((0 . "CIRCLE"))))
  4.     (progn
  5.       (setq i        -1
  6.             lst        '()
  7.       )
  8.       (while (setq s1 (ssname ss (setq i (1+ i))))
  9.         (setq r          (cdr (assoc 40 (entget s1)))
  10.               lst (if (member r lst)
  11.                     lst
  12.                     (cons r lst)
  13.                   )
  14.         )
  15.       )
  16.       (setq lst        (vl-sort lst '>)
  17.             i        0
  18.       )
  19.       (foreach r lst
  20.         (command "select" ss "")
  21.         (setq ss1 (ssget "P" (list '(0 . "CIRCLE") (cons 40 r))))
  22.         (command "chprop" ss1 "" "C" (itoa (1+ i)) "")
  23.         (setq i (1+ i))
  24.       )
  25.     )
  26.   )
  27.   (princ)
  28. )
 楼主| 发表于 2012-6-5 00:08:53 | 显示全部楼层
夜了回家   
xyp1964
版主
谢谢呀
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-9-25 11:19 , Processed in 0.200474 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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