找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 634|回复: 1

[实体] (XD::Ellipse:isArc)判断SPLINE,椭圆是否是ARC

[复制链接]

已领礼包: 20个

财富等级: 恭喜发财

发表于 2020-4-20 10:13:37 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Geom:isArc
调用格式: (XD::Geom:isArc e tol)
参数说明: e ----- 实体名 or 几何实体名
tol ----- 精度数值
返回值:
(时针方向 (圆心 半径 起始角 终止角) (起点 中间点 终点))

nil
函数简介: 判断SPLINE,椭圆是否是ARC
函数来源: 原创
函数作者:
适用版本: XDRX API 
最后更新时间: 2020-04-20
备注: -
演示图片: -

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

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

×
本帖最后由 marting 于 2020-4-20 23:42 编辑

使用了XDRX API的几何库函数,用SPLINE,椭圆的面积和转换成弧线的几何模型面积是否在精度内相等判断。

  1. (defun XD::Geom:isArc (e tol / pts ge info)
  2.   (if (and (= (type e) 'ename)
  3.            (or (= (strcase (car (xdrx-getpropertyvalue e "classname")))
  4.                   "ELLIPSE"
  5.                )
  6.                (= (strcase (car (xdrx-getpropertyvalue e "classname")))
  7.                   "SPLINE"
  8.                )
  9.            )
  10.            (setq pts (xdrx_getsamplept e))
  11.            (not (equal (car pts) (last pts) tol))
  12.            (setq ar1 (xdrx-getpropertyvalue e "area"))
  13.            (setq pts (xdrx_getsamplept e))
  14.            (and        (setq ge (xdge::constructor
  15.                            "kcircarc3d"
  16.                            (car pts)
  17.                            (cadr pts)
  18.                            (last pts)
  19.                          )
  20.                 )
  21.                 (setq ar2 (xdrx-getpropertyvalue ge "area"))
  22.                 (setq info (list (xd::pnts:isclockwise pts)
  23.                                  (xdrx-getpropertyvalue
  24.                                    ge                 "center"
  25.                                    "radius"         "startangle"
  26.                                    "endangle"
  27.                                   )
  28.                                  (list (car pts) (cadr pts) (last pts))
  29.                            )
  30.                 )
  31.                 (xdge::free ge)
  32.            )
  33.            (equal (/ (abs (- ar1 ar2)) ar1) 0.0 tol)
  34.       )
  35.     info
  36.   )
  37. )


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

已领礼包: 272个

财富等级: 日进斗金

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-24 07:10 , Processed in 0.188608 second(s), 33 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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