明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 886|回复: 5

填充继承

[复制链接]
发表于 2019-3-9 19:22 | 显示全部楼层 |阅读模式
1明经币

快捷键  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)
)

附件: 您需要 登录 才可以下载或查看,没有账号?注册

最佳答案

查看完整内容

;;在原来的基础上改了下 ;;可能有不完善的地方
发表于 2019-3-9 19:22 | 显示全部楼层
本帖最后由 satan421 于 2019-4-16 09:58 编辑

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


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
回复

使用道具 举报

 楼主| 发表于 2019-4-14 21:18 | 显示全部楼层
本帖最后由 KO你 于 2019-4-15 00:42 编辑
satan421 发表于 2019-3-9 19:22
;;在原来的基础上改了下
;;可能有不完善的地方

我发布的只有用户定义填充继承时单向填充会变成双向填充,所以寻求完善,
我试过你发回的,很多种填充角度都会变,待求完善。
回复

使用道具 举报

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

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

使用道具 举报

发表于 2019-4-15 09:32 来自手机 | 显示全部楼层
这个填充继承可以的
回复

使用道具 举报

发表于 2019-4-30 00:07 | 显示全部楼层
学习了

回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-19 10:58 , Processed in 0.318450 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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