乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 162|回复: 9

[VLisp]一点在两点之间?

[复制链接]

36

主题

201

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
345
发表于 2003-11-14 12:17:00 | 显示全部楼层 |阅读模式
请问:
若已知有四个(反正就是多于两个)点的坐标(二维还是三维不知),和一个点A的坐标。
求:这个点A在那四个点中的哪两个点所确定的连线上?(返回这两个点的坐标)
用VL,谢谢!
回复

使用道具 举报

29

主题

1152

帖子

10

银币

顶梁支柱

Rank: 50Rank: 50

铜币
1268
发表于 2003-11-14 12:21:00 | 显示全部楼层
用圖解釋一下好嗎?
回复

使用道具 举报

26

主题

3072

帖子

10

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3177
发表于 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 (list (vlax-variant-value a)))
  14.       (setq b (vla-get-delta entv2))
  15.       (setq b (vlax-safearray->list (vlax-variant-value b)))
  16.       (if (and (= (car a) 0) (= (cadr a) 0) (= (car b) 0) (= (cadr b) 0))
  17.         (progn (setq pts (list ptx pt2x)) (setq i n j n))
  18.         (progn
  19.           (if (and
  20.                 (/= (+ (car a) (cadr a)) 0)
  21.                 (/= (+ (car b) (cadr b)) 0)               
  22.                 (= (/ (caddr a) (sqrt (+ (* (car a) (car a)) (* (cadr a) (cadr a)))))
  23.                    (/ (caddr b) (sqrt (+ (* (car b) (car b)) (* (cadr b) (cadr b)))))
  24.                 )
  25.               )
  26.             (if (and (/= (car a) 0) (/= (car b) 0)
  27.                      (= (/ (cadr a) (car a)) (/ (cadr b) (car b)))
  28.                 )
  29.               (progn (setq pts (list ptx pt2x)) (setq i n j n))
  30.               (if (and (= (car a) 0) (= (car b) 0))
  31.                 (progn (setq pts (list ptx pt2x)) (setq i n j n))
  32.               )
  33.             );if
  34.           );if
  35.         );progn
  36.       );if
  37.       (setq j (1+ j))
  38.     );while
  39.     (setq i (1+ i))
  40.   );while
  41.   (entdel ent)
  42.   (entdel ent2)
  43.   pts
  44. )
回复

使用道具 举报

36

主题

201

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
345
发表于 2003-11-14 17:20:00 | 显示全部楼层

xtwubo4ppeo.jpg

xtwubo4ppeo.jpg


用vlax-curve-getClosestPointTo怎么用?
回复

使用道具 举报

36

主题

201

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
345
发表于 2003-11-17 12:09:00 | 显示全部楼层
飞哥,我用(get '(2.2248 25.1101) '((10 10) (15 20) (-10 30) (0 20)))运行上面的程序,但是返回的是nil???
另外,ptlist的长度是变化的话,好像上面的程序不对吧。我只是觉得,请别见怪!
回复

使用道具 举报

26

主题

3072

帖子

10

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3177
发表于 2003-11-17 12:32:00 | 显示全部楼层
这个返回是正确的啊,你的那个点确实不在任何两点之间。
另,PTLIST长度变化是什么意思?你输入一个表后,这个表的长度还能变化?
回复

使用道具 举报

36

主题

201

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
345
发表于 2003-11-17 12:38:00 | 显示全部楼层
我的意思是:那个表的得来是由我们所选择的对象来确定的!比如,我们选择多段线,它的顶点数是随选择的多段线变化的。
回复

使用道具 举报

26

主题

3072

帖子

10

银币

社区元老

Rank: 75Rank: 75Rank: 75

铜币
3177
发表于 2003-11-17 12:46:00 | 显示全部楼层
我只是提供了一个函数,函数的参数是一个点和一个由点组成的表,至于这个怎么来的,那是你的事情。原先你也并未有任何说明,
你作为一个开发者,应该明白提供一个函数和一个完整的程序有什么不同。函数是给你在写程序过程中调用的,而函数的使用条件应该是你去适应它,而不是要它适应你。比如说,你不能去要求(command "list"...)返回LIST命令显示的内容。。。
就本函数来说,获得多线段顶点,并将它做成一个列表并不是什么困难的事情,即使你改一下函数,在开头将其做成选择线段,然后组成点的列表,之后的内容照样运行,都是很容易的,为何还要问这个问题?
回复

使用道具 举报

36

主题

201

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
345
发表于 2003-11-17 12:49:00 | 显示全部楼层
受教了,谢谢飞哥!
回复

使用道具 举报

36

主题

201

帖子

8

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
345
发表于 2003-11-17 17:10:00 | 显示全部楼层

飞哥,下面是我写的,请指教:
  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的长度是变化也可用。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-7 01:16 , Processed in 1.437134 second(s), 75 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表