明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 2956|回复: 11

[VLisp]一点在两点之间?

  [复制链接]
发表于 2003-11-14 12:17:00 | 显示全部楼层 |阅读模式
请问:
若已知有四个(反正就是多于两个)点的坐标(二维还是三维不知),和一个点A的坐标。
求:这个点A在那四个点中的哪两个点所确定的连线上?(返回这两个点的坐标)
用VL,谢谢!
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2003-11-14 12:21:00 | 显示全部楼层
用圖解釋一下好嗎?
发表于 2003-11-14 13:20:00 | 显示全部楼层
看看这个函数:

  1. (defun Get(pt ptlist / ent entv ent2 entv2 n i j ptv ptx pt2x pts a b)
  2.   ;(setq ent (car (entsel)))
  3.   (command "_.line" '(0 0) '(1 1) "")
  4.   (setq ent (entlast))
  5.   (command "_.line" '(0 0) '(1 1) "")
  6.   (setq ent2 (entlast))
  7.   
  8.   (setq entv (vlax-ename->vla-object ent))
  9.   (setq entv2 (vlax-ename->vla-object ent2))
  10.   (setq i 0)
  11.   (setq ptv (vlax-3d-point pt))
  12.   (setq n (length ptlist))
  13.   (while (< i n)
  14.     (setq ptx (nth i ptlist))
  15.     (vla-put-startpoint entv (vlax-3d-point ptx))
  16.     (vla-put-startpoint entv2 ptv)
  17.     (setq j (1+ i))
  18.     (while (< j n)
  19.       (setq pt2x (nth j ptlist))
  20.       (vla-put-endpoint entv (vlax-3d-point pt2x))
  21.       (vla-put-endpoint entv2 (vlax-3d-point pt2x))
  22.       (setq a (vla-get-delta entv))
  23.       (setq a (vlax-safearray->list (vlax-variant-value a)))
  24.       (setq b (vla-get-delta entv2))
  25.       (setq b (vlax-safearray->list (vlax-variant-value b)))
  26.       (if (and (= (car a) 0) (= (cadr a) 0) (= (car b) 0) (= (cadr b) 0))
  27.         (progn (setq pts (list ptx pt2x)) (setq i n j n))
  28.         (progn
  29.           (if (and
  30.                 (/= (+ (car a) (cadr a)) 0)
  31.                 (/= (+ (car b) (cadr b)) 0)               
  32.                 (= (/ (caddr a) (sqrt (+ (* (car a) (car a)) (* (cadr a) (cadr a)))))
  33.                    (/ (caddr b) (sqrt (+ (* (car b) (car b)) (* (cadr b) (cadr b)))))
  34.                 )
  35.               )
  36.             (if (and (/= (car a) 0) (/= (car b) 0)
  37.                      (= (/ (cadr a) (car a)) (/ (cadr b) (car b)))
  38.                 )
  39.               (progn (setq pts (list ptx pt2x)) (setq i n j n))
  40.               (if (and (= (car a) 0) (= (car b) 0))
  41.                 (progn (setq pts (list ptx pt2x)) (setq i n j n))
  42.               )
  43.             );if
  44.           );if
  45.         );progn
  46.       );if
  47.       (setq j (1+ j))
  48.     );while
  49.     (setq i (1+ i))
  50.   );while
  51.   (entdel ent)
  52.   (entdel ent2)
  53.   pts
  54. )
 楼主| 发表于 2003-11-14 17:20:00 | 显示全部楼层

用vlax-curve-getClosestPointTo怎么用?

本帖子中包含更多资源

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

x
 楼主| 发表于 2003-11-17 12:09:00 | 显示全部楼层
飞哥,我用(get '(2.2248 25.1101) '((10 10) (15 20) (-10 30) (0 20)))运行上面的程序,但是返回的是nil???
另外,ptlist的长度是变化的话,好像上面的程序不对吧。我只是觉得,请别见怪!
发表于 2003-11-17 12:32:00 | 显示全部楼层
这个返回是正确的啊,你的那个点确实不在任何两点之间。

另,PTLIST长度变化是什么意思?你输入一个表后,这个表的长度还能变化?
 楼主| 发表于 2003-11-17 12:38:00 | 显示全部楼层
我的意思是:那个表的得来是由我们所选择的对象来确定的!比如,我们选择多段线,它的顶点数是随选择的多段线变化的。
发表于 2003-11-17 12:46:00 | 显示全部楼层
我只是提供了一个函数,函数的参数是一个点和一个由点组成的表,至于这个怎么来的,那是你的事情。原先你也并未有任何说明,
你作为一个开发者,应该明白提供一个函数和一个完整的程序有什么不同。函数是给你在写程序过程中调用的,而函数的使用条件应该是你去适应它,而不是要它适应你。比如说,你不能去要求(command "list"...)返回LIST命令显示的内容。。。
就本函数来说,获得多线段顶点,并将它做成一个列表并不是什么困难的事情,即使你改一下函数,在开头将其做成选择线段,然后组成点的列表,之后的内容照样运行,都是很容易的,为何还要问这个问题?
 楼主| 发表于 2003-11-17 12:49:00 | 显示全部楼层
受教了,谢谢飞哥!
 楼主| 发表于 2003-11-17 17:10:00 | 显示全部楼层
本帖最后由 作者 于 2003-11-17 17:36:50 编辑

飞哥,下面是我写的,请指教:
  1. (defun getTwoPts (pt0 ptList / ss0 i lastent ptEnd1 ptEnd2)
  2.     (setq var1 (getvar "osmode"))
  3.     (setvar "osmode" 0)
  4.     (setq i 0)
  5.     (repeat (- (length ptList) 1)
  6.       (vl-cmdf "line" (nth i ptList) (nth (+ 1 i) ptList) "")
  7.       (setq lastent (entlast))      
  8.       (if (equal (vlax-curve-getClosestPointTo
  9.                    (vlax-ename->vla-object lastent)
  10.                    pt0
  11.                  )
  12.                  pt0
  13.           )
  14.         (progn
  15.           (setq        ptEnd1 (nth i ptList)
  16.                 ptEnd2 (nth (+ 1 i) ptList)
  17.           )
  18.         )
  19.       )
  20.       (setq i (+ 1 i))
  21.       (vl-cmdf "ERASE" lastent "")
  22.     )
  23.     (setvar "osmode" var1)
  24.     (append (list ptEnd1) (list ptEnd2))
  25.   )



pt0要为3D点,ptlist的长度是变化也可用。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-10-2 10:41 , Processed in 0.184034 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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