乐筑天下

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

[编程交流] 多线宽度/比例LISP

[复制链接]

95

主题

477

帖子

383

银币

后起之秀

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

铜币
475
发表于 2022-7-5 18:08:27 | 显示全部楼层 |阅读模式
因此,我正在研究一些LISP例程,以使使用MLINES更有趣。我当前快速编写的附加dxf代码40的代码(这是mlines比例的所在)如下所示:
  1. (defun c:mlwidth ()
  2. (if (setq ss (LM:ssget "\nSelect multilines: " '("_:L" ((0 . "MLINE")))))
  3.    (initget 4)
  4.    (setq mwidth
  5.    (cond ((getdist "\nSpecify width for all mlines <0.0>: ")) (0.0)))
  6.    (setq newdxf '(40 . mwidth))
  7.    (setq cnt 0)
  8.    (repeat (sslength ss)
  9.      (setq dxfdata (ssname ss cnt))
  10.      (setq entdata (entget dxfdata))
  11.      (setq dxfdata (subst newdxf olddxf dxfdata))
  12.      (entmod dxfdata)
  13.      (setq cnt (+ 1 cnt))
  14.    )
  15. )
  16. )
  17. ;; ssget  -  Lee Mac
  18. ;; A wrapper for the ssget function to permit the use of a custom selection prompt
  19. ;; msg - [str] selection prompt
  20. ;; arg - [lst] list of ssget arguments
  21. (defun LM:ssget (msg arg / sel)
  22. (princ msg)
  23. (setvar 'nomutt 1)
  24. (setq sel (vl-catch-all-apply 'ssget arg))
  25. (setvar 'nomutt 0)
  26. (if (not (vl-catch-all-error-p sel))
  27.    sel
  28. )
  29. )
。我不明白为什么这实际上不是附加dxf数据,而是将其全部打印到屏幕上。有人知道为什么吗?
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 18:37:36 | 显示全部楼层
一些即时更正:
我还建议您阅读本教程,了解为什么在这种情况下必须使用cons。
 
回复

使用道具 举报

95

主题

477

帖子

383

银币

后起之秀

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

铜币
475
发表于 2022-7-5 18:42:56 | 显示全部楼层
谢谢李!我正在阅读cons函数以理解它。
回复

使用道具 举报

95

主题

477

帖子

383

银币

后起之秀

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

铜币
475
发表于 2022-7-5 19:06:06 | 显示全部楼层
李,很抱歉再次打扰你,但在阅读了你的帖子后,我仍然对cons函数有点困惑。这是我的更新代码。我很困惑为什么我同时使用cons功能和assoc不起作用。
  1. (defun c:mlwidth (/ ss mwidth newdxf cnt dxfdata ent olddxf)
  2. (if (setq
  3. ss (LM:ssget "\nSelect multilines: " '("_:L" ((0 . "MLINE"))))
  4.      )
  5.    (progn
  6.      (initget 4)
  7.      (setq
  8. mwidth (cond
  9.   ((getdist "\nSpecify width for all mlines <0.0>: "))
  10.   (0.0)
  11.        )
  12.      )
  13.      (setq cnt 0)
  14.      (repeat (sslength ss)
  15. (setq dxfdata (ssname ss cnt))
  16. (setq ent (entget dxfdata))
  17. (setq dxfdata (subst (cons 40 mwidth) (assoc 8 ent) ent))
  18. (entmod dxfdata)
  19. (setq cnt (+ 1 cnt))
  20.      )
  21.    )
  22. )
  23. (princ)
  24. )
回复

使用道具 举报

95

主题

477

帖子

383

银币

后起之秀

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

铜币
475
发表于 2022-7-5 19:20:49 | 显示全部楼层
所以我最终使用了visual lisp。我只需要对它感到更舒服,因为它似乎可以让编码变得更容易。如果人们将来需要,我最后的代码是:
  1. 3
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-12 20:31 , Processed in 0.461522 second(s), 62 queries .

© 2020-2025 乐筑天下

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