如何使用 PHP 将 Bing 地图四键转换为缩放级别、x 坐标和 y 坐标
本文关键字:坐标 缩放 转换 PHP 何使用 Bing 地图 | 更新日期: 2023-09-27 18:36:48
我正在尝试用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";
}
我正在使用的示例四键和预期结果如下:
四键:120202111102203112
X 坐标:134926
Y 坐标: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) ;