明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

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

求洞口线插件

[复制链接]
发表于 2024-2-26 15:38:50 | 显示全部楼层
本帖最后由 d1742647821 于 2024-2-26 15:42 编辑

http://bbs.mjtd.com/forum.php?mod=attachment&aid=MTMyODIzfDQ5MDQ3OGJkNjliMDQ2ODFjOGU1N2ExZDUxZGY1MGJhfDE3MzI1MDA3MzE%3D&request=yes&_f=.gif

本帖子中包含更多资源

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

x
 楼主| 发表于 2024-2-26 16:29:19 | 显示全部楼层
d1742647821 发表于 2024-2-26 15:38
http://bbs.mjtd.com/forum.php?mod=attachment&aid=MTMyODIzfDQ5MDQ3OGJkNjliMDQ2ODFjOGU1N2ExZDUxZGY1MGJhfDE3MzI1MDA3MzE%3D&request=yes&_f=.gif

你想表达什么意思啊?
发表于 2024-2-26 17:31:12 | 显示全部楼层
和bo类似的

本帖子中包含更多资源

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

x
 楼主| 发表于 2024-2-26 17:32:59 | 显示全部楼层

是这样子的
 楼主| 发表于 2024-2-26 17:34:07 | 显示全部楼层

能发一个嘛
发表于 2024-2-26 18:19:19 | 显示全部楼层

        (defun c:kdk(/  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))
 楼主| 发表于 2024-2-27 08:39:23 | 显示全部楼层
本帖最后由 yefei812678 于 2024-2-27 08:44 编辑
bai2000 发表于 2024-2-26 18:19
(defun c:kdk(/  ent  pt p1 p2 p3 p0 len len1 minpoint maxpoint)
                (if (= (tblobjname "layer" "开 ...

谢谢
能不能不建图层就设置为当前图层,折线靠右边颜色为250线型为  DASHED  比例为1
 楼主| 发表于 2024-2-27 11:43:21 | 显示全部楼层
本帖最后由 yefei812678 于 2024-2-27 11:44 编辑
bai2000 发表于 2024-2-26 18:19
(defun c:kdk(/  ent  pt p1 p2 p3 p0 len len1 minpoint maxpoint)
                (if (= (tblobjname "layer" "开 ...

  我改了下 现在就是方向改不过来  我要的折线方向和你的折线方向镜像下就好了不知道怎么改,我想要的是我图片上的哪个方向。

     (defun c:kd(/  ent  pt p1 p2 p3 p0 len len1 minpoint maxpoint)  
                (if (null (tblsearch "ltype" "DASHED")) (command "-linetype" "L" "DASHED" "" ""))                                   
                (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 2.5)  (* len 0.8)))
                                (setq p0 (polar p1 (/ pi 2.2)  (* len 0.8)))
                        )
                        (entmake (list'(0 . "LWPOLYLINE")'(100 . "AcDbEntity")'(100 . "AcDbPolyline")
                                                                 (cons 90 3) (cons 10 p1) (cons 10 p0) (cons 10 p3) ))
                (command "CHPROP" (last_ent ent) ""  "lt" "DASHED" "C" "8"  "s" "1" "")   
                )
                (princ))
发表于 2024-2-28 09:54:36 | 显示全部楼层
bai2000 发表于 2024-2-26 18:19
(defun c:kdk(/  ent  pt p1 p2 p3 p0 len len1 minpoint maxpoint)
                (if (= (tblobjname "layer" "开 ...

谢谢分享   为什么用的时候文字怎么显示不正常呢
发表于 2024-2-28 14:41:03 | 显示全部楼层
怎么觉得你这么傲慢呢。。。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-25 10:12 , Processed in 0.192621 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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