明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2046|回复: 9

[讨论] 如何获得块中的圆的圆心?

[复制链接]
发表于 2011-3-3 08:49:08 | 显示全部楼层 |阅读模式
如果块中存在圆 ,如何获得块中的圆的圆心?
发表于 2011-3-3 09:38:06 | 显示全部楼层
选择块ss1->炸开ss1->ss2 (ssget "p")->过滤出圆->删除ss2->insert ss1
发表于 2011-3-3 10:50:55 | 显示全部楼层
本帖最后由 Gu_xl 于 2011-3-3 10:55 编辑

(setq cp (cdr (assoc 10 (entget (car (setq nel (nentsel "\n选择块中圆:")))))))
(setq cp (polar cp (angle '(0 0 0) (setq pt (cdr (assoc 10 (entget (last (last nel))))))) (distance  '(0 0 0) pt)))
发表于 2011-3-7 11:19:50 | 显示全部楼层
op--选择--在块中启用夹点,就可以了
发表于 2011-3-7 18:21:56 | 显示全部楼层
可适应任何UCS下的圆:
1、用(nentselp)取得:OCS圆心 pt(10组),坐标转换矩阵M,拉伸方向vo(210组)
2、将pt转换到块内“WCS”:(trans pt vo 0)
3、利用坐标转换矩阵M将块内“WCS”转换到块外WCS
4、根据需要转换到当前UCS
 楼主| 发表于 2011-3-8 19:38:20 | 显示全部楼层
到底怎么弄 需要直接可以用的代码
发表于 2011-3-8 23:42:42 | 显示全部楼层
思路:选中块,然后遍历块中子实体,如果是圆则取出并取其dxf列表,从而获得圆心坐标;如果含嵌套块,则需递归调用。
 楼主| 发表于 2011-3-11 20:00:38 | 显示全部楼层
如何遍历块中子实体
发表于 2011-3-13 14:49:42 | 显示全部楼层

  1. (defun c:cc()
  2.     (while (setq ent (nentsel "\nobj:"))
  3.        (setq dxf (entget (car ent))
  4.       nam (cdr (assoc 0 dxf))
  5.       po  (cdr (assoc 10 dxf))
  6.       x   (car  po)
  7.       y   (cadr po)
  8.       z   (last po)
  9.        )
  10.        (if (> (length ent) 2)
  11.            (setq mm  (caddr ent)
  12.           m0  (car mm)
  13.           m1  (nth 1 mm)
  14.           m2  (nth 2 mm)
  15.           m3  (last mm)
  16.           x   (+ (* (car po) (cadr m0)) (* (cadr po) (cadr m1)) (* (last po) (cadr m2)) (cadr m3))
  17.           y   (+ (* (car po) (car  m0)) (* (cadr po) (car  m1)) (* (last po) (car  m2)) (car  m3))
  18.           z   (+ (* (car po) (last m0)) (* (cadr po) (last m1)) (* (last po) (last m2)) (last  m3))
  19.     )
  20.        )
  21.        (princ (strcat "\n圆心坐标x=" (rtos x 2 4) "  y=" (rtos y 2 4) "  z=" (rtos z 2 4)))
  22.     )
  23.     (princ)
  24. )

发表于 2011-3-14 17:01:17 | 显示全部楼层
entnext+while
遍历
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2025-6-11 05:52 , Processed in 0.190779 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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