找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 742|回复: 5

[源码] 返回两曲线间最短距离

[复制链接]

已领礼包: 244个

财富等级: 日进斗金

发表于 2022-9-6 08:40:13 | 显示全部楼层 |阅读模式

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

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

×
本帖最后由 qxlonmsn 于 2022-9-9 08:01 编辑

(defun NearestDist (ent1 ent2 num fzz / pts dislst pt1 pt2 lst)
  (vl-load-com)
  (if (and
        (wcmatch "LINE,LWPOLYLINE,CIRCLE,ARC,HELIX,ELLIPSE,SPLINE,POLYLINE" (strcat "*" (cdr (assoc 0 (entget ent1))) "*"))
        (wcmatch "LINE,LWPOLYLINE,CIRCLE,ARC,HELIX,ELLIPSE,SPLINE,POLYLINE" (strcat "*" (cdr (assoc 0 (entget ent2))) "*"))
        (setq pts (GetPtsAtSptToEpt ent1 num (vlax-curve-getStartPoint ent1) (vlax-curve-getEndPoint ent1)));获取曲线ent1上的num个点
        (setq dislst (mapcar '(lambda (x) (distance (vlax-curve-getClosestPointTo (vlax-ename->vla-object ent2) x) x)) pts));距离列表
        (not (vl-every '(lambda (x) (equal x (car dislst) 0.001)) dislst));列表每个元素不相等==>两曲线不平行
      );两图元都是曲线
      (progn
          (setq pts (vl-sort pts
                      '(lambda (x y)
                         (< (distance (vlax-curve-getClosestPointTo (vlax-ename->vla-object ent2) x) x)
                            (distance (vlax-curve-getClosestPointTo (vlax-ename->vla-object ent2) y) y)
                         )
                       );end lambda
                    );end vl-sort
          );end setq
          (setq pt1 (car pts));最近点
          (setq pt2 (vlax-curve-getClosestPointTo (vlax-ename->vla-object ent2) pt1));pt1距离ent2上最近点
          (while (and
                   (setq pt3 (vlax-curve-getClosestPointTo (vlax-ename->vla-object ent1) pt2));pt2距离ent1上最近点
                   (not (equal pt1 pt3 fzz));两点不在公差内相等就循环
                 );end and
            (setq pt1 pt3)
            (setq pt2 (vlax-curve-getClosestPointTo (vlax-ename->vla-object ent2) pt1));更新pt2
          );end while
          (setq lst (list (distance pt1 pt2) pt1 pt2))
      );end progn
      (princ "\n2曲线平行!")
  );end if
)




;;返回曲线指定开始点到结束点指定数量的点
;;函数名称:  GetPtsAtSptToEpt
;;调用格式:        (GetPtsAtSptToEpt ent1 num spt ept)
;;参数说明:        
;;ent1 ----------- 图元名
;;num  ----------- 取点数
;;spt  ----------- 开始点
;;ept  ----------- 结束点
;;返回值:        点表
(defun GetPtsAtSptToEpt (ent1 num spt ept / pts n entobj dis num_b)
  (vl-load-com)
  (if (wcmatch "LINE,LWPOLYLINE,CIRCLE,ARC,HELIX,ELLIPSE,SPLINE,POLYLINE" (strcat "*" (cdr (assoc 0 (entget ent1))) "*"));图元是曲线
      (progn
        (setq pts '())
        (setq n 1)
        (setq entobj (vlax-ename->vla-object ent1));图元转vla对象
        (setq spt (vlax-curve-getClosestPointTo entobj spt))
        (setq ept (vlax-curve-getClosestPointTo entobj ept))
        (setq dis (-
                    (vlax-curve-getDistAtParam entobj (vlax-curve-getParamAtPoint entobj ept));结束点长度
                    (vlax-curve-getDistAtParam entobj (vlax-curve-getParamAtPoint entobj spt));开始点长度
                  )
        );获取区间总长度
        (setq num_b (/ dis (1+ num)));每份长度
        (repeat num
          (setq pts (cons (vlax-curve-getPointAtParam entobj (vlax-curve-getParamAtDist entobj (+ (vlax-curve-getDistAtPoint entobj spt) (* n num_b)) )) pts))
          (setq n (1+ n))
        );end repeat
        (setq pts (reverse pts));倒置
      );end progn
  );end if
)


;;(progn (setq oldosmode (getvar 'osmode)) (setvar 'osmode 16447) (command "_line" (cadr (setq lst (NearestDist (car (entsel)) (car (entsel)) 10 0.0001))) (caddr lst) "") (setvar 'osmode oldosmode) (setq lst nil oldosmode nil))
动画.gif
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 5601个

财富等级: 富甲天下

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

使用道具 举报

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

使用道具 举报

已领礼包: 4个

财富等级: 恭喜发财

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

使用道具 举报

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

使用道具 举报

已领礼包: 828个

财富等级: 财运亨通

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 13:05 , Processed in 0.346391 second(s), 41 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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