如何使用 PHP 将 Bing 地图四键转换为缩放级别、x 坐标和 y 坐标


How can I convert a Bing maps quadkey into zoom level, x-coordinate and y-coordinate using PHP?

我正在尝试用PHP编写一个脚本,该脚本将接受Bing地图四键,然后返回缩放级别,x坐标和y坐标,以便我可以使用自己的地图。我的代码基于 Microsoft 提供的 C# 示例代码,如下所示:

public static void QuadKeyToTileXY(string quadKey, out int tileX, out int tileY, out int levelOfDetail)
{
    tileX = tileY = 0;
    levelOfDetail = quadKey.Length;
    for (int i = levelOfDetail; i > 0; i--)
    {
        int mask = 1 << (i - 1);
        switch (quadKey[levelOfDetail - i])
        {
            case '0':
                break;
            case '1':
                tileX |= mask;
                break;
            case '2':
                tileY |= mask;
                break;
            case '3':
                tileX |= mask;
                tileY |= mask;
                break;
            default:
                throw new ArgumentException("Invalid QuadKey digit sequence.");
        }
    }
}

这是我使用 PHP 的重新创建,它没有按我预期运行:

$quadkey = intval($_GET["quadkey"]);
$zoom = count($quadkey);
for ($i = $zoom; $i > 0; $i--)
{
    $mask = 1 << ($i - 1);
    $quadkey_array = str_split($quadkey);
    switch ($quadkey_array[$zoom - $i])
    {
        case 0:
            break;
        case 1:
            $x |= $mask;
            break;
        case 2:
            $y |= $mask;
            break;
        case 3:
            $x |= $mask;
            $y |= $mask;
            break;
        default:
            echo "Error";
    }

    echo "/" . $zoom . "/" . $x . "/" . $y . ".png";
}

我正在使用的示例四键和预期结果如下:

四键:120202111102203112X 坐标:134926Y 坐标:86121变焦:18

有人能说明我做错了什么吗?我一直在四处寻找,找不到任何其他示例代码来检查!谢谢大家!

我的代码中有一些我应该看到的错误。

$zoom = count($quadkey);

错误,计算$quadkeys数,而不是字符串的长度。

$zoom = strlen($quadkey);

此外,URL 应在 for 循环之外生成,就在它下方。如果其他人需要将 Bing 地图四键转换为坐标的 PHP 脚本,我将更新的代码放在下面。

$quadkey = intval($_GET["quadkey"]);
$zoom = strlen($quadkey);
for ($i = $zoom; $i > 0; $i--)
{
    $mask = 1 << ($i - 1);
    $quadkey_array = str_split($quadkey);
    switch ($quadkey_array[$zoom - $i])
    {
        case 0:
            break;
        case 1:
            $x |= $mask;
            break;
        case 2:
            $y |= $mask;
            break;
        case 3:
            $x |= $mask;
            $y |= $mask;
            break;
        default:
            echo "Error";
    }
}
echo "/" . $zoom . "/" . $x . "/" . $y . ".png";

在Bing Ajax 7中,QuadKey不是提供的唯一项目,它还提供x,y和levelOfDetail,又名Zoom。

我发现这一点之前,我也考虑过服务器端转换,但它在 javascript 中可供您使用。

必应地图附带 x、y 和 z,可直接用于 OSM Web 请求:

var map = new Microsoft.Maps.Map( <snip> )
function useZXY(tile) {
    return "http://tile.openstreetmap.org/" + 
            tile.levelOfDetail + "/" + 
            tile.x + "/" + 
            tile.y +".png";
}
var omsTS = new Microsoft.Maps.TileSource({ uriConstructor: useZXY  });
var omsTL = new Microsoft.Maps.TileLayer({ mercator: omsTS, opacity: 0.5 });
map.entities.push(omsTL) ;