乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 30|回复: 6

[编程交流] 如何征服entsel#039;s d

[复制链接]

91

主题

428

帖子

326

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
474
发表于 2022-7-6 09:44:36 | 显示全部楼层 |阅读模式
朋友们好,
 
正如你们中的一些人所知,entsel是一个很好的选择单个对象的函数,但它在区分“按enter键”和“不选择任何对象”方面有一个严重的缺陷:(。
 
有人有什么建议可以克服这个缺陷吗:哎呀:?
回复

使用道具 举报

44

主题

3166

帖子

2803

银币

中流砥柱

Rank: 25

铜币
557
发表于 2022-7-6 10:01:03 | 显示全部楼层
我不确定我是否理解你的问题。。。您试图调用什么行为?
回复

使用道具 举报

91

主题

428

帖子

326

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
474
发表于 2022-7-6 10:10:14 | 显示全部楼层
代码如下:
  1. (defun C:Length () (MT-TotalLength))
  2. (defun MT-TotalLength (/ *error* ans layname cont len)
  3.    (MT-Start)
  4.    (initget "Name eXit _Name eXit")
  5.    (setq ans nil)
  6.    (setq ans
  7.             (entsel
  8.                 "\nSelect an object on the layer to proceed [Name/eXit] <eXit>: "
  9.             )
  10.    )
  11.    (cond
  12.        ((member ans '(nil "eXit")) (exit))
  13.        ((= "Name" ans)
  14.         (setq cont T)
  15.         (while cont
  16.             (setq layname (getstring T "\nEnter layer name: "))
  17.             (if (null (read layname))
  18.                 (progn (princ "\nNull name for layer not allowed, try again."))
  19.                 (progn (if (tblsearch "layer" layname)
  20.                            (setq cont nil)
  21.                            (princ (strcat "\nLayer ""
  22.                                           layname
  23.                                           "" not exists, try again."
  24.                                   )
  25.                            )
  26.                        )
  27.                 )
  28.             )
  29.         )
  30.        )
  31.        (T (setq layname (cdr (assoc 8 (entget (car ans))))))
  32.    )
  33.    (and (setq ss (ssget "_X"
  34.                         (list (cons -4 "<OR")
  35.                               (cons 0 "LINE")
  36.                               (cons 0 "ARC")
  37.                               (cons 0 "LWPOLYLINE")
  38.                               (cons -4 "OR>")
  39.                               (cons 8 layname)
  40.                         )
  41.                  )
  42.         )
  43.         (setq len (MT-Calc-Length ss))
  44.    )
  45.    (setq msg
  46.             (strcat
  47.                 "Total length of objects (Lines, Arcs, Polylines) in layer:   ""
  48.                 layname
  49.                 ""\n\nequals to:   "
  50.                 (rtos len)
  51.             )
  52.    )
  53.    (princ msg)
  54.    (alert msg)
  55.    (MT-End)
  56. )
  57. (defun MT-Calc-Length (ss / sslist len)
  58.    (setq sslist (MT-Conv-SS-To-List ss))
  59.    (setq len 0)
  60.    (foreach obj sslist (setq len (+ len (MT-Get-Obj-Length obj))))
  61. )
  62. (defun MT-Conv-SS-To-List (ss / entlist index)
  63.    (setq entlist nil)
  64.    (if (= 'PICKSET (type ss))
  65.        (progn (setq index -1)
  66.               (repeat (sslength ss)
  67.                   (setq
  68.                       entlist (append (list (ssname ss (setq index (1+ index))))
  69.                                       entlist
  70.                               )
  71.                   )
  72.               )
  73.        )
  74.    )
  75.    (reverse entlist)
  76. )
  77. (defun MT-Error (msg)
  78.    (or (member (read msg) '(nil *BREAK *CANCEL*)); *EXIT* isn't an error condition
  79.        (princ (strcat "\n** Error: " msg " **"))
  80.    )
  81.    (setvar 'Cmdecho 1)
  82.    (princ)
  83. )
  84. (defun MT-Start () (setq *error* MT-Error) (setvar 'Cmdecho 0))
  85. (defun MT-End () (MT-Error ""))
  86. (defun MT-Exit () (exit))

 
如您所知,在工作空间的空白区域按Enter键和单击鼠标底部没有区别。
这就是上述限制。
回复

使用道具 举报

54

主题

3755

帖子

3583

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
438
发表于 2022-7-6 10:15:19 | 显示全部楼层
将errno变量与while一起使用
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 10:29:50 | 显示全部楼层
正如Alan所说,可以使用ERRNO系统变量。。。
 
请参阅此处以获取示例。
回复

使用道具 举报

91

主题

428

帖子

326

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
474
发表于 2022-7-6 10:40:54 | 显示全部楼层
alanjt和Lee Mac,非常感谢。
我将使用说明和提到的代码。
回复

使用道具 举报

54

主题

3755

帖子

3583

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
438
发表于 2022-7-6 10:53:09 | 显示全部楼层
享受
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-6 23:42 , Processed in 0.328962 second(s), 66 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表