填充继承
快捷键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-4-16 09:58 编辑
;;在原来的基础上改了下
;;可能有不完善的地方
本帖最后由 KO你 于 2019-4-15 00:42 编辑
satan421 发表于 2019-3-9 19:22
;;在原来的基础上改了下
;;可能有不完善的地方
我发布的只有用户定义填充继承时单向填充会变成双向填充,所以寻求完善,
我试过你发回的,很多种填充角度都会变,待求完善。 KO你 发表于 2019-4-14 21:18
我发布的只有用户定义填充继承时单向填充会变成双向填充,所以寻求完善,
我试过你发回的,很多种填充角 ...
可能是你CAD角度的类型不是度而是弧度,你输入units,看一下 这个填充继承可以的 学习了
页:
[1]