Uber H3查找两个地理位置之间的距离

时间:2018-11-28 14:49:08

标签: h3

我阅读了h3文档,不确定在两个地理位置之间的绝对距离是否是用例之一。 this页中有一些公式,或者Google Maps为此提供了API。我看到h3 API用于查找六边形之间的距离,但不确定在不同分辨率等条件下如何精确或如何使用它。任何示例或细节都将不胜感激。我希望使用h3可以减少外部API的使用。

3 个答案:

答案 0 :(得分:1)

需要帮助吗?

const h3 = require("h3-js");

function distanceBetweenIndexCentres(h3Index1, h3Index2){
    if(!h3.h3IsValid(h3Index1) || !h3.h3IsValid(h3Index2))
        throw 'invalid h3 indexes provided'

    let index1CenterCoordinates = h3.h3ToGeo(h3Index1);
    let index2CenterCoordinates = h3.h3ToGeo(h3Index2);

    return distanceInKm(index1CenterCoordinates[0], index1CenterCoordinates[1], index2CenterCoordinates[0], index2CenterCoordinates[1])
}

function distanceInKm(lat1, lon1, lat2, lon2) {
    if ((lat1 == lat2) && (lon1 == lon2)) {
        return 0;
    }
    else {
        var radlat1 = Math.PI * lat1/180;
        var radlat2 = Math.PI * lat2/180;
        var theta = lon1-lon2;
        var radtheta = Math.PI * theta/180;
        var dist = Math.sin(radlat1) * Math.sin(radlat2) + Math.cos(radlat1) * Math.cos(radlat2) * Math.cos(radtheta);
        if (dist > 1) {
            dist = 1;
        }
        dist = Math.acos(dist);
        dist = dist * 180/Math.PI;
        dist = dist * 60 * 1.1515;
        return dist * 1.609344;
    }
}


let h3Index1 = h3.geoToH3(16.750642, 78.017239, 7);
let h3Index2 = h3.geoToH3(16.806983, 78.027875, 6);
console.log('distance in km: '+distanceBetweenIndexCentres(h3Index1, h3Index2))

//prints - distance in km: 7.60193311570551

答案 1 :(得分:0)

您是正确的,目前没有H3函数可以计算两个地理点之间的物理距离。库中有一个内部函数,该函数将返回以千米为单位的物理距离,但是我们当前不在H3库API中公开它。有一个开放的request for this feature,很可能会在下一个或两个月内添加。

答案 2 :(得分:0)

H3 Index Distance

https://boundaries-io.com 有一个 API 可以获取两个 H3 地址的距离(英里)和方位(Hex 或 Long 值)。
API 调用示例: 给出以下 GeoJson 结果。

   /rest/v1/public/boundary/h3/zipcode/index1/89283409857ffff/index2/89283446943ffff/hex?showLineBetween=true&showPoints=false

该服务每天免费拨打 50 次,让您快速获得结果,免责声明,我为这家公司工作