已知直线终点与起点坐标 怎么两点距离

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了已知直线终点与起点坐标 怎么两点距离相关的知识,希望对你有一定的参考价值。

参考技术A 可以使用两点间距离公式来求。已知两点坐标(x1,x2)和(y1,y2),计算两点之间距离的方法:
(y2-y1)²+(x2-x1)²=d²
d=√[(x2-x1)²+(y2-y1)²]
假如:点坐标分别是(1,3)和(4,7),
那么距离d=√[(4-1)²+(7-3)²]=5

两点间距离公式:
两点间距离公式常用于函数图形内求两点之间距离、求点的坐标的基本公式,是距离公式之一。两点间距离公式叙述了点的坐标和点之间距离的关系。

Scala实现:已知三点坐标,求最短距离(如果在垂足不在线段内,最短距离为到其中一点的直线距离)



/**
* 已知三点坐标,求其中一点到另两点的垂线距离
* (如果在垂足不在线段内,最短距离为到其中一点的直线距离)
* Created by wzq on 17-11-2.
*/
object Point2lineDistance {
def main(args: Array[String]) {
val v: Double = pointToLine(-3, 0, 3, 0, 0, 3)
System.out.println(v)
}

def pointToLine(x1: Int, y1: Int, x2: Int, y2: Int, x0: Int, y0: Int): Double = {
var space: Double = 0
var a: Double = .0
var b: Double = .0
var c: Double = .0
a = lineSpace(x1, y1, x2, y2) // 线段的长度
b = lineSpace(x1, y1, x0, y0) // (x1,y1)到点的距离
c = lineSpace(x2, y2, x0, y0) // (x2,y2)到点的距离
if (c <= 0.000001 || b <= 0.000001) {
space = 0
return space
}
if (a <= 0.000001) {
space = b
return space
}
//钝角三角形的最小边长
if (c * c >= a * a + b * b) {
space = b
return space
}
if (b * b >= a * a + c * c) {
space = c
return space
}
val p: Double = (a + b + c) / 2 // 半周长
val s: Double = Math.sqrt(p * (p - a) * (p - b) * (p - c)) // 海伦公式求面积
space = 2 * s / a // 返回点到线的距离(利用三角形面积公式求高)
space
}

// 计算两点之间的距离
private def lineSpace(x1: Int, y1: Int, x2: Int, y2: Int): Double = {
var lineLength: Double = 0
lineLength = Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2))
lineLength
}
}

以上是关于已知直线终点与起点坐标 怎么两点距离的主要内容,如果未能解决你的问题,请参考以下文章

百度地图如何测量距离?

如何计算百度地图上两点的距离

c语言关于求“已知坐标的两点之间距离的距离”的问题

坐标间获取两点距离

两个坐标点的距离怎样算

求助!!!!知道三维两点坐标如何用MATLAB求直线方程,急求!!!!!!!