乐筑天下

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

[编程交流] setq问题

[复制链接]

2

主题

3

帖子

1

银币

初来乍到

Rank: 1

铜币
10
发表于 2022-7-6 07:53:43 | 显示全部楼层 |阅读模式
您好,我用4个点创建了一个矩形。那么,有没有办法将两条垂直线自动分配到两个变量Line\u 1/Line\u 2中,而不是使用
(setq Line_1(entsel“选择第1行:))。
非常感谢
杰伊
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 08:16:58 | 显示全部楼层
如果使用命令功能创建了行,请使用entlast收集添加到数据库的最后一个实体;否则,使用entmakex,函数将返回所创建实体的实体名称。
 
欢迎来到周。
回复

使用道具 举报

51

主题

481

帖子

457

银币

后起之秀

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

铜币
262
发表于 2022-7-6 08:50:16 | 显示全部楼层
选项
  1. (defun c:rec1 (/ pt1 pt2 pt3 pt4)
  2. (setq pt1 (getpoint "\n click first corner"))
  3. (setq ortmd (getvar "orthomode"))
  4. (setvar "orthomode" 0)
  5. (setq pt2 (getcorner pt1 "\n click second corner"))
  6. (setvar "orthomode" ortmd)
  7. (command "rectang" pt1 pt2 "")
  8. (setq pt3 (list (car pt2) (cadr pt1)))
  9. (setq pt4 (list (car pt1) (cadr pt2)))
  10. (command "line" pt1 pt2 "")
  11. (command "line" pt3 pt4 "")
  12. )

 
另一个
  1. (defun c:rec2 (/ pt1 pt2 pt3 pt4)
  2. (setq pt1 (getpoint "\n click first corner"))
  3. (setq ortmd (getvar "orthomode"))
  4. (setvar "orthomode" 0)
  5. (setq pt2 (getpoint pt1 "\n click second corner"))
  6. (setvar "orthomode" ortmd)
  7. (setq pt3 (list (car pt2) (cadr pt1)))
  8. (setq pt4 (list (car pt1) (cadr pt2)))
  9. (LWPoly pt1 pt3 pt2 pt4)
  10. (Line pt1 pt2)
  11. (Line pt3 pt4)
  12. )
  13.   
  14. (defun LWPoly (p1 p2 p3 p4)
  15. (entmakex (list
  16.       (cons 0 "LWPOLYLINE")
  17.       (cons 100 "AcDbEntity")
  18.       (cons 100 "AcDbPolyline")
  19.       (cons 90 4)
  20.       (cons 70 1)
  21.       (cons 10 p1)
  22.       (cons 10 p2)
  23.       (cons 10 p3)
  24.       (cons 10 p4)
  25.       )))
  26. (defun Line (p1 p2)
  27. (entmakex (list (cons 0 "LINE")
  28.                  (cons 10 p1)
  29.                  (cons 11 p2))))
回复

使用道具 举报

51

主题

481

帖子

457

银币

后起之秀

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

铜币
262
发表于 2022-7-6 09:10:22 | 显示全部楼层
另一个
只有一个闭合的LWPoly
  1. (defun c:rec3 (/ pt1 pt2 pt3 pt4)
  2. (setq pt1 (getpoint "\n click first corner"))
  3. (setq ortmd (getvar "orthomode"))
  4. (setvar "orthomode" 0)
  5. (setq pt2 (getpoint pt1 "\n click second corner"))
  6. (setvar "orthomode" ortmd)
  7. (setq pt3 (list (car pt2) (cadr pt1)))
  8. (setq pt4 (list (car pt1) (cadr pt2)))
  9. (setq lst (list pt1 pt3 pt2 pt4 pt1 pt2 pt4 pt3))
  10. (LWPoly lst)
  11. )
  12. (defun LWPoly (lst)
  13. (entmakex (append (list (cons 0 "LWPOLYLINE")
  14.                          (cons 100 "AcDbEntity")
  15.                          (cons 100 "AcDbPolyline")
  16.                          (cons 90 (length lst))
  17.                   (cons 70 1) ; closed LWPoly
  18.                          )
  19.                    (mapcar (function (lambda (p) (cons 10 p))) lst))))
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-9 20:54 , Processed in 0.344476 second(s), 60 queries .

© 2020-2025 乐筑天下

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