明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 700|回复: 8

[讨论] 各位大佬,这个动态尺寸,现在左键是连续画线,如何改成左键画一次就结束?谢谢

[复制链接]
发表于 2023-4-7 15:17 | 显示全部楼层 |阅读模式
本帖最后由 depgfdepgf 于 2023-4-7 17:05 编辑

(defun c:g15( / cood d1 d2 data1 data3 data4 en1 en3 en4 gr loop pt1 ptb)
  (setvar "cmdecho" 0)  
  (setq d1 0 pt1 (getpoint "\n 动态显示线段的长度,请确定原点:"))
  (entmake (list '(0 . "line")  (cons 62 2)  (cons 10 pt1) (cons 11 (polar pt1 0 100) ) ) )
  (setq en1 (entlast)   data1 (entget en1)  )  
  (entmake (list '(0 . "TEXT") (cons 1 (strcat "d1=" (rtos d1 2 3))) (cons 10 pt1) (cons 40 100 ) (cons 41 0.85 )(cons 62 3)  ))
  (setq en4 (entlast)   data4 (entget en4)  )
  (setq  loop T)
(while loop
    (setq gr (grread T 8))
    (setq cood (car gr)  ptb (cadr gr))
    (cond
       ((= cood 3) ;;; 鼠标左键
          (progn      
                 (setq pt1 ptb)
                 (entmake (list '(0 . "line")  (cons 62 2)  (cons 10 pt1) (cons 11 (polar pt1 0 100) ) ) )
                 (setq en1 (entlast)   data1 (entget en1)  d1 (+ d1 d2) )
                     (entmake (list '(0 . "TEXT") (cons 1 (strcat " " (rtos d1 2 3))) (cons 10 pt1) (cons 40 100 )(cons 41 0.85 ) (cons 62 3)  ))
                 (setq en4 (entlast)   data4 (entget en4)  )
                 ;(setq loop nil)
       ))
       ((= cood 11) (setq loop nil)(entdel en1)(entdel en4)  )
       ((= cood 25) (setq loop nil)(entdel en1)(entdel en4)  )
       ((equal gr '(2 32)) (setq loop nil)(entdel en1)(entdel en4))
      
       ( (= cood 5)  
          (progn              
                 (setq pt2 (cdr (assoc 10 data1))  data1 (subst (cons 11 ptb) (assoc 11 data1) data1))                 
                 (entmod data1)         
                 (setq d2 (distance pt1 ptb)  ag1 (+ (angle pt2 ptb) 0)  )
                 (cond
                 ((< (* pi 0.5) (angle pt2 ptb) pi)(setq ag2 (+ (angle pt2 ptb) pi))  )
                 ((< (* pi 1) (angle pt2 ptb) (* pi 1.5))(setq ag2 (- (angle pt2 ptb) pi))  )
                 (t (setq ag2 (angle pt2 ptb) )  )      
                 )
                 (setq pt3 (polar pt2 ag1 (/ d2 2.0))  pt3 (polar pt3 (+ ag2 (* pi 0.5)) 30)      )
                 (setq data4 (subst (cons 10  pt3 ) (assoc 10 data4) data4) )                 
                 (setq data4 (subst (cons 50  ag2 ) (assoc 50 data4) data4) )                 
                 (setq data4 (subst (cons 1  (strcat " " (rtos d2 2 3))  ) (assoc 1 data4) data4))
                 (entmod data4)        ;当前段长度         
        
         ))
    );cond   
   
);while
  (princ "\n    over 。")
  (princ)
)
发表于 2023-4-7 15:55 | 显示全部楼层
我这右键是退出啊,你是说左键吧?
发表于 2023-4-7 15:56 | 显示全部楼层
现在就是鼠标右键结束啊
 楼主| 发表于 2023-4-7 17:07 | 显示全部楼层
是左键,不小心发错了,如何修改成,左键点一次就和右键一样的功能,不要连续画线
发表于 2023-4-7 18:12 | 显示全部楼层
depgfdepgf 发表于 2023-4-7 17:07
是左键,不小心发错了,如何修改成,左键点一次就和右键一样的功能,不要连续画线

((= cood 3) ;;; 鼠标左键
          (progn      
                 (setq pt1 ptb)
                 (entmake (list '(0 . "line")  (cons 62 2)  (cons 10 pt1) (cons 11 (polar pt1 0 100) ) ) )
                 (setq en1 (entlast)   data1 (entget en1)  d1 (+ d1 d2) )
                     (entmake (list '(0 . "TEXT") (cons 1 (strcat " " (rtos d1 2 3))) (cons 10 pt1) (cons 40 100 )(cons 41 0.85 ) (cons 62 3)  ))
                 (setq en4 (entlast)   data4 (entget en4)  )
                 (setq loop nil)(entdel en1)(entdel en4)
       ))

评分

参与人数 1明经币 +1 收起 理由
depgfdepgf + 1 谢谢大佬!很给力!

查看全部评分

发表于 2023-4-8 07:11 | 显示全部楼层
这个程序,怎么加正交控制?
发表于 2023-4-8 07:40 | 显示全部楼层
lxdz443 发表于 2023-4-8 07:11
这个程序,怎么加正交控制?

看看zml84大佬的函数,支持捕捉 正交
https://mp.weixin.qq.com/s/Y4CEa_r-xEMob8zm9XlD5g
发表于 2023-5-20 18:06 | 显示全部楼层
怎么修改字体大小
发表于 2023-12-9 15:52 | 显示全部楼层
同问这个程序,怎么加正交控制?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-13 05:44 , Processed in 0.154734 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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