找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 3090|回复: 4

判断点是否在多边形内的函数

[复制链接]

已领礼包: 51个

财富等级: 招财进宝

发表于 2013-4-30 22:49:58 | 显示全部楼层 |阅读模式

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

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

×
借鉴下老大上面发的论文,论文链接:关于点与简单多边形位置关系的一种算法
给大家写个测试点是否在多边形内的代码,
程序中用到了高飞鸟斑竹的矩阵函数。
用的是射线法。

[pcode=lisp,true]
;;;-----------------------------------------------------------;;
;;; 向量乘标量(系数)                                              ;;
;;; Vector x Scalar - Lee Mac                                      ;;
;;; Args: v - vector in R^n, s - real scalar                      ;;
;;;-----------------------------------------------------------;;
(defun MAT:vxs ( v s )
  (mapcar (function (lambda ( n ) (* n s))) v)
)
(defun GEO:Centroid (Pts / )
  (MAT:vxs (apply 'mapcar (cons '+ pts)) (/ 1.0 (length pts)))
)
;| 参数
   pts:多边形顶点集
   testpoint:测试点
   返回:T(内)NIL(外)
|;
(defun Points:PntIsIn (pts testpoint / centroid i_cnt item p_1 p_2 tmp vp1 x)
  (setq i_cnt nil
        centroid (geo:centroid pts)
        vp1 3e10
        tmp (angle testpoint centroid)
        vp1 (polar testpoint tmp vp1)
        i_cnt nil
  )

  (while (cdr pts)
    (setq p_1 (car pts)
          p_2 (cadr pts)
    )
    (if (setq tmp (inters
                    testpoint
                    vp1
                    p_1
                    p_2
                    't
                  )
        )
      (setq i_cnt (cons tmp i_cnt))
    )
    (setq pts (cdr pts))
  )
  (if i_cnt
    (progn
      (setq tmp (list (car i_cnt)))
      (foreach item (cdr i_cnt)
        (if (apply
              'and
              (mapcar
                '(lambda (x)
                   (not (equal x item 0.001))
                 )
                tmp
              )
            )
          (setq tmp (cons item tmp))
        )
      )
      (setq i_cnt tmp)
    )
  )
  (if (zerop (rem (length i_cnt) 2))
    nil
    t
  )
)
[/pcode]

本帖被以下淘专辑推荐:

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

已领礼包: 1632个

财富等级: 堆金积玉

发表于 2013-5-1 09:25:48 | 显示全部楼层
本帖最后由 ScmTools 于 2013-5-1 16:49 编辑

建议LZ将此贴也发到“LISP/VLISP函数库”板块中, 这里还有另中方法: http://www.xdcad.net/forum/thread-667705-1-1.html
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 305个

财富等级: 日进斗金

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

使用道具 举报

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

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 01:58 , Processed in 0.189794 second(s), 43 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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