首页 > 解决方案 > 从地图中心计算地图正方形的坐标

问题描述

我想获取矩形角的坐标。或者寻找最西北点的坐标,距离地图中心50公里。

有谁知道我该怎么做?

关键是当我在地图上移动时,我希望总是有一个矩形(矩形不需要绘制,我只需要它的坐标来进行后端请求),它的角总是距离当前中心 50 公里地图。

我正在考虑以某种方式使用distancefrom 的函数CLLocation,但在这种情况下,我有距离,但没有坐标之一。

50km = mapCenterLocation.distance(from: coordinatesUnknown)

在此处输入图像描述

标签: iosmapkitcllocationcllocationcoordinate2d

解决方案


不太清楚你的意思,但也许这可以帮助

func getNewTargetCoordinate(position: CLLocationCoordinate2D, userBearing: Float, distance: Float)-> CLLocationCoordinate2D{
    //haversine formula 
    //r is earth radius
    let r = 6378140.0
    let latitude1 = position.latitude * (Double.pi/180);
    let longitude1 = position.longitude * (Double.pi/180);
    //bearing for user heading in degree
    let brng = Double(userBearing) * (Double.pi/180);

    //calculating user new position based on user distance and bearing can be seen at haversine formula
    var latitude2 = asin(sin(latitude1)*cos(Double(distance)/r) + cos(latitude1)*sin(Double(distance)/r)*cos(brng));
    var longitude2 = longitude1 + atan2(sin(brng)*sin(Double(distance)/r)*cos(latitude1),cos(Double(distance)/r)-sin(latitude1)*sin(latitude2));

    //converting latitude as degree 
    latitude2 = latitude2 * (180/Double.pi)
    longitude2 = longitude2 * (180/Double.pi)

    // return location of user
    return CLLocationCoordinate2DMake(latitude2, longitude2)
}

这项工作适用于东北方向,西北方向的距离以米为单位,我认为您可以将度数设置为 135,距离设置为 5000。对于位置,您需要放置地图中心位置。

编辑:对于自定义矩形。,您可以先检查对角线度数

func getDiagonalDegree(x: Float, y:Float) -> Float{
    return atan2(y,x)*(180/Double.pi)
}

所以现在你可以得到返回的对角线度数并将其放入 getNewTargetCoordinate。新轴承为 270+diagonalDegree。


推荐阅读