博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java求解:点到线段的距离
阅读量:5047 次
发布时间:2019-06-12

本文共 1257 字,大约阅读时间需要 4 分钟。

前言:本人要制作一个android的APP,在屏幕上画出了一条线段后,手指点击线段可以将线段选中。因此要测量手指点击的坐标与该线段的距离,距离设定在20内就算是选中它。

 

想法:点到线段的距离类似于点到直线的距离,但是出现点到线段的投影不在线段上,于是要考虑4种情况:

有时间画图来具体讲解。

情况1,测试点离线段的起点最近。

情况2,测试点离线段最近。

情况3,测试点离线段的终点最近。

情况4,测试点在线段上。

 

java代码:

// 点到直线的最短距离的判断 点(x0,y0) 到由两点组成的线段(x1,y1) ,( x2,y2 )private double pointToLine(int x1, int y1, int x2, int y2, int x0,       int y0) {    double space = 0;    double a, b, c;    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;    }    double p = (a + b + c) / 2;// 半周长    double s = Math.sqrt(p * (p - a) * (p - b) * (p - c));// 海伦公式求面积    space = 2 * s / a;// 返回点到线的距离(利用三角形面积公式求高)    return space;}// 计算两点之间的距离private double lineSpace(int x1, int y1, int x2, int y2) {    double lineLength = 0;    lineLength = Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2)           * (y1 - y2));    return lineLength;}

  

转载于:https://www.cnblogs.com/Genius3115/p/6774799.html

你可能感兴趣的文章
一个小的日常实践——高速Fibonacci数算法
查看>>
创建与删除索引
查看>>
java的基本数据类型
查看>>
机器学些技法(9)--Decision Tree
查看>>
静态页面复习--用semantic UI写一个10min首页
查看>>
在Windows下安装64位压缩包版mysql 5.7.11版本的方法
查看>>
drf权限组件
查看>>
输入月份和日期,得出是今年第几天
查看>>
利用mysqldump备份mysql
查看>>
Qt中子窗口全屏显示与退出全屏
查看>>
使用brew安装软件
查看>>
[BZOJ1083] [SCOI2005] 繁忙的都市 (kruskal)
查看>>
吴裕雄 python 机器学习——数据预处理嵌入式特征选择
查看>>
Centos6.4安装JDK
查看>>
201521123069 《Java程序设计》 第4周学习总结
查看>>
线性表的顺序存储——线性表的本质和操作
查看>>
【linux】重置fedora root密码
查看>>
用swing做一个简单的正则验证工具
查看>>
百度坐标(BD-09)、国测局坐标(火星坐标,GCJ-02)和WGS-84坐标互转
查看>>
pig自定义UDF
查看>>