找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1097|回复: 1

用下面的函数得到的包围圈与ucs的X轴不平行?求解析

[复制链接]

已领礼包: 184个

财富等级: 日进斗金

发表于 2015-1-24 09:45:03 | 显示全部楼层 |阅读模式

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

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

×
本帖最后由 qq564837358 于 2015-1-24 09:48 编辑

;|
获得实体或者选择集在UCS下的实际包围盒
参数:
   ss --- 实体名 or 选择集
返回UCS下的对齐X轴的包围盒(UCS点)
|;
(defun XD::Entity:Box (ss / an box from mat mat0 pj r to)
  (xdrx_document_ucsoff)
  (setq box (xdrx_entity_box ss))
  (if (not (xdrx_document_iswcs))
    (progn
      (setq an         (XD::UCS:Angle)
            pj         (car box)
            mat0 (xdrx_matrix_identity 3)
            from (list pj
                       (getvar "ucsxdir")
                       (getvar "ucsydir")
                       (XD::UCS:ZDir)
                 )
            to         (list pj '(1 0 0) '(0 1 0) '(0 0 1))
            mat         (xdrx_matrix_AlignCoordSystem from to)
      )
      (xdrx_entity_transform ss Mat)
      (setq box (xdrx_entity_box ss))
      (xdrx_entity_transform
        ss
        (setq r (xdrx_matrix_inverse Mat))
      )
      (setq box (XD::Pnts:WCS2UCS (XD::Pnts:Transform box r)))
    )
  )
  box
)
;|
获得UCS的X轴夹角
参:无
返回值: 弧度
|;
(defun XD::UCS:Angle (/ an xdir)
  (setq        xDir (getvar "ucsxdir")
        an   (xdrx_vector_dotproduct xDir '(1.0 0.0 0.0))
        an   (atan (/ (sqrt (- 1 (* an an))) an))
  )
)
;|
点的矩阵变换
参数:
    pts ---- 点表
    mat ---- 变换矩阵
返回值: 点表
|;

(defun XD::Pnts:TransForm (pts mat)
  (mapcar '(lambda (x) (xdrx_point_transform x mat)) pts)
)

;|
点表从WCS变换到UCS
|;
(defun XD::Pnts:WCS2UCS (pts / mat)
  (setq mat (xdrx_matrix_wcs2ucs))
  (XD::Pnts:Transform pts mat)
)

;|
获得UCS的Z轴
参数:无
返回值:向量
|;
(defun XD::UCS:zDir()
  (xdrx_vector_crossProduct (getvar "ucsxdir") (getvar "ucsydir"))
)
(defun c:test (/ box)
  (start)
  (setq box (XD::Entity:Box (ssget)))
  (command "_.pline"
           (nth 0 box)
           (nth 1 box)
           (nth 2 box)
           (nth 3 box)
           "c"
  )
  (endover)
)
用得是晓东开源函数.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 40个

财富等级: 招财进宝

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-11-13 06:27 , Processed in 0.361708 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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