将在地图上画的折线等分,并得到等分点的坐标

//首先将折线上的坐标点存入一个数组中
var arr = [pt1,pt2,pt3],
    brr = [],
    i = 0;
while(i < arr.length){
    //这样可以按照画线的顺序获取相邻的两个坐标点
    var p1 = arr[i+1],
        p2 = arr[i];

    //计算两点之间的实际距离,百度地图用map.getDistance(pointA,pointB)计算,其他地图可以用自定义函数distanceTo
    //然后除以一个整数M(M具体根据情况而定),得到等分点的个数N
    //计算两点的经纬度的偏移值
    var disX = p1.x - p2.x;
        disY = p1.y - p2.y;
    //disX和disy分别除以N,得到每个等分点的经纬度分别需要偏移的值
    var newdisX = disX/N,
        newdisY = disY/N;
    //得到新的经纬度坐标
    var newptX = arr[i].x + newdisX * i,
        newptY = arr[i].y + newdisY * i;
    //实例化一个新的坐标点
    var newpt = new Point(newptX,newptY);
    //将新的坐标点存到一个新的数组中,该数组即为我们需要的坐标点的集合
    brr.push(newpt);
    i ++;
}

//计算两点的实际距离
distanceTo: function(pointA,pointB) {
    var distance = 0.0;
    if ((pointA.x != null) && (pointA.y != null) &&
    (pointB != null) && (pointB.x != null) && (pointB.y != null)) {
        var dx2 = Math.pow(pointA.x - pointB.x, 2);
        var dy2 = Math.pow(pointA.y - pointB.y, 2);
        distance = Math.sqrt(dx2 + dy2);
    }
    return distance;
}

 

posted @ 2015-05-29 21:22  Liu66~  阅读(1492)  评论(1编辑  收藏  举报