找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 556|回复: 0

[每日一码] 获取REGION,3DSOLID的centroid的代码

[复制链接]

已领礼包: 20个

财富等级: 恭喜发财

发表于 2017-7-18 19:23:18 | 显示全部楼层 |阅读模式

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

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

×
  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豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-5-27 01:31 , Processed in 0.428569 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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