VC++开发GIS系统(188)线上移点之获取点在线的位置
发布时间: 2016-05-25
所属分类: VC++开发GIS系统
在下面的开发中会经常遇到操作线上的点的情况,所以本文设计了一个函数用来获取点在线的位置。具体说明如下:
函数定义
在_malaBase.h中分别增加下面的函数定义
double distancePointToPoint(malaPoint point1, malaPoint point2);//计算两点距离
int getPointPosInLine(malaPoint point, vector<malaPoint>& Line);//得到点在线的位置
函数distancePointToPoint
用于计算两点之间的距离。
- @point1 点1
- @point2 点2
- 返回距离
函数getPointPosInLine
用于得到点在线的位置(也就是点序列中的位置)
- @point 选中的点
- @Line 选中的线
- 返回点在序列中的位置索引
函数实现
两个函数的实现如下
/*
* 计算两点之间距离
*/
double malaLogic::distancePointToPoint(malaPoint point1, malaPoint point2)
{
double x1, y1;
double x2, y2;
double dis(0.0);
x1 = point1.x; y1 = point1.y;
x2 = point2.x; y2 = point2.y;
dis = sqrt(double((x1 - x2)*(x1 - x2) + (y1 - y2)*(y1 - y2)));
return dis;
}
/*
* 得到点在线的位置
*/
int malaLogic::getPointPosInLine(malaPoint point, vector<malaPoint>& Line)
{
int length = Line.size();
double dis = 0.0;
for (int i = 0; i < length; i++)
{
dis = distancePointToPoint(point, Line[i]);
if (dis <= 5)
return i;
}
return -1;
}
实现原理是遍历一条线中每一个点,计算每一个点与鼠标点击点的距离,如果小于一定阈值(本程序设为5),则认为这个点被选中,并返回这个点的索引。如果没有,返回-1。
相关阅读
声明
1.本文所分享的所有需要用户下载使用的内容(包括但不限于软件、数据、图片)来自于网络或者麻辣GIS粉丝自行分享,版权归该下载资源的合法拥有者所有,如有侵权请第一时间联系本站删除。
2.下载内容仅限个人学习使用,请切勿用作商用等其他用途,否则后果自负。
手机阅读
公众号关注
知识星球
手机阅读
最新GIS干货
私享圈子