乐筑天下

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

[编程交流] 等距多边形

[复制链接]

17

主题

193

帖子

179

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
84
发表于 2022-7-6 07:31:42 | 显示全部楼层 |阅读模式
有没有人可以用lisp来绘制等距多边形?
我做的是做一个等距圆,把圆分成几个部分,追踪节点,擦除圆和节点,这就是我的多边形。
回复

使用道具 举报

16

主题

119

帖子

109

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
82
发表于 2022-7-6 07:35:18 | 显示全部楼层
如果我理解正确的话,你的等距圆是一个椭圆。
你们的分割长度都相等吗?
 
如果是这样,杰出的李Mac有一个优秀的程序,将圆和椭圆(以及其他)等长分割成等长的段。
我经常使用这个程序。我相信李不会介意我把你引向这里。谢谢李。
 
可以在李的网站上找到:-
 
http://lee-mac.com/segmentcurve.html
回复

使用道具 举报

17

主题

193

帖子

179

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
84
发表于 2022-7-6 07:38:32 | 显示全部楼层
 
谢谢你的回复。对我有一个椭圆
我要找的是一个lisp,它会提示我多边形有多少边,并输入agad的直径。
 
但这也有帮助。谢谢!
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-6 07:42:50 | 显示全部楼层
也许,这是:
 
  1. (defun transptiso (pt)
  2. (list (+ (car (polar (list 0.0 0.0 0.0) (/ pi 6.0) (car pt)))
  3.        (car (polar (list 0.0 0.0 0.0) (* 5.0 (/ pi 6.0)) (cadr pt))) )
  4.        (+ (cadr (polar (list 0.0 0.0 0.0) (/ pi 6.0) (car pt)))
  5.        (cadr (polar (list 0.0 0.0 0.0) (* 5.0 (/ pi 6.0)) (cadr pt))) )
  6.        0.0
  7. )
  8. )
  9. (defun c:isopolygon (/ pol vertlst vertlstn)
  10. (vl-cmdf "_.ucs" "w")
  11. (vl-cmdf "_.plan" "")
  12. (vl-cmdf "_.zoom" "c" "0,0,0" "")
  13. (vl-cmdf "_.polygon" pause "0,0,0" pause pause)
  14. (setq pol (entlast))
  15. (mapcar '(lambda (x) (if (= (car x) 10) (setq vertlst (cons (cdr x) vertlst)))) (entget pol))
  16. (setq vertlst (reverse vertlst))
  17. (setq vertlstn (mapcar '(lambda (p) (transptiso p)) vertlst))
  18. (entmake
  19.    (append
  20.      (list
  21.        '(0 . "LWPOLYLINE")
  22.        '(100 . "AcDbEntity")
  23.        '(100 . "AcDbPolyline")
  24.        (cons 90 (length vertlstn))
  25.        '(70 . 1)
  26.      )
  27.      (mapcar '(lambda (x) (cons 10 x)) vertlstn)
  28.      (list (list 210 0.0 0.0 1.0))
  29.    )
  30. )
  31. (entdel pol)
  32. (vl-cmdf "_.ucs" "p")
  33. (princ)
  34. )

 
M、 R。
回复

使用道具 举报

pBe

32

主题

2722

帖子

2666

银币

后起之秀

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

铜币
211
发表于 2022-7-6 07:47:20 | 显示全部楼层
 
听起来很简单。
 
我不确定你需要的和我想要的是否一样。你能贴出想要结果的图片吗?
回复

使用道具 举报

17

主题

193

帖子

179

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
84
发表于 2022-7-6 07:49:58 | 显示全部楼层
嗨,M.R。
尝试使用你的例程,但我认为有一些错误,因为生成的多边形不是等距的
 
pBe,附图片
083143vmeyp3voj4lzmk3a.jpg
回复

使用道具 举报

5

主题

1334

帖子

1410

银币

限制会员

铜币
-20
发表于 2022-7-6 07:53:27 | 显示全部楼层
将极轴跟踪设置为45度,在执行例程的同时,使用“内接”选项创建角度为135度的6边多边形。。。你会得到你发布的内容-传统方式。。。我的代码绘制等距多边形-请参阅我附加的jpg。。。
 
M、 R。
083144j2hws6yc6hwszm7w.jpg
回复

使用道具 举报

pBe

32

主题

2722

帖子

2666

银币

后起之秀

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

铜币
211
发表于 2022-7-6 07:55:31 | 显示全部楼层
 
传统方法意味着存在等圆?
回复

使用道具 举报

114

主题

1万

帖子

1万

银币

中流砥柱

Rank: 25

铜币
543
发表于 2022-7-6 07:58:44 | 显示全部楼层
我认为“等轴测”不是描述OP希望获得的结果的正确术语,这可能会误导那些试图提供解决方案的人;也就是说,我不确定自己是否完全理解预期结果。
回复

使用道具 举报

pBe

32

主题

2722

帖子

2666

银币

后起之秀

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

铜币
211
发表于 2022-7-6 08:01:37 | 显示全部楼层
 
事实上,它确实显示了一个奇数形状的多边形,我试图根据第一篇文章中的描述编写代码(假设存在等圆)
 
  1. (defun  c:sample (/ objell sides seg seg2 pts)
  2. (vl-load-com)
  3. (setq objell  (car (entsel)))
  4. (setq sides (getint "\nEnter number of sides"))
  5. (setq  seg  (/ (vlax-curve-getdistatparam
  6.              objell
  7.              (vlax-curve-getendparam objell)
  8.              )
  9.            sides
  10.            ) seg2 0.0
  11.    )
  12. (repeat sides
  13.    (setq
  14.      pts
  15.       (cons (vlax-curve-getpointatdist objell (+ seg seg2)) pts)
  16.      )
  17.    (setq seg2 (+ seg seg2))
  18.    )
  19. (command "_Pline" "_non")
  20. (foreach pt (cons (last pts) pts) (command pt))
  21. (command)
  22. (entdel objell)
  23. (princ)
  24. )

 
我猜这个帖子和OP在另一个论坛上的帖子有关。创建面向上/左/右的等圆
 
http://www.theswamp.org/index.php?topic=42737.0
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-10 04:41 , Processed in 0.872483 second(s), 74 queries .

© 2020-2025 乐筑天下

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