找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 645|回复: 0

[点表] (XD::Pnts:Extremum)求点表的极值点

[复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2018-3-27 01:08:50 | 显示全部楼层 |阅读模式
函数发布
函数名称: XD::Pnts:Extremum
调用格式: (XD::Pnts:Extremum pts xoper yoper mode)
参数说明: pts ----- 点表
xoper -- X方向排序操作符('> '>= '< '<=)
yoper -- Y方向排序操作符('> '>= '< '<=)
mode -- T(先排Y) , NIL(先排X)
返回值:
函数简介: 根据参数,求点表的
1、Y最大里面,X最大
2、Y最大里面,X最小
3、X最大里面,Y最小
4、X最大里面,Y最大
函数来源: 原创
函数作者: newer
适用版本: XDRX API 
最后更新时间: 2018-03-27
备注: -
演示图片: -

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

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

×
  1. (defun XD::Pnts:Extremum (pts xoper yoper mode / box gx gy x y)
  2.   (setq box (xdrx_points_box pts)
  3.         gy (xdge::constructor "kLineseg3d" (car box) (cadr box))
  4.         gx (xdge::constructor "kLineseg3d" (car box) (last box))
  5.   )
  6.   (setq pts (cdar (vl-sort (xd::list:groupbyindex (mapcar
  7.                                                     '(lambda (x)
  8.                                                        (list
  9.                                                           (xdge::getpropertyvalue (if mode gy gx) "distanceto" x)
  10.                                                           x
  11.                                                        )
  12.                                                      )
  13.                                                     pts
  14.                                                   ) 1e-3
  15.                            ) '(lambda (x y)
  16.                                 (if mode
  17.                                   (apply yoper (list (car x) (car y)))
  18.                                   (apply xoper (list (car x) (car y)))
  19.                                 )
  20.                               )
  21.                   )
  22.             )
  23.   )
  24.   (setq pts (mapcar
  25.               'cadr
  26.               (vl-sort (xd::list:groupbyindex (mapcar
  27.                                                 '(lambda (x)
  28.                                                    (list
  29.                                                           (xdge::getpropertyvalue (if mode gx gy) "distanceto" x)
  30.                                                           x
  31.                                                        )
  32.                                                  )
  33.                                                 pts
  34.                                               ) 1e-3
  35.                        ) '(lambda (x y)
  36.                                 (if mode
  37.                                   (apply xoper (list (car x) (car y)))
  38.                                   (apply yoper (list (car x) (car y)))
  39.                                 )
  40.                               )
  41.               )
  42.             )
  43.   )
  44.   (xdge::free gx gy)
  45.   (car pts)
  46. )


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

本版积分规则

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

GMT+8, 2024-4-20 10:24 , Processed in 0.207324 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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