明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
12
返回列表 发新帖
楼主: bingshuier

[提问] 怎么实现点击封闭图形内部,自动形成开洞线

[复制链接]
发表于 2023-10-22 23:12 | 显示全部楼层
tt; 错误: no function definition: XYP-MKLACO


我怎么用不了......
发表于 2023-10-22 23:16 | 显示全部楼层
a405692168 发表于 2023-10-22 23:12
tt; 错误: no function definition: XYP-MKLACO

要配合e派工具箱使用。
发表于 2023-10-22 23:36 | 显示全部楼层
我的不需要配合任何工具箱的。可以试试
(defun c:11(/  ent  pt p1 p2 p3 p0 len len1 minpoint maxpoint)
(while
(setq pt (getpoint "\n在闭合区域拾取一点<退出>:"))
(vl-cmdf "-boundary" pt "")
(setq ent (entlast))
(vla-getboundingbox (vlax-ename->vla-object ent) 'minpoint 'maxpoint) ;获得包围盒
(setq p1(vlax-safearray->list minpoint) p3(vlax-safearray->list maxpoint)) ;盒最小与最大点
(entdel ent)
(setq p2 (list (car p1)(cadr p3)))
(setq len (distance p1 p2))
(setq len1 (distance p3 p2))
(if (< len len1)
(setq p0 (polar p1 (/ pi 3)  (* len 0.8)))
(setq p0 (polar p1 (/ pi 2.2)  (* len 0.8)))
)
(entmake (list'(0 . "LWPOLYLINE")'(100 . "AcDbEntity")'(100 . "AcDbPolyline")(cons 62 8)
(cons 90 3) (cons 10 p1) (cons 10 p0) (cons 10 p3) ))
)
(princ))
发表于 2023-10-25 15:20 | 显示全部楼层
qazxswk 发表于 2023-10-22 23:36
我的不需要配合任何工具箱的。可以试试
(defun c:11(/  ent  pt p1 p2 p3 p0 len len1 minpoint maxpoint) ...

还是大哥你这个好用
发表于 2023-10-26 20:53 | 显示全部楼层
qazxswk 发表于 2023-10-22 23:36
我的不需要配合任何工具箱的。可以试试
(defun c:11(/  ent  pt p1 p2 p3 p0 len len1 minpoint maxpoint) ...

谢谢,大神这个好用,有空的时候,能增加个功能:自动把开洞线固定到"开洞线"图层上吗?
发表于 2023-10-27 13:23 | 显示全部楼层
本帖最后由 qazxswk 于 2023-10-30 00:09 编辑
a405692168 发表于 2023-10-26 20:53
谢谢,大神这个好用,有空的时候,能增加个功能:自动把开洞线固定到"开洞线"图层上吗?

(defun c:11(/  ent  pt p1 p2 p3 p0 len len1 minpoint maxpoint)
(if (= (tblobjname "layer" "开洞线") nil)
(entmake (list'(0 . "layer")'(100 . "AcDbSymbolTableRecord") '(100 . "AcDbLayerTableRecord")
(cons 2 "开洞线") '(70 . 0) '(62 . 8)
)))
(while
(setq pt (getpoint "\n在闭合区域拾取一点<退出>:"))
(vl-cmdf "-boundary" pt "")
(setq ent (entlast))
(vla-getboundingbox (vlax-ename->vla-object ent) 'minpoint 'maxpoint) ;获得包围盒
(setq p1(vlax-safearray->list minpoint) p3(vlax-safearray->list maxpoint)) ;盒最小与最大点
(entdel ent)
(setq p2 (list (car p1)(cadr p3)))
(setq len (distance p1 p2))
(setq len1 (distance p3 p2))
(if (< len len1)
(setq p0 (polar p1 (/ pi 3)  (* len 0.8)))
(setq p0 (polar p1 (/ pi 2.2)  (* len 0.8)))
)
(entmake (list'(0 . "LWPOLYLINE")'(100 . "AcDbEntity")'(100 . "AcDbPolyline")(cons 8 "开洞线")
(cons 90 3) (cons 10 p1) (cons 10 p0) (cons 10 p3) ))
)
(princ))
发表于 2023-10-27 18:59 | 显示全部楼层
这个功能不错,我用画门板的开启线,马克了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-6-23 10:42 , Processed in 0.138831 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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