明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: xj6019

[讨论] 关于画垂线的,哪位大佬给优化一下啊,拜托了

[复制链接]
发表于 2019-12-19 12:02 | 显示全部楼层
纯平民代码,弧形不适用,不知道有无bug

(defun c:tt5 (/ ang ename ent1 ent2 entdat p0 p1 pk pmid w)
        (setq w t)
        (while w
                (if (setq ent1 (entsel "\n请选择对象<定点垂线>:"))
                        (progn (setq ename (car ent1)  entdat(entget ename)  pk (cadr ent1) p0 (osnap pk "_nea")  p1 (getpoint"\n请输入垂线点:") ang (angle pk p0))
                                (command "line" "non" (polar (inters p1 (polar p1 ang -1000) pk (polar pk (+ ang (* 0.5 pi)) -1000) nil) ang 1000) "non" (polar (inters p1 (polar p1 ang -1000) pk (polar pk (+ ang (* 0.5 pi)) -1000) nil) ang -1000) ""));progn1
                        (progn (while (setq ent2 (entsel "\n请选择对象<中垂线>:"))
                                                         (setq ename (car ent2) entdat(entget ename) pk (cadr ent2) p0 (osnap pk "nea") pmid (osnap pk "mid")        ang (angle pk p0))
                                                         (command "line" "non" (polar pmid ang 1000) "non" (polar pmid ang -1000) "")) (c:tt5));progn2
                       
                );if
        );while
        (princ)       
)
回复

使用道具 举报

 楼主| 发表于 2019-12-19 12:10 | 显示全部楼层
start4444 发表于 2019-12-19 12:02
纯平民代码,弧形不适用,不知道有无bug

(defun c:tt5 (/ ang ename ent1 ent2 entdat p0 p1 pk  ...

经测验,完美运行,无BUG,比之前的的代码更简练了,哥们 你太牛了!!谢谢
回复

使用道具 举报

 楼主| 发表于 2019-12-19 12:25 | 显示全部楼层
start4444 发表于 2019-12-19 12:02
纯平民代码,弧形不适用,不知道有无bug

(defun c:tt5 (/ ang ename ent1 ent2 entdat p0 p1 pk  ...

(command "Selectioncycling" "0");ctrl/w關閉
(command "Selectioncycling" "2");ctrl/w打開
我想把这两句加进去,开头放上的管用,结尾放上的好像不起作用呀,加上这个函数避免重线的时候点选麻烦
回复

使用道具 举报

发表于 2019-12-19 12:51 | 显示全部楼层
代码是死循环,要按esc退出,最后面加个出错函数把参数恢复就行了

(defun *error* (msg) (command "Selectioncycling" "2") (princ "程序退出! "))
回复

使用道具 举报

 楼主| 发表于 2019-12-19 13:10 | 显示全部楼层
start4444 发表于 2019-12-19 12:51
代码是死循环,要按esc退出,最后面加个出错函数把参数恢复就行了

(defun *error* (msg) (command "Sele ...

原谅我有点笨 我试着换了好几个方式加上,都不行呢,复制的代码是最后一次实验的,在给看看吧
我尝试把末尾删掉只留你写的这句,也是没效果的,要不你加好再来段现成的吧,谢谢!
(defun c:HCX (/ ang ename ent1 ent2 entdat p0 p1 pk pmid w)
  (command "Selectioncycling" "0");ctrl/w關閉
        (setq w t)
        (while w
                (if (setq ent1 (entsel "\n請選擇對象<一般垂線>:"))
                        (progn (setq ename (car ent1)  entdat(entget ename)  pk (cadr ent1) p0 (osnap pk "_nea")  p1 (getpoint"\n請輸入垂足:") ang (angle pk p0))
                                (command "line" "non" (polar (inters p1 (polar p1 ang -1000) pk (polar pk (+ ang (* 0.5 pi)) -1000) nil) ang 1000) "non" (polar (inters p1 (polar p1 ang -1000) pk (polar pk (+ ang (* 0.5 pi)) -1000) nil) ang -1000) ""));progn1
                        (progn (while (setq ent2 (entsel "\n請選擇對象<中垂線>:"))
                                                         (setq ename (car ent2) entdat(entget ename) pk (cadr ent2) p0 (osnap pk "nea") pmid (osnap pk "mid")        ang (angle pk p0))
                                                         (command "line" "non" (polar pmid ang 1000) "non" (polar pmid ang -1000) "")) (c:HCX))
                            (defun *error* (msg) (command "Selectioncycling" "2") (princ "程序退出! "))
                               );if
        );while
        (princ)        
)
回复

使用道具 举报

发表于 2019-12-19 13:49 | 显示全部楼层
xj6019 发表于 2019-12-19 13:10
原谅我有点笨 我试着换了好几个方式加上,都不行呢,复制的代码是最后一次实验的,在给看看吧
我尝试把 ...

(defun c:HCX (/ ang ename ent1 ent2 entdat p0 p1 pk pmid w)
  (command "Selectioncycling" "0");ctrl/w關閉
        (setq w t)
        (while w
                (if (setq ent1 (entsel "\n請選擇對象<一般垂線>:"))
                        (progn (setq ename (car ent1)  entdat(entget ename)  pk (cadr ent1) p0 (osnap pk "_nea")  p1 (getpoint"\n請輸入垂足:") ang (angle pk p0))
                                (command "line" "non" (polar (inters p1 (polar p1 ang -1000) pk (polar pk (+ ang (* 0.5 pi)) -1000) nil) ang 1000) "non" (polar (inters p1 (polar p1 ang -1000) pk (polar pk (+ ang (* 0.5 pi)) -1000) nil) ang -1000) ""));progn1
                        (progn (while (setq ent2 (entsel "\n請選擇對象<中垂線>:"))
                                                         (setq ename (car ent2) entdat(entget ename) pk (cadr ent2) p0 (osnap pk "nea") pmid (osnap pk "mid")        ang (angle pk p0))
                                                         (command "line" "non" (polar pmid ang 1000) "non" (polar pmid ang -1000) "")) (c:HCX))
                           
                               );if
        );while
        (princ)        
) (defun *error* (msg) (command "Selectioncycling" "2") (princ "程序退出! "))
回复

使用道具 举报

 楼主| 发表于 2019-12-19 13:59 | 显示全部楼层
start4444 发表于 2019-12-19 13:49
(defun c:HCX (/ ang ename ent1 ent2 entdat p0 p1 pk pmid w)
  (command "Selectioncycling" "0");ct ...

朋友谢谢了,不过ESC报错还是不行,算了不管这个了,这点问题不是问题了,完全不耽误使用,这问题略过吧
下面这个问题帮我看看好吗,这个一直想解决一下,发布的帖子都没一个人回复的,我觉得应该不费劲吧,布局的事我更不懂了,你看看,可以弄一下吗?
http://bbs.mjtd.com/thread-180617-1-1.html
回复

使用道具 举报

发表于 2019-12-19 20:27 | 显示全部楼层
start4444 发表于 2019-12-19 13:49
(defun c:HCX (/ ang ename ent1 ent2 entdat p0 p1 pk pmid w)
  (command "Selectioncycling" "0");ct ...

大神好!请问加载后使用时提示文字乱码,有解决的办法吗?谢谢

本帖子中包含更多资源

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

x

点评

把代码里面的中文改成简体看看  发表于 2019-12-19 22:52
回复

使用道具 举报

发表于 2019-12-19 20:30 | 显示全部楼层
&#169; 2001-2013 Comsenz Inc.
回复

使用道具 举报

发表于 2019-12-19 23:14 | 显示全部楼层

适合标注和图块的状态

本帖子中包含更多资源

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

x
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-23 10:40 , Processed in 0.142508 second(s), 22 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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