2012-11-22 21:42:29 +01:00
|
|
|
|
// XAML Map Control - http://xamlmapcontrol.codeplex.com/
|
2013-05-07 18:12:25 +02:00
|
|
|
|
// Copyright © Clemens Fischer 2012-2013
|
2012-11-22 21:42:29 +01:00
|
|
|
|
// Licensed under the Microsoft Public License (Ms-PL)
|
|
|
|
|
|
|
2013-05-13 23:49:48 +02:00
|
|
|
|
using System;
|
2012-12-09 22:18:31 +01:00
|
|
|
|
#if NETFX_CORE
|
2012-11-22 21:42:29 +01:00
|
|
|
|
using Windows.Foundation;
|
|
|
|
|
|
using Windows.UI.Xaml.Controls;
|
|
|
|
|
|
using Windows.UI.Xaml.Media;
|
|
|
|
|
|
#else
|
|
|
|
|
|
using System.Windows;
|
|
|
|
|
|
using System.Windows.Controls;
|
|
|
|
|
|
using System.Windows.Media;
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
namespace MapControl
|
|
|
|
|
|
{
|
|
|
|
|
|
internal partial class TileContainer : Panel
|
|
|
|
|
|
{
|
2013-10-13 16:32:51 +02:00
|
|
|
|
private Matrix GetViewportTransformMatrix(Matrix transform)
|
2012-11-22 21:42:29 +01:00
|
|
|
|
{
|
2013-10-13 16:32:51 +02:00
|
|
|
|
return transform.RotateAt(rotation, viewportOrigin.X, viewportOrigin.Y);
|
2013-05-13 23:49:48 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// Gets a transform matrix with origin at tileGrid.X and tileGrid.Y to minimize rounding errors.
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
private Matrix GetTileLayerTransformMatrix()
|
|
|
|
|
|
{
|
|
|
|
|
|
var scale = Math.Pow(2d, zoomLevel - tileZoomLevel);
|
|
|
|
|
|
|
|
|
|
|
|
return new Matrix(1d, 0d, 0d, 1d, tileGrid.X * TileSource.TileSize, tileGrid.Y * TileSource.TileSize)
|
2012-11-22 21:42:29 +01:00
|
|
|
|
.Scale(scale, scale)
|
2013-05-13 23:49:48 +02:00
|
|
|
|
.Translate(tileLayerOffset.X, tileLayerOffset.Y)
|
|
|
|
|
|
.RotateAt(rotation, viewportOrigin.X, viewportOrigin.Y);
|
2012-11-22 21:42:29 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private Matrix GetTileIndexMatrix(int numTiles)
|
|
|
|
|
|
{
|
2013-05-13 23:49:48 +02:00
|
|
|
|
var scale = (double)numTiles / 360d;
|
|
|
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
|
return ViewportTransform.Matrix
|
|
|
|
|
|
.Invert() // view to map coordinates
|
|
|
|
|
|
.Translate(180d, -180d)
|
2013-05-13 23:49:48 +02:00
|
|
|
|
.Scale(scale, -scale); // map coordinates to tile indices
|
2012-11-22 21:42:29 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
protected override Size MeasureOverride(Size availableSize)
|
|
|
|
|
|
{
|
|
|
|
|
|
foreach (TileLayer tileLayer in Children)
|
|
|
|
|
|
{
|
|
|
|
|
|
tileLayer.Measure(availableSize);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return new Size();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
protected override Size ArrangeOverride(Size finalSize)
|
|
|
|
|
|
{
|
|
|
|
|
|
foreach (TileLayer tileLayer in Children)
|
|
|
|
|
|
{
|
|
|
|
|
|
tileLayer.Arrange(new Rect());
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return finalSize;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|