找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1373|回复: 3

[研讨] 是平行四边形时画中心线,其它封闭曲线在质心处画十字线

[复制链接]

已领礼包: 604个

财富等级: 财运亨通

发表于 2013-11-18 16:14:56 | 显示全部楼层 |阅读模式

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

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

×
本帖最后由 /db_自贡黄明儒_ 于 2013-11-18 16:17 编辑

  1. ;;是平行四边形时画中心线,其它封闭曲线在质心处画十字线
  2. (defun HH:CenMark (en / CEN LL LST OBJ OBJN P1 P2 PX1 PX2 PY1 PY2 R UR X Y)
  3.   ;;133.2 [功能] 缩放一个点
  4.   ;;scale 'pnt' from a base point of 'p1' by a factor of fact
  5.   (defun scale_pnt (pnt p1 fact /)
  6.     (polar p1 (angle p1 pnt) (* fact (distance p1 pnt)))
  7.   )

  8.   (if (and
  9.         (setq lst (entget en))
  10.         (setq lst (mapcar 'cdr
  11.                           (vl-remove-if-not '(lambda (x) (= (car x) 10)) lst)
  12.                   )
  13.         )
  14.         (equal (length lst) 4)
  15.         (not (inters (car lst) (cadr lst) (caddr lst) (cadddr lst) nil))
  16.         (not (inters (cadr lst) (caddr lst) (cadddr lst) (car lst) nil))
  17.       )
  18.     (progn
  19.       (setq cen (mapcar '(lambda (X Y) (/ (+ X Y) 2.0)) (car lst) (caddr lst)))
  20.       (setq p1 (mapcar '(lambda (X Y) (/ (+ X Y) 2.0)) (car lst) (cadddr lst)))
  21.       (setq p1 (scale_pnt p1 cen 1.25))
  22.       (setq p2 (mapcar '(lambda (X Y) (/ (+ X Y) 2.0)) (cadr lst) (caddr lst)))
  23.       (setq p2 (scale_pnt p2 cen 1.25))
  24.       (entmake (list (cons 0 "LINE") (cons 10 p1) (cons 11 p2)))
  25.       (setq p1 (mapcar '(lambda (X Y) (/ (+ X Y) 2.0)) (car lst) (cadr lst)))
  26.       (setq p1 (scale_pnt p1 cen 1.25))
  27.       (setq p2 (mapcar '(lambda (X Y) (/ (+ X Y) 2.0)) (caddr lst) (cadddr lst)))
  28.       (setq p2 (scale_pnt p2 cen 1.25))
  29.       (entmake (list (cons 0 "LINE") (cons 10 p1) (cons 11 p2)))
  30.     )
  31.     (progn
  32.       (setq obj (vlax-ename->vla-object en))
  33.       ;;(setq objN (vla-copy obj))
  34.       (or *DOC*
  35.           (setq *DOC* (vla-get-ActiveDocument (vlax-get-acad-object)))
  36.       )
  37.       (setq *MSP* (vla-get-Modelspace *DOC*))
  38.       (vlax-invoke *MSP* 'addregion (list obj))
  39.       (setq objN (vlax-ename->vla-object (entlast)))
  40.       (setq cen (vlax-safearray->list (vlax-variant-value (vla-get-Centroid objN))))
  41.       (vla-getboundingbox objN 'll 'ur)
  42.       (setq lst (mapcar 'vlax-safearray->list (list ll ur)))
  43.       (vla-delete objN)
  44.       (setq r (/ (distance (car lst) (cadr lst)) 2.0))
  45.       (setq px1 (mapcar '- cen (list r 0 0)))
  46.       (setq px2 (mapcar '+ cen (list r 0 0)))
  47.       (entmake (list (cons 0 "LINE") (cons 10 px1) (cons 11 px2)))
  48.       (setq py1 (mapcar '- cen (list 0 r 0)))
  49.       (setq py2 (mapcar '+ cen (list 0 r 0)))
  50.       (entmake (list (cons 0 "LINE") (cons 10 py1) (cons 11 py2)))
  51.     )
  52.   )
  53. )
  54. (defun C:W4 (/ EN)
  55.   (setq en (car (entsel)))
  56.   (HH:CenMark en)
  57.   (princ)
  58. )
1.gif
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-18 16:24:06 | 显示全部楼层
点集中心有数学算法,不用生成 Region

点评

不是点集,比如一个异型零件,如果知道质心,我们就知道吊钩放在什么地方合适  详情 回复 发表于 2013-11-18 16:27
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 604个

财富等级: 财运亨通

 楼主| 发表于 2013-11-18 16:27:54 | 显示全部楼层
st788796 发表于 2013-11-18 16:24
点集中心有数学算法,不用生成 Region

不是点集,比如一个异型零件,如果知道质心,我们就知道吊钩放在什么地方合适

点评

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

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2013-11-18 17:16:36 | 显示全部楼层
/db_自贡黄明儒_ 发表于 2013-11-18 16:27
不是点集,比如一个异型零件,如果知道质心,我们就知道吊钩放在什么地方合适

用API写了个
  1. (defun c:tt (/ ss)
  2.   (if (setq ss (ssget))
  3.     (progn
  4.       (xdrx_linetype_load "Center")
  5.       (mapcar
  6.         '(lambda (x / pts cen vl hl box an an1 an2 p1 p2 p3 p4 ln1)
  7.            (setq pts (xdrx_geom_searchoutline x)
  8.                  cen (apply 'xdrx_points_centroid pts)
  9.                  box (xdrx_entity_box x)
  10.                  vl  (* 0.7 (distance (nth 1 box) (nth 2 box)))
  11.                  hl  (* 0.7 (distance (car box) (cadr box)))
  12.            )
  13.            (if (and (= (length pts) 5)
  14.                     (setq an1 (angle (car pts) (cadr pts)))
  15.                     (setq an2 (angle (nth 3 pts) (nth 2 pts)))
  16.                     (equal (setq hl (distance (car pts) (nth 2 pts)))
  17.                            (distance (cadr pts) (nth 3 pts))
  18.                            1e-5
  19.                     )
  20.                     (equal an1 an2 1e-4)
  21.                )
  22.              (setq p1 (polar cen
  23.                              an2
  24.                              (setq
  25.                                hl (* 0.7 (distance (car pts) (cadr pts)))
  26.                              )
  27.                       )
  28.                    p2 (polar cen (+ an2 pi) hl)
  29.                    p3 (polar cen
  30.                              (setq an (+ an1 (/ pi 2)))
  31.                              (setq
  32.                                vl (* 0.7 (distance (car pts) (nth 3 pts)))
  33.                              )
  34.                       )
  35.                    p4 (polar cen (+ pi an) vl)
  36.              )
  37.              (setq p1 (polar cen pi hl)
  38.                    p2 (polar cen 0. hl)
  39.                    p3 (polar cen (/ pi 2) vl)
  40.                    p4 (polar cen (* pi 1.5) vl)
  41.              )
  42.            )
  43.            (setq ln1 (xdrx_line_make p1 p2))
  44.            (xdrx_entity_setlinetype ln1 "Center")
  45.            (setq ln1 (xdrx_line_make p3 p4))
  46.            (xdrx_entity_setlinetype ln1 "Center")
  47.          )
  48.         (xdrx_pickset->ents ss)
  49.       )
  50.     )
  51.   )
  52.   (princ)
  53. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-22 10:31 , Processed in 0.364553 second(s), 42 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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