KO你 发表于 2019-3-9 19:22:35

填充继承


快捷键ch填充继承特性
(defun c:ch(/ e en key n p ss tc_ang tc_col tc_e tc_la tc_name tc_scle tc_vlae)
(cxsta)
(vl-load-com)
(setq en (entlast))
(if (setq tc_e (car (entsel "\n选择填充源图案:")))
    (progn
      (IF (= (CDR (ASSOC 0 (ENTGET TC_E))) "HATCH")
(PROGN
   (setq tc_vlae (vlax-ename->vla-object tc_e)
tc_name (vla-get-patternname tc_vlae)
tc_scle (vla-get-patternscale tc_vlae)
tc_ang (vla-get-patternangle tc_vlae)
tc_la (vla-get-layer tc_vlae)
tc_col (vla-get-color tc_vlae)
   )
   (if (= "_USER" tc_name)
   (command "bhatch"
       "p"
       "U"
       (* 180 (/ tc_ang pi))
       tc_scle
       "y"
       ""
   )
   (command "bhatch"
       "p"
       tc_name
       tc_scle
       (* 180 (/ tc_ang pi))
       ""
   )
   )
   (thpanduan)
   (if (setq ss (cx-en-ss en))
   (progn
       (cx-gs ss tc_col)
       (repeat (setq n (sslength ss))
(vla-put-layer
    (vlax-ename->vla-object (ssname ss (setq n (1- N))))
    tc_la
)
       )
   )
   )
)
      )
    )
    (PROMPT "选择的不是填充\n")
)
(cxend)
)
   ;api接口 填充判断
(defun thpanduan ()
(if (setq ss (ssget))
    (command "bhatch" "s" ss "" "") ;如果选择集不为空,则执行对象填充
    (progn    ;如果选择集为空,则执行点选命令
      (prompt "\n请拾取填充内部点:\n")
      (command "bhatch" pause)
      (while (> (getvar "CMDACTIVE") 0) (command PAUSE))
    )
)
)
   ;返回en之后的选择集
(defun cx-en-ss (en / ss)
(if en
    (progn
      (setq ss (ssadd))
      (while (entnext en)
(setq ss (ssadd (entnext en) ss))
(setq en (entnext en))
      )
      (if (> (sslength ss) 0)
ss
nil
      )
    )
)
)
(defun cx-gs (en clo / en clo)
(cond
    ((= (type en) 'ENAMe)
   (vla-put-Color (vlax-ename->vla-object en) clo)
    )
    ((= (type en) 'PICKSET)
   (repeat (setq i (sslength en))
       (vla-put-Color
(vlax-ename->vla-object (ssname en (setq i (1- i))))
clo
       )
   )
    )
    ((= (type en) 'VLA-OBJECT)
   (vla-put-Color en clo)
    )
)
)

(defun cxsta ()
(setvar "cmdecho" 0)   ; 关闭命令响应
(setq $orr *error*)
(setq *error* #err2)   ; 当程序出错时就会执行#err函数
(command ".UNDO" "BE"); 设置UNDO起点
)
(defun cxend ()
(command ".UNDO" "E")   ; 设置UNDO终点
(setq *error* $orr)
(setvar "osmode" 15359)
(princ)
)
;;; 出错处理函数
(defun #err2 (s)
(command ".UNDO" "E")   ; 设置UNDO终点
(redraw name1 4)
(redraw name2 4)
(princ)
(setq *error* $orr)
)

satan421 发表于 2019-3-9 19:22:36

本帖最后由 satan421 于 2019-4-16 09:58 编辑

;;在原来的基础上改了下
;;可能有不完善的地方


KO你 发表于 2019-4-14 21:18:51

本帖最后由 KO你 于 2019-4-15 00:42 编辑

satan421 发表于 2019-3-9 19:22
;;在原来的基础上改了下
;;可能有不完善的地方
我发布的只有用户定义填充继承时单向填充会变成双向填充,所以寻求完善,
我试过你发回的,很多种填充角度都会变,待求完善。

satan421 发表于 2019-4-15 08:37:22

KO你 发表于 2019-4-14 21:18
我发布的只有用户定义填充继承时单向填充会变成双向填充,所以寻求完善,
我试过你发回的,很多种填充角 ...

可能是你CAD角度的类型不是度而是弧度,你输入units,看一下

纵横八方 发表于 2019-4-15 09:32:38

这个填充继承可以的

雁苍山下人 发表于 2019-4-30 00:07:12

学习了

页: [1]
查看完整版本: 填充继承