2012-11-22 21:42:29 +01:00
|
|
|
|
// XAML Map Control - http://xamlmapcontrol.codeplex.com/
|
2014-01-10 20:11:39 +01:00
|
|
|
|
// Copyright © 2014 Clemens Fischer
|
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-11-22 21:42:29 +01:00
|
|
|
|
using System.Windows.Media;
|
|
|
|
|
|
|
|
|
|
|
|
namespace MapControl
|
|
|
|
|
|
{
|
|
|
|
|
|
internal partial class TileContainer : ContainerVisual
|
|
|
|
|
|
{
|
2013-11-17 16:52:03 +01:00
|
|
|
|
private Matrix GetViewportTransformMatrix(double scale, double offsetX, double offsetY)
|
2012-11-22 21:42:29 +01:00
|
|
|
|
{
|
2013-11-17 16:52:03 +01:00
|
|
|
|
var transform = new Matrix(scale, 0d, 0d, -scale, offsetX, offsetY);
|
|
|
|
|
|
|
2013-05-13 23:49:48 +02:00
|
|
|
|
transform.RotateAt(rotation, viewportOrigin.X, viewportOrigin.Y);
|
2013-10-13 16:32:51 +02:00
|
|
|
|
|
|
|
|
|
|
return transform;
|
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);
|
|
|
|
|
|
var transform = new Matrix(1d, 0d, 0d, 1d, tileGrid.X * TileSource.TileSize, tileGrid.Y * TileSource.TileSize);
|
|
|
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
|
transform.Scale(scale, scale);
|
2013-05-13 23:49:48 +02:00
|
|
|
|
transform.Translate(tileLayerOffset.X, tileLayerOffset.Y);
|
|
|
|
|
|
transform.RotateAt(rotation, viewportOrigin.X, viewportOrigin.Y);
|
|
|
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
|
return transform;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
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
|
|
|
|
var transform = ViewportTransform.Matrix;
|
2013-05-13 23:49:48 +02:00
|
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
|
transform.Invert(); // view to map coordinates
|
|
|
|
|
|
transform.Translate(180d, -180d);
|
2013-05-13 23:49:48 +02:00
|
|
|
|
transform.Scale(scale, -scale); // map coordinates to tile indices
|
|
|
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
|
return transform;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|