找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 485|回复: 1

[点表] (XD::Geom:isCircle)判断SPLINE或者点表是否构成圆(CIRCLE)

[复制链接]

已领礼包: 51个

财富等级: 招财进宝

发表于 2017-8-25 19:38:57 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Geom:isCircle
调用格式: (XD::Geom:isCircle pts fuzz)
参数说明: pts ---- spline实体名或点表
fuzz --- 精度值
返回值: (圆心 半径) 或 nil
函数简介: 判断SPLINE或者点表是否构成圆(CIRCLE)
函数来源: 原创
函数作者: Lispboy
适用版本: XDRX API 
最后更新时间: 2017-08-25
备注: -
演示图片:

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

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

×
  1. (defun xd::Geom:iscircle (pts fuzz / #center #radius area1 c1 cen1 cen2 g r1
  2.                               ret
  3.                          )
  4.   (if (and
  5.         (= (type pts) 'ENAME)
  6.         (= (cdr (assoc 0 (entget pts))) "SPLINE")
  7.       )
  8.     (progn
  9.       (setq pts (xdrx_getsamplept pts 5)
  10.               pts (list (nth 1 pts) (nth 2 pts) (nth 3 pts))
  11.         )
  12.     )
  13.     (progn
  14.       (setq pts (xd::list:removedup pts))
  15.       (if (< (length pts) 5)
  16.         (setq pts nil)
  17.       )
  18.     )
  19.   )
  20.   (and
  21.     (setq c1 (xdrx_points_mincircle pts))
  22.     (setq r1 (cadr c1))
  23.     (setq cen1 (car c1))
  24.     (setq area1 (* pi r1 r1))
  25.     (setq g (xdge::constructor "kcircarc3d"))
  26.     (xdge::setpropertyvalue g "set" (nth 0 pts) (nth (fix (/
  27.                                                              (length pts)
  28.                                                              2.0
  29.                                                           )
  30.                                                      ) pts
  31.                                                 ) (last pts)
  32.     )
  33.     (xdge::getpropertyvalue g "center" "radius" "area")
  34.     (equal cen1 #center fuzz)
  35.     (equal r1 #radius fuzz)
  36.     (setq ret (list cen2 #radius))
  37.   )
  38.   (xdge::free g)
  39.   ret
  40. )


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

已领礼包: 769个

财富等级: 财运亨通

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-3-29 08:57 , Processed in 0.292830 second(s), 34 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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