找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 618|回复: 2

[求助]:请QUN帮忙看看,谢谢了

[复制链接]

已领礼包: 58个

财富等级: 招财进宝

发表于 2007-12-27 12:05:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
QUN版主你好,我想仿照理正Q键功能写个小程序,怎样实现在屏幕上选点,直接调用ssget,而不是需要点二次,请帮忙看看下面代码,谢谢
(defun c:test (/ a)
    (defun grreadstr1 (msg / k)
        (prompt msg)
        (if (= (car (setq k (grread nil 4 2))) 12)
            (setq k (grread nil 4 2))
            k
        )
    )
    (setq a (grreadstr1 "\n请选择{Q改参数}:"))
    (if        (= (car a) 3)
        (ssget)
        (princ "\n输入新的参数:")
    )
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2007-12-27 13:36:04 | 显示全部楼层
理正Q键功能是C程序实现的,你的方法我没用过。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 58个

财富等级: 招财进宝

 楼主| 发表于 2007-12-28 19:37:56 | 显示全部楼层
;用笨方法解决一下
(defun c:tt (/ a b pt1 pt2 loop mode ss1 ss2 ss3)
  (setq i 0)
  (defun zgx-redraw-ss (ss n / i)
    (setq i 0)
    (repeat (sslength ss)
      (redraw (ssname ss i) n)
      (setq i (1+ i))
    )
  )
  (defun grreadstr12 (msg / k)
    (prompt msg)
    (if        (= (car (setq k (grread nil 4 2))) 12)
      (setq k (grread nil 4 2))
      k
    )
  )
  (setq loop t)
  (while loop
    (setq b (grreadstr12 "\n请选择物体{Q改参数}:"))
    (setq a (car b))
    (cond
      ((member a '(11 12))
       (progn (setq loop nil)
              (quit)
       )
      )
      ((= a 3)
       ;;progn
       (progn
         (setq pt1 (cadr b))
         (setq loop nil)
         (if (not (setq ss1 (ssget pt1)))
           (progn
             (setq pt2 (getcorner pt1))
             (if (> (car pt1) (car pt2))
               (setq mode "c")
               (setq mode "w")
             )
             (setq ss (ssget mode pt1 pt2))
             (zgx-redraw-ss ss 3)
             (prompt "\n请继续选择:")
             (setq ss1 (ssget))
           )
           (progn
             (zgx-redraw-ss ss1 3)
             (prompt "\n请继续选择:")
             (setq ss2 (ssget))
             (zgx-redraw-ss ss1 4)
           )
         )
       )
       ;;progn
      )
      ((= a 2)
       (progn
         (if (member (cadr b) '(13 32))
           (setq loop nil)
           (progn
             (if (not (member (cadr b) '(81 113)))
               (setq loop t)
               (progn
                 (princ "\n成功:")
                 (setq i (1+ i))
                 (princ (strcat "\n" (rtos i 2 0)))
                 (setq loop t)
               )
             )
           )
         )
       )
      )
      (t (quit))
    )
  )
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-18 05:58 , Processed in 0.357252 second(s), 34 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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