乐筑天下

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

[编程交流] Entmake rect。

[复制链接]

36

主题

161

帖子

125

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
182
发表于 2022-7-5 17:42:11 | 显示全部楼层 |阅读模式
  1. (command "_.rectang" "f" 10 (getpoint)(getpoint))

 
如何使用“entmake”函数做到这一点?
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 18:00:17 | 显示全部楼层
您需要计算8个顶点中每个顶点的位置,计算圆角[noparse][tan(pi/8)][/noparse]的适当凸出值,然后使用此类顶点和凸出数据entmake(x)一个LWPOLYLINE实体。
回复

使用道具 举报

36

主题

161

帖子

125

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
182
发表于 2022-7-5 18:05:18 | 显示全部楼层
谢谢你,李,如果“f”=0,那么只有4个顶点?
 
看起来很难,我的数学和几何很差。
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 18:17:32 | 显示全部楼层
下面是一个供您学习的示例:
  1. ;; Rounded Rectangle Example  -  Lee Mac 2016
  2. (defun c:myrect ( / blg lst ocs pt1 pt2 rad tmp )
  3.    
  4.    (setq rad 10.0) ;; Fillet Radius
  5.    
  6.    (if (and (setq pt1 (getpoint "\nSpecify 1st point: "))
  7.             (setq pt2 ((if (zerop (getvar 'worlducs)) getpoint getcorner) pt1 "\nSpecify 2nd point: "))
  8.        )
  9.        (progn
  10.            (setq ocs (trans '(0 0 1) 1 0 t)
  11.                  tmp (mapcar 'max pt1 pt2)
  12.                  pt1 (mapcar 'min pt1 pt2)
  13.                  pt2 tmp
  14.                  lst (list pt1 (list (car pt2) (cadr pt1)) pt2 (list (car pt1) (cadr pt2)))
  15.                  blg (1- (sqrt 2))
  16.            )
  17.            (if (equal rad 0.0 1e-
  18.                (entmake
  19.                    (append
  20.                       '(   (000 . "LWPOLYLINE")
  21.                            (100 . "AcDbEntity")
  22.                            (100 . "AcDbPolyline")
  23.                            (090 . 4)
  24.                            (070 . 1)
  25.                        )
  26.                        (list (cons 038 (caddr (trans pt1 1 ocs))))
  27.                        (mapcar '(lambda ( x ) (cons 10 (trans x 1 ocs))) lst)
  28.                        (list (cons 210 ocs))
  29.                    )
  30.                )
  31.                (entmake
  32.                    (append
  33.                       '(   (000 . "LWPOLYLINE")
  34.                            (100 . "AcDbEntity")
  35.                            (100 . "AcDbPolyline")
  36.                            (090 .
  37.                            (070 . 1)
  38.                        )
  39.                        (list (cons 038 (caddr (trans pt1 1 ocs))))
  40.                        (apply 'append
  41.                            (mapcar
  42.                                (function
  43.                                    (lambda ( a b )
  44.                                        (apply 'append
  45.                                            (mapcar
  46.                                                (function
  47.                                                    (lambda ( c d )
  48.                                                        (list
  49.                                                            (cons 10 (trans (mapcar '+ a c) 1 ocs))
  50.                                                            (cons 42 d)
  51.                                                        )
  52.                                                    )
  53.                                                )
  54.                                                b (list blg 0.0)
  55.                                            )
  56.                                        )
  57.                                    )
  58.                                )
  59.                                lst
  60.                                (list
  61.                                    (list (list 0 rad)     (list rad 0))
  62.                                    (list (list (- rad) 0) (list 0 rad))
  63.                                    (list (list 0 (- rad)) (list (- rad) 0))
  64.                                    (list (list rad 0)     (list 0 (- rad)))
  65.                                )
  66.                            )
  67.                        )
  68.                        (list (cons 210 ocs))
  69.                    )
  70.                )
  71.            )
  72.        )
  73.    )
  74.    (princ)
  75. )

上述内容也应在所有UCS和视图中兼容。
回复

使用道具 举报

36

主题

161

帖子

125

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
182
发表于 2022-7-5 18:26:13 | 显示全部楼层
 
非常感谢你!李。我会好好学习的!
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-5 18:38:44 | 显示全部楼层
 
不客气-请随时询问有关代码的任何问题。
回复

使用道具 举报

36

主题

161

帖子

125

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
182
发表于 2022-7-5 18:45:36 | 显示全部楼层
 
谢谢,我做了一点改变。
 
1.使用参数
  1. (defun myrect (rad pt1 pt2 lay col / blg lst ocs tmp )
  2. (if (and pt1 pt2 rad lay col)
  3.        (progn
  4.    ...
  5.        ...

 
2.
  1. (list (cons 038 (caddr (trans pt1 1 ocs))))

更改为-->
  1. (list (cons 8 lay)(cons 62 col)(cons 038 (caddr (trans pt1 1 ocs))))
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-13 04:31 , Processed in 0.482992 second(s), 66 queries .

© 2020-2025 乐筑天下

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