找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 3953|回复: 9

[多段线] 返回多段线自交点

[复制链接]

已领礼包: 7个

财富等级: 恭喜发财

发表于 2013-6-7 22:39:31 | 显示全部楼层 |阅读模式
函数发布
函数名称: GetAllSelfInters
调用格式: lsp
参数说明: Ename 多段线图元
返回值: 所有自交点的表
函数简介:
函数来源: 原创
函数作者: ayl1004
适用版本: 不限 
最后更新时间: 2013-06-08
备注:
演示图片: -

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

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

×
本帖最后由 ayl1004 于 2013-6-8 01:10 编辑


  1. ;;;把数组转换过来的表转成点表
  2. (defun GetPts (Lst)
  3.   (if (caddr Lst)
  4.     (cons
  5.       (list (car Lst) (cadr Lst) (caddr Lst))
  6.       (GetPts (cdddr Lst))
  7.     )
  8.   )
  9. )
  10. ;;;计算两个vla对象的交点
  11. (defun intersectPts (vlaobj1 vlaobj2 / ptsVar ptsArray ptsList)
  12.   (setq ptsVar  (vla-intersectwith vlaobj1 vlaobj2 acExtendNone)
  13. ptsArray (vlax-variant-value ptsVar)
  14. ptsList  (vl-catch-all-apply 'vlax-safeArray->list (list ptsArray))
  15.   )
  16.   (if (vl-catch-all-error-p ptsList)
  17.     nil
  18.     (GetPts ptsList)
  19.   )
  20. )
  21. ;;;移除多段线不是自交点的角点参量
  22. ;;;EndPrm 多段线终点参量
  23. ;;;Pline 多段线对象
  24. (defun RemoveParam (EndPrm Pline / SomPrm)
  25.   (cond ((= EndPrm 0) nil)
  26. ((= (setq SomPrm (vlax-curve-GetParamAtPoint
  27.       Pline
  28.       (vlax-curve-GetPointAtParam Pline EndPrm)
  29.     )
  30.      )
  31.      EndPrm
  32.   )
  33.   (RemoveParam (1- EndPrm) Pline)
  34. )
  35. ((/= SomPrm EndPrm)
  36.   (cons SomPrm (RemoveParam (1- EndPrm) Pline))
  37. )
  38.   )
  39. )
  40. ;;;多段线所有自交点
  41. (defun GetAllSelfInters (Ename / VlaObj PrmLst)
  42.   (setq VlaObj (vlax-ename->vla-object Ename))
  43.   (setq
  44.     PrmLst (append
  45.       ;;非角点自交
  46.       (vl-remove-if
  47.         (function (lambda (x) (= (fix x) x)))
  48.         (mapcar
  49.    (function
  50.      (lambda (x) (vlax-curve-GetParamAtPoint VlaObj x))
  51.    )
  52.    (intersectPts VlaObj VlaObj)
  53.         )
  54.       )
  55.       ;;角点自交
  56.       (RemoveParam (vlax-curve-GetEndParam VlaObj) VlaObj)
  57.     )
  58.   )
  59.   ;;所有自交点参量按从小到大排列,并转换成点
  60.   (mapcar (function (lambda (x) (vlax-curve-GetPointAtParam VlaObj x))
  61.    )
  62.    (vl-sort PrmLst '<)
  63.   )
  64. )


评分

参与人数 1D豆 +6 贡献 +1 收起 理由
XDSoft + 6 + 1 很给力!经验;技术要点;资料分享奖!

查看全部评分

论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2013-6-7 23:04:49 | 显示全部楼层
本帖最后由 Free-Lancer 于 2013-6-7 23:06 编辑

LZ这个帖子看起来太费劲了,发布有特殊的页面,把函数功能、参数意义、返回值、说明等等讲清楚,你再试试
另外,GetAllSelfInters 可以求得 Intersectwith 后和顶点数量比较,如果多了就是有自身交点,把那个多余的找出来即可

点评

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

使用道具 举报

已领礼包: 145个

财富等级: 日进斗金

发表于 2013-6-7 23:08:34 | 显示全部楼层
把函数整理下,能分出来的就分出来,发帖时候选第二个 “函数发布”,按提示发布就行了。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 7个

财富等级: 恭喜发财

 楼主| 发表于 2013-6-8 01:04:24 | 显示全部楼层
Free-Lancer 发表于 2013-6-7 23:04
LZ这个帖子看起来太费劲了,发布有特殊的页面,把函数功能、参数意义、返回值、说明等等讲清楚,你再试试
...

你没考虑角点是自交点

点评

找到所有的交点,判断下点是否在顶点表里面不在的,就是外面的交点。  详情 回复 发表于 2013-6-8 01:33
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 51个

财富等级: 招财进宝

发表于 2013-6-8 01:33:34 | 显示全部楼层
ayl1004 发表于 2013-6-8 01:04
你没考虑角点是自交点

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

使用道具 举报

发表于 2013-6-8 08:04:56 | 显示全部楼层
GetPts不用递归,写了一个啰嗦

  1. (defun GetPts (lst / lst1 lst2)
  2.   (repeat (/ (length lst) 3)
  3.     (setq lst1 nil)
  4.     (repeat 3
  5.       (setq lst1 (cons (car lst) lst1)
  6.             lst         (cdr lst)
  7.       )
  8.     )
  9.     (setq lst2 (cons (reverse lst1) lst2))
  10.   )
  11.   (reverse lst2)
  12. )

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

使用道具 举报

发表于 2013-6-9 05:35:14 来自手机 | 显示全部楼层
可以发布一个判断多段线是否自交函数来自: Android客户端
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 2476个

财富等级: 金玉满堂

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

使用道具 举报

发表于 2014-5-4 12:56:49 | 显示全部楼层
有个疑问,不知道对于"8"或者"日"这样形状的多线段,会不会判断不出它是自交?

点评

LZ很厉害,应该搞定了的,去年我搞了很久也没有搞定,原来他早就发布了。  详情 回复 发表于 2014-5-4 14:06
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 604个

财富等级: 财运亨通

发表于 2014-5-4 14:06:20 | 显示全部楼层
llsheng_73 发表于 2014-5-4 12:56
有个疑问,不知道对于"8"或者"日"这样形状的多线段,会不会判断不出它是自交?

LZ很厉害,应该搞定了的,去年我搞了很久也没有搞定,原来他早就发布了。{:soso_e109:}
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-4-25 13:20 , Processed in 0.287983 second(s), 55 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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