2020-10-25 16:09:09 +01:00
|
|
|
|
// XAML Map Control - https://github.com/ClemensFischer/XAML-Map-Control
|
2022-01-14 20:22:56 +01:00
|
|
|
|
// © 2022 Clemens Fischer
|
2020-10-25 16:09:09 +01:00
|
|
|
|
// Licensed under the Microsoft Public License (Ms-PL)
|
|
|
|
|
|
|
|
|
|
|
|
using System;
|
|
|
|
|
|
using System.Globalization;
|
|
|
|
|
|
|
|
|
|
|
|
namespace MapControl
|
|
|
|
|
|
{
|
|
|
|
|
|
public class BoundingBoxTileSource : TileSource
|
|
|
|
|
|
{
|
|
|
|
|
|
public override Uri GetUri(int x, int y, int zoomLevel)
|
|
|
|
|
|
{
|
|
|
|
|
|
Uri uri = null;
|
|
|
|
|
|
|
|
|
|
|
|
if (UriFormat != null)
|
|
|
|
|
|
{
|
|
|
|
|
|
var tileSize = 360d / (1 << zoomLevel); // tile width in degrees
|
|
|
|
|
|
var west = MapProjection.Wgs84MetersPerDegree * (x * tileSize - 180d);
|
|
|
|
|
|
var east = MapProjection.Wgs84MetersPerDegree * ((x + 1) * tileSize - 180d);
|
|
|
|
|
|
var south = MapProjection.Wgs84MetersPerDegree * (180d - (y + 1) * tileSize);
|
|
|
|
|
|
var north = MapProjection.Wgs84MetersPerDegree * (180d - y * tileSize);
|
|
|
|
|
|
|
|
|
|
|
|
if (UriFormat.Contains("{bbox}"))
|
|
|
|
|
|
{
|
2021-01-26 00:25:50 +01:00
|
|
|
|
uri = new Uri(UriFormat.Replace("{bbox}",
|
|
|
|
|
|
string.Format(CultureInfo.InvariantCulture, "{0:F2},{1:F2},{2:F2},{3:F2}", west, south, east, north)));
|
2020-10-25 16:09:09 +01:00
|
|
|
|
}
|
|
|
|
|
|
else
|
|
|
|
|
|
{
|
|
|
|
|
|
uri = new Uri(UriFormat
|
|
|
|
|
|
.Replace("{west}", west.ToString("F2", CultureInfo.InvariantCulture))
|
|
|
|
|
|
.Replace("{south}", south.ToString("F2", CultureInfo.InvariantCulture))
|
|
|
|
|
|
.Replace("{east}", east.ToString("F2", CultureInfo.InvariantCulture))
|
|
|
|
|
|
.Replace("{north}", north.ToString("F2", CultureInfo.InvariantCulture)));
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return uri;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|