找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 810|回复: 10

[求助] [求助]:谁能给一个求点到直线的垂点的代码

[复制链接]

已领礼包: 488个

财富等级: 日进斗金

发表于 2003-8-5 15:59:32 | 显示全部楼层 |阅读模式

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

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

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

  1.   [FONT=courier new]
  2. ;垂足:点到线
  3. (defun chengs_getpoint_per (p0 p1 p2 / r12 p3)
  4.   (setq
  5.            r12 (angle p1 p2)
  6.            r0 (+ r12 (/ pi 2))
  7.            p3 (polar p0 r0 1.0)
  8.   )
  9.   (inters p1 p2 p0 p3 nil)
  10. )
  11. ;垂足2:线上点p0,线点p1 p2;w垂足距线长度
  12. (defun chengs_getpoint_per2 (p0 p1 p2 w / r12 p3)
  13.   (setq
  14.            r12 (angle p1 p2)
  15.            r0 (+ r12 (/ pi 2))
  16.            p3 (polar p0 r0 w)
  17.   )
  18. )
  19. ;垂足3:点->线
  20. (defun chengs_getpoint_per3 (p0 ln1 / p1 p2  ln1_list r12 p3)
  21.   (if (cdr ln1) (setq ln1 (car ln1)))
  22.   (setq ln1_list (entget ln1))
  23.   (setq p1 (cdr (assoc 10 ln1_list)))
  24.   (setq p2 (cdr (assoc 11 ln1_list)))
  25.   (setq
  26.            r12 (angle p1 p2)
  27.            r0 (+ r12 (/ pi 2))
  28.            p3 (polar p0 r0 1.0)
  29.   )
  30.   (inters p1 p2 p0 p3 nil)
  31. )
  32. [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 488个

财富等级: 日进斗金

 楼主| 发表于 2003-8-5 19:06:31 | 显示全部楼层
最初由 libo2000 发布
[B]
  
;垂足:点到线
(defun chengs_getpoint_per (p0 p1 p2 / r12 p3)
  (setq
           r12 (angle p1 p2)
           r0 (+ r12 (/ pi 2))
           p3 (polar p0 r0 1.0)
  )
  (inters p1... [/B]


inters,谁都会想到的.

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

使用道具 举报

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

使用道具 举报

发表于 2003-8-5 22:24:20 | 显示全部楼层
(setq a (distance p1 p2))
(setq b (distance p0 p1))
(setq c (distance p0 p2))
(setq cosang (/ (- (+ (* a a)(* b b))(* c c))(* 2 a b)))
(setq l (* b cosang))
(setq pt-per (polar p1 (angle p1 p2) l))

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

使用道具 举报

发表于 2003-8-5 22:37:16 | 显示全部楼层
不用那么复杂,根据三条边长计算面积(由数学公式)
在用标准三角形面积计算方法算:高
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 488个

财富等级: 日进斗金

 楼主| 发表于 2003-8-6 00:05:51 | 显示全部楼层
好象谁也逃不掉 inters distance polar ,都不能用,就数学公式可用

比如求p1(x1 y1) p2(x2 y2)的距离: (sqrt (+ (* (- x2 x1)(- x2 x1))(*(- y2 y1)(- y2 y1))))
就要这种方法.
举个例子:
晓东贴过的,求三角形面积:

  1. (defun tarea (p1 p2 p3)
  2.   (- (+ (* (car p1) (cadr p2)) (* (car p2) (cadr p3)) (* (car p3)
  3.                              (cadr p1)
  4.                               )
  5.     ) (* (car p1) (cadr p3)) (* (car p2) (cadr p1)) (* (car p3)
  6.                             (cadr p2)
  7.                             )
  8.   )
  9. )
(可能要除于2 .)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 593个

财富等级: 财运亨通

发表于 2003-8-6 07:37:42 | 显示全部楼层

  1. ;;; 返回点到直线距离
  2. ;;;返回值:点到直线的距离,点在线段的左(上)侧为负值, 在右(下)侧为正值。;
  3. ;;;方向根据给定的起始点和终止点定。
  4. ;;; Request distance from a point(p0) to a line(p1 p2).
  5. (defun pntoln (p0 p1 p2 / x1 y1 x2 y2 c1 c2 c3)
  6.   (setq        x1 (car p1)
  7.         y1 (cadr p1)
  8.         x2 (car p2)
  9.         y2 (cadr p2)
  10.         c1 (- y2 y1)
  11.         c2 (- x1 x2)
  12.         c3 (- (* x2 y1) (* x1 y2))
  13.   )
  14.   (/ (+ (* c1 (car p0)) (* c2 (cadr p0)) c3)
  15.      (sqrt (+ (* c1 c1) (* c2 c2)))
  16.   )
  17. )
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 488个

财富等级: 日进斗金

 楼主| 发表于 2003-8-6 22:47:27 | 显示全部楼层
最初由 eachy 发布
[B]
;;; 返回点到直线距离
;;;返回值:点到直线的距离,点在线段的左(上)侧为负值, 在右(下)侧为正值。;
;;;方向根据给定的起始点和终止点定。
;;; Request distance from a point(p0) to a line(p1 p2).
(d... [/B]


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

使用道具 举报

发表于 2003-8-7 20:54:33 | 显示全部楼层
能说一下为什么不用INTERS等函数,有什么特别的意义吗?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1个

财富等级: 恭喜发财

发表于 2003-8-13 13:32:49 | 显示全部楼层
;;;===============================
;;;(ppt ptt1 ptt2 ptt3)返回点pt1至直线pt2 pt3的垂点坐标
(defun ppt (ptt1 ptt2 ptt3 / pt osmode_old angtmp)
  (if (/= (getvar "osmode") 0)
    (progn (setq osmode_old (getvar "osmode"))
           (setvar "osmode" 0)
    )
  )
  (setq angtmp (-(angle ptt2 ptt1)(angle ptt2 ptt3)))
  (if (> angtmp pi)
    (setq angtmp (- (* pi 2) angtmp))
  )

  (if (> angtmp (/ pi 2))
    (setq pt (polar ptt2
                    (+ (angle ptt2 ptt3) pi)
                    (sqrt (- (^ (distance ptt1 ptt2) 2)
                             (^ (sort ptt1 ptt2 ptt3) 2)
                          )
                    )
             )
    )
    (setq pt (polar ptt2
                    (angle ptt2 ptt3)
                    (sqrt (- (^ (distance ptt1 ptt2) 2)
                             (^ (sort ptt1 ptt2 ptt3) 2)
                          )
                    )
             )
    )
  )
  (if osmode_old
    (setvar "osmode" osmode_old)
  )
  pt
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-26 19:03 , Processed in 0.424976 second(s), 53 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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