VC++开发GIS系统(188)线上移点之获取点在线的位置

在下面的开发中会经常遇到操作线上的点的情况,所以本文设计了一个函数用来获取点在线的位置。具体说明如下:

函数定义

在_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。

VC++开发GIS系统(187)线上加点之菜单响应 VC++开发GIS系统(189)线上移点之类的设计及实现

作者:,GIS爱好者。
分享本文,请您带上本文链接
分享到:

发表评论