找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 活动 交友 discuz
查看: 212|回复: 0

点到直线的距离

[复制链接]

0

主题

0

回帖

26

积分

管理员

积分
26
发表于 2024-3-16 09:57:11 | 显示全部楼层 |阅读模式
  1. //点到直线的距离  
  2. public static double getDistanceByPointToLine采用笛卡尔坐标(Coordinate point, Coordinate pnt1, Coordinate pnt2)
  3.     {
  4.         double dis = 0;
  5.         if (pnt1.x == pnt2.x)
  6.         {
  7.             if (pnt1.y == pnt2.y)
  8.             {
  9.                 double dx = point.x - pnt1.x;
  10.                 double dy = point.y - pnt1.y;
  11.                 dis = Math.sqrt(dx * dx + dy * dy);
  12.             }
  13.             else
  14.                 dis = Math.abs(point.x - pnt1.x);
  15.         }
  16.         else
  17.         {
  18.             double lineK = (pnt2.y - pnt1.y) / (pnt2.x - pnt1.x);
  19.             double lineC = (pnt2.x * pnt1.y - pnt1.x * pnt2.y) / (pnt2.x - pnt1.x);
  20.             dis = Math.abs(lineK * point.x - point.y + lineC) / (Math.sqrt(lineK * lineK + 1));
  21.         }
  22.         //
  23.         return dis;
  24.     }
复制代码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|膜结构网

GMT+8, 2024-12-27 06:47 , Processed in 0.136654 second(s), 20 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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