找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1674|回复: 4

[LISP函数]判断点pt2相对于点pt1的位置

[复制链接]

已领礼包: 2个

财富等级: 恭喜发财

发表于 2013-8-16 09:00:44 | 显示全部楼层 |阅读模式

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

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

×
  1. ;判断点pt2相对于点pt1的位置  by PEACE 2013/05/28
  2. ;以pt1为中心,画横竖坐标系,pt2在第一象限时返回1,以此类推分别返回2,3,4
  3. (defun PEACE:Position2Point(pt1 pt2 / symbol)
  4.   (if (and (>= (car pt2) (car pt1)) (>= (cadr pt2) (cadr pt1)))
  5.     (setq symbol 1)
  6.     (if (and (< (car pt2) (car pt1)) (>= (cadr pt2) (cadr pt1)))
  7.       (setq symbol 2)
  8.       (if (and (< (car pt2) (car pt1)) (< (cadr pt2) (cadr pt1)))
  9.         (setq symbol 3)
  10.         (setq symbol 4)
  11.       )
  12.     )
  13.   )
  14.   symbol
  15. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!

已领礼包: 862个

财富等级: 财运亨通

发表于 2013-8-16 09:08:22 | 显示全部楼层
有个还有两个点重合这种情况~~~~~~~~~~~~~~~~~~~~~~~~~~

点评

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

使用道具 举报

已领礼包: 2个

财富等级: 恭喜发财

 楼主| 发表于 2013-8-16 12:57:21 | 显示全部楼层
zhangq_cai1 发表于 2013-8-16 09:08
有个还有两个点重合这种情况~~~~~~~~~~~~~~~~~~~~~~~~~~

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

使用道具 举报

已领礼包: 3256个

财富等级: 富可敌国

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

使用道具 举报

发表于 2013-8-16 15:24:00 | 显示全部楼层
本帖最后由 Free-Lancer 于 2013-8-16 18:40 编辑

用 Angle 判断不是更好?
  1. (defun P2p (p1 p2 / an)
  2.   (if (not (equal p1 p2 1e-9))
  3.     (progn
  4.       (setq an (angle p1 p2))
  5.       (cond
  6. ((and (<= 0. an)
  7.        (< an (/ pi 2))
  8.   )
  9.   1
  10. )
  11. ((and (> an (/ pi 2))
  12.        (<= an pi)
  13.   )
  14.   2
  15. )
  16. ((and (> an pi)
  17.        (<= an (* 1.5 pi))
  18.   )
  19.   3
  20. )
  21. (t 4)
  22.       )
  23.     )
  24.     nil
  25.   )  
  26. )

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-25 02:08 , Processed in 0.211846 second(s), 40 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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