乐筑天下

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

[编程交流] 3dpoly-距离-perp。。。。。

[复制链接]

28

主题

76

帖子

48

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
140
发表于 2022-7-6 12:07:47 | 显示全部楼层 |阅读模式
大家好,
在从点到三维多边形绘制垂直线之后,我必须测量连续交点三维多边形-垂直线之间的距离。Lisp程序这样做会帮我很多。。。见附件-图纸。谢谢
3dpoly-dist.dwg
回复

使用道具 举报

106

主题

1万

帖子

101

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1299
发表于 2022-7-6 13:04:00 | 显示全部楼层
给这些线,而不是普林斯尝试工作
 
  1. [size=2]; offset perpendicular to line
  2. (defun c:p2p ()
  3. (setq tp1 (entsel "\nSelect line near end : "))
  4. (setq tpp1 (entget (car tp1)))
  5. (setq pt1 (cdr (assoc 10 tpp1)))
  6. (setq pt1 (list (car pt1) (cadr pt1) 0.0)) ;reset z to zero
  7. (setq pt2 (cdr (assoc 11 tpp1)))
  8. (setq pt2 (list (car pt2) (cadr pt2) 0.0)) ;reset z to zero
  9. (setq pt3 (cadr tp1))
  10. (setq d1 (distance pt1 pt3))
  11. (setq d2 (distance pt2 pt3))
  12. (if (> d1 d2)
  13. (progn
  14. (setq temp pt1)
  15. (setq pt1 pt2)
  16. (setq pt2 temp)
  17. )
  18. )
  19. (setq ang (angle pt1 pt2)
  20. )
  21. (setq pt4 (getpoint "\nSelect point"))
  22. (setq pt4 (list (car pt4) (cadr pt4) 0.0)) ;reset z to zero
  23. (setq ang2 (angle pt1 pt4))
  24. (setq dist2 (distance pt1 pt4))
  25. (setq angdiff (- ang ang2))
  26. (setq sidel (distance pt1 pt4))
  27. (setq offset (abs(* sidel (sin angdiff))))
  28. (setq offsetdist (rtos offset 2 3))
  29. (setq fromdist (sqrt (- (* dist2 dist2)(* offset offset))))
  30. (setq fromdist2 (rtos fromdist 2 3))
  31. (setq pt5 (polar pt1 ang fromdist))
  32. (setq remainder (- (distance pt1 pt2)(distance pt1 pt5)))
  33. (setq remain (rtos remainder 2 3))
  34. (setq messg1 "The offset is ")
  35. (setq messg2 " distance is ")
  36. (setq messg3 " remainder is ")
  37. (setq displayans (strcat messg1 offsetdist messg2 fromdist2 messg3 remain))
  38. (princ "\n")
  39. (princ displayans)
  40. (setq pt1 nil)
  41. (setq pt2 nil)
  42. (setq pt3 nil)
  43. (setq pt4 nil)
  44. (Princ)
  45. ) ;end defun
  46. [/size]

 
 
  1. [size=2]
  2. ; offset perpendicular to line
  3. (defun c:p2pp ()
  4. (setq pt1 (getpoint "\nSelect point 1 "))
  5. (setq pt1 (list (car pt1) (cadr pt1) 0.0)) ;reset z to zero
  6. (setq pt2 (getpoint "\nSelect point 2 "))
  7. (setq pt2 (list (car pt2) (cadr pt2) 0.0)) ;reset z to zero
  8. (setq ang (angle pt1 pt2))
  9. (setq pt4 (getpoint "\nSelect offset point "))
  10. (setq pt4 (list (car pt4) (cadr pt4) 0.0)) ;reset z to zero
  11. (setq ang2 (angle pt1 pt4))
  12. (setq dist2 (distance pt1 pt4))
  13. (setq angdiff (- ang ang2))
  14. (setq sidel (distance pt1 pt4))
  15. (setq offset (abs(* sidel (sin angdiff))))
  16. (setq offsetdist (rtos offset 2 3))
  17. (setq fromdist (sqrt (- (* dist2 dist2)(* offset offset))))
  18. (setq fromdist2 (rtos fromdist 2 3))
  19. (setq pt5 (polar pt1 ang fromdist))
  20. (setq remainder (- (distance pt1 pt2)(distance pt1 pt5)))
  21. (setq remain (rtos remainder 2 3))
  22. (setq messg1 "The offset is ")
  23. (setq messg2 " distance is ")
  24. (setq messg3 " remainder is ")
  25. (setq displayans (strcat messg1 offsetdist messg2 fromdist2 messg3 remain))
  26. (princ "\n")
  27. (princ displayans)
  28. (setq pt1 nil)
  29. (setq pt2 nil)
  30. (setq pt3 nil)
  31. (setq pt4 nil)
  32. (Princ)
  33. ) ;end defun
  34. [/size]
回复

使用道具 举报

0

主题

269

帖子

279

银币

限制会员

铜币
-4
发表于 2022-7-6 13:17:00 | 显示全部楼层
嘿,弗洛波,
 
检查你关于这个主题的其他线程CAB发布了一个例程,完全符合你的要求,尽我所能。。。
 
**编辑,只是好奇,为什么当它是Z=0的LWDOLYLINE时,会将其称为3dpoly?
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-5 10:16 , Processed in 0.312316 second(s), 58 queries .

© 2020-2025 乐筑天下

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