找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 746|回复: 2

[每日一码] 求SOLID,REGION的形心

[复制链接]

已领礼包: 20个

财富等级: 恭喜发财

发表于 2018-12-7 11:13:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
  1. (defun c:centroid ( / v^v unit ucs x y ss ent enta n p )
  2. (vl-load-com)
  3. (defun v^v ( u v )
  4.    (mapcar '(lambda ( s1 s2 a b ) (+ ((eval s1) (* (nth a u) (nth b v))) ((eval s2) (* (nth a v) (nth b u))))) '(+ - +) '(- + -) '(1 0 0) '(2 2 1))
  5. )
  6. (defun unit ( v )
  7.    (mapcar '(lambda ( x ) (/ x (distance '(0.0 0.0 0.0) v))) v)
  8. )
  9. (if (/= (getvar 'worlducs) 1)
  10.    (command "_.ucs" "_w")
  11. )
  12. (setq ss (ssget "_+.:E:S" '((0 . "3DSOLID,REGION"))))
  13. (setq ent (ssname ss 0))
  14. (setq enta (vlax-ename->vla-object ent))
  15. (if
  16.    (eq (cdr (assoc 0 (entget ent))) "REGION")
  17.    (progn
  18.      (setq n (vlax-safearray->list (vlax-variant-value (vla-get-normal enta))))
  19.      (if (equal (v^v n '(0.0 0.0 1.0)) '(0.0 0.0 0.0) 1e-6)
  20.        (setq x '(1.0 0.0 0.0) y '(0.0 1.0 0.0))
  21.        (setq x (unit (v^v n '(0.0 0.0 1.0))) y (unit (v^v n x)))
  22.      )
  23.      (command "_.explode" ent)
  24.      (while
  25.        (> (getvar 'cmdactive) 0)
  26.        (command "")
  27.      )
  28.      (setq p (vlax-curve-getstartpoint (entlast)))
  29.      (command "_.undo")
  30.      (while
  31.        (> (getvar 'cmdactive) 0)
  32.        (command "")
  33.      )
  34.      (setq ucs (vla-add (vla-get-usercoordinatesystems (vla-get-activedocument (vlax-get-acad-object))) (vlax-3d-point p) (vlax-3d-point (mapcar '+ p x)) (vlax-3d-point (mapcar '+ p y)) "{ UCS }"))
  35.      (vla-put-activeucs (vla-get-activedocument (vlax-get-acad-object)) ucs)
  36.      (command "_.UCS" "_D" "{ UCS }")
  37.      (vlax-release-object ucs)
  38.      (setq cent (trans (vlax-safearray->list (vlax-variant-value (vla-get-centroid enta))) 1 0))
  39.      (command "_.ucs" "_p")
  40.    )
  41.    (setq cent (vlax-safearray->list (vlax-variant-value (vla-get-centroid enta))))
  42. )
  43. (prompt "\nCentroid : ") (princ cent)
  44. (prompt "\nVariable is called \"cent\" - you call it with !cent")
  45. (princ)
  46. )


论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 6056个

财富等级: 富甲天下

发表于 2018-12-8 16:34:57 | 显示全部楼层
沙发支持。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复

使用道具 举报

已领礼包: 1个

财富等级: 恭喜发财

发表于 2020-11-12 20:33:38 | 显示全部楼层
沙发支持。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-15 04:02 , Processed in 0.191164 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表