2012-11-22 21:42:29 +01:00
|
|
|
<UserControl
|
|
|
|
|
x:Class="SilverlightApplication.MainPage"
|
|
|
|
|
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
|
|
|
|
|
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
|
|
|
|
|
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
|
|
|
|
|
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
|
2013-11-17 16:52:03 +01:00
|
|
|
xmlns:map="clr-namespace:MapControl;assembly=MapControl.Silverlight"
|
|
|
|
|
xmlns:vm="clr-namespace:ViewModel"
|
2012-11-22 21:42:29 +01:00
|
|
|
xmlns:local="clr-namespace:SilverlightApplication"
|
2013-05-08 17:05:17 +02:00
|
|
|
mc:Ignorable="d" d:DesignHeight="300" d:DesignWidth="400">
|
2012-11-22 21:42:29 +01:00
|
|
|
<UserControl.Resources>
|
|
|
|
|
<map:TileLayerCollection x:Key="TileLayers">
|
2014-10-19 21:50:23 +02:00
|
|
|
<!--
|
2015-08-09 20:04:44 +02:00
|
|
|
TileLayers with OpenStreetMap data.
|
2014-10-19 21:50:23 +02:00
|
|
|
-->
|
|
|
|
|
<map:TileLayer SourceName="OpenStreetMap"
|
|
|
|
|
Description="Maps © [OpenStreetMap Contributors](http://www.openstreetmap.org/copyright)"
|
|
|
|
|
TileSource="http://{c}.tile.openstreetmap.org/{z}/{x}/{y}.png"
|
|
|
|
|
MaxZoomLevel="19"/>
|
|
|
|
|
<map:TileLayer SourceName="Thunderforest OpenCycleMap"
|
|
|
|
|
Description="Maps © [Thunderforest](http://www.thunderforest.com/), Data © [OpenStreetMap Contributors](http://www.openstreetmap.org/copyright)"
|
|
|
|
|
TileSource="http://{c}.tile.thunderforest.com/cycle/{z}/{x}/{y}.png"/>
|
|
|
|
|
<map:TileLayer SourceName="Thunderforest Landscape"
|
|
|
|
|
Description="Maps © [Thunderforest](http://www.thunderforest.com/), Data © [OpenStreetMap Contributors](http://www.openstreetmap.org/copyright)"
|
|
|
|
|
TileSource="http://{c}.tile.thunderforest.com/landscape/{z}/{x}/{y}.png"/>
|
|
|
|
|
<map:TileLayer SourceName="Thunderforest Outdoors"
|
|
|
|
|
Description="Maps © [Thunderforest](http://www.thunderforest.com/), Data © [OpenStreetMap Contributors](http://www.openstreetmap.org/copyright)"
|
|
|
|
|
TileSource="http://{c}.tile.thunderforest.com/outdoors/{z}/{x}/{y}.png"/>
|
|
|
|
|
<map:TileLayer SourceName="Thunderforest Transport"
|
|
|
|
|
Description="Maps © [Thunderforest](http://www.thunderforest.com/), Data © [OpenStreetMap Contributors](http://www.openstreetmap.org/copyright)"
|
|
|
|
|
TileSource="http://{c}.tile.thunderforest.com/transport/{z}/{x}/{y}.png"/>
|
|
|
|
|
<map:TileLayer SourceName="Thunderforest Transport Dark"
|
|
|
|
|
Description="Maps © [Thunderforest](http://www.thunderforest.com/), Data © [OpenStreetMap Contributors](http://www.openstreetmap.org/copyright)"
|
|
|
|
|
TileSource="http://{c}.tile.thunderforest.com/transport-dark/{z}/{x}/{y}.png"
|
2014-11-19 21:11:14 +01:00
|
|
|
Foreground="White" Background="Black"/>
|
2014-10-19 21:50:23 +02:00
|
|
|
<map:TileLayer SourceName="MapQuest OpenStreetMap"
|
|
|
|
|
Description="Maps © [MapQuest](http://www.mapquest.com/), Data © [OpenStreetMap Contributors](http://www.openstreetmap.org/copyright)"
|
2015-11-11 19:48:50 +01:00
|
|
|
TileSource="http://otile{n}.mqcdn.com/tiles/1.0.0/osm/{z}/{x}/{y}.jpg"
|
2014-10-19 21:50:23 +02:00
|
|
|
MaxZoomLevel="19"/>
|
|
|
|
|
<map:TileLayer SourceName="Seamarks"
|
|
|
|
|
TileSource="http://tiles.openseamap.org/seamark/{z}/{x}/{y}.png"
|
|
|
|
|
MinZoomLevel="10" MaxZoomLevel="18"/>
|
|
|
|
|
|
|
|
|
|
<!--
|
2015-08-09 20:04:44 +02:00
|
|
|
Bing Maps TileLayers with tile URLs retrieved from the Imagery Metadata Service
|
|
|
|
|
(see http://msdn.microsoft.com/en-us/library/ff701716.aspx).
|
|
|
|
|
A Bing Maps API Key (see http://msdn.microsoft.com/en-us/library/ff428642.aspx) is required
|
|
|
|
|
for using these layers and must be assigned to the static BingMapsTileLayer.ApiKey property.
|
2014-10-19 21:50:23 +02:00
|
|
|
-->
|
|
|
|
|
<map:BingMapsTileLayer SourceName="Bing Maps Road"
|
|
|
|
|
Description="© [Microsoft Corporation](http://www.bing.com/maps/)"
|
|
|
|
|
Mode="Road" MaxZoomLevel="19"/>
|
|
|
|
|
<map:BingMapsTileLayer SourceName="Bing Maps Aerial"
|
|
|
|
|
Description="© [Microsoft Corporation](http://www.bing.com/maps/)"
|
|
|
|
|
Mode="Aerial" MaxZoomLevel="19" Foreground="White" Background="Black"/>
|
|
|
|
|
<map:BingMapsTileLayer SourceName="Bing Maps Hybrid"
|
|
|
|
|
Description="© [Microsoft Corporation](http://www.bing.com/maps/)"
|
|
|
|
|
Mode="AerialWithLabels" MaxZoomLevel="19" Foreground="White" Background="Black"/>
|
2012-11-22 21:42:29 +01:00
|
|
|
</map:TileLayerCollection>
|
2014-12-17 21:38:28 +01:00
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
<DataTemplate x:Key="PolylineItemTemplate">
|
|
|
|
|
<map:MapPolyline Locations="{Binding Locations}" Stroke="Red" StrokeThickness="3"/>
|
|
|
|
|
</DataTemplate>
|
2014-12-17 21:38:28 +01:00
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
<Style x:Key="PolylineItemStyle" TargetType="map:MapItem">
|
|
|
|
|
<Setter Property="Template">
|
|
|
|
|
<Setter.Value>
|
|
|
|
|
<ControlTemplate TargetType="map:MapItem">
|
|
|
|
|
<map:MapPolyline Locations="{Binding Locations}" Stroke="Red" StrokeThickness="3"/>
|
|
|
|
|
</ControlTemplate>
|
|
|
|
|
</Setter.Value>
|
|
|
|
|
</Setter>
|
|
|
|
|
</Style>
|
2014-12-17 21:38:28 +01:00
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
<Style x:Key="PointItemStyle" TargetType="map:MapItem">
|
2012-12-06 23:28:12 +01:00
|
|
|
<Setter Property="map:MapPanel.Location" Value="{Binding Location}"/>
|
2012-11-22 21:42:29 +01:00
|
|
|
<Setter Property="Template">
|
|
|
|
|
<Setter.Value>
|
|
|
|
|
<ControlTemplate TargetType="map:MapItem">
|
|
|
|
|
<Canvas>
|
|
|
|
|
<VisualStateManager.VisualStateGroups>
|
|
|
|
|
<VisualStateGroup x:Name="CommonStates">
|
|
|
|
|
<VisualState x:Name="Normal"/>
|
|
|
|
|
<VisualState x:Name="Disabled"/>
|
|
|
|
|
<VisualState x:Name="MouseOver">
|
|
|
|
|
<Storyboard>
|
|
|
|
|
<DoubleAnimation Storyboard.TargetName="labelBackground" Storyboard.TargetProperty="Opacity" To="1" Duration="0:0:0.1"/>
|
|
|
|
|
</Storyboard>
|
|
|
|
|
</VisualState>
|
|
|
|
|
</VisualStateGroup>
|
|
|
|
|
<VisualStateGroup x:Name="SelectionStates">
|
|
|
|
|
<VisualState x:Name="Unselected"/>
|
|
|
|
|
<VisualState x:Name="Selected">
|
|
|
|
|
<Storyboard>
|
|
|
|
|
<DoubleAnimation Storyboard.TargetName="selectedPath" Storyboard.TargetProperty="Opacity" To="0.7" Duration="0:0:0.1"/>
|
|
|
|
|
</Storyboard>
|
|
|
|
|
</VisualState>
|
|
|
|
|
</VisualStateGroup>
|
|
|
|
|
</VisualStateManager.VisualStateGroups>
|
2013-08-17 08:41:11 +02:00
|
|
|
<Path x:Name="selectedPath" Fill="White" Opacity="0">
|
2012-11-22 21:42:29 +01:00
|
|
|
<Path.Data>
|
|
|
|
|
<EllipseGeometry RadiusX="15" RadiusY="15"/>
|
|
|
|
|
</Path.Data>
|
|
|
|
|
</Path>
|
2013-08-17 08:41:11 +02:00
|
|
|
<Path Fill="Transparent" Stroke="Gray" StrokeThickness="2">
|
2012-11-22 21:42:29 +01:00
|
|
|
<Path.Data>
|
|
|
|
|
<EllipseGeometry RadiusX="8" RadiusY="8"/>
|
|
|
|
|
</Path.Data>
|
|
|
|
|
</Path>
|
|
|
|
|
<Grid Canvas.Left="15" Canvas.Top="-8">
|
2013-08-17 08:41:11 +02:00
|
|
|
<Rectangle x:Name="labelBackground" Fill="White" Opacity="0.7"/>
|
2012-11-22 21:42:29 +01:00
|
|
|
<TextBlock Margin="2,0,2,0" Text="{Binding Name}"/>
|
|
|
|
|
</Grid>
|
|
|
|
|
</Canvas>
|
|
|
|
|
</ControlTemplate>
|
|
|
|
|
</Setter.Value>
|
|
|
|
|
</Setter>
|
|
|
|
|
</Style>
|
2014-12-17 21:38:28 +01:00
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
<Style x:Key="PushpinItemStyle" TargetType="map:MapItem">
|
2012-12-06 23:28:12 +01:00
|
|
|
<Setter Property="map:MapPanel.Location" Value="{Binding Location}"/>
|
2012-11-22 21:42:29 +01:00
|
|
|
<Setter Property="VerticalAlignment" Value="Bottom"/>
|
|
|
|
|
<Setter Property="Template">
|
|
|
|
|
<Setter.Value>
|
2012-12-06 23:28:12 +01:00
|
|
|
<ControlTemplate TargetType="map:MapItem">
|
2012-11-22 21:42:29 +01:00
|
|
|
<map:Pushpin Content="{Binding Name}"/>
|
|
|
|
|
</ControlTemplate>
|
|
|
|
|
</Setter.Value>
|
|
|
|
|
</Setter>
|
|
|
|
|
</Style>
|
|
|
|
|
</UserControl.Resources>
|
2014-12-17 21:38:28 +01:00
|
|
|
|
2013-11-17 16:52:03 +01:00
|
|
|
<UserControl.DataContext>
|
|
|
|
|
<vm:ViewModel/>
|
|
|
|
|
</UserControl.DataContext>
|
2014-12-17 21:38:28 +01:00
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
<Grid x:Name="LayoutRoot" Background="White">
|
|
|
|
|
<Grid.RowDefinitions>
|
|
|
|
|
<RowDefinition/>
|
|
|
|
|
<RowDefinition Height="Auto"/>
|
|
|
|
|
</Grid.RowDefinitions>
|
2014-12-17 21:38:28 +01:00
|
|
|
<map:Map x:Name="map" TileLayer="{Binding [OpenStreetMap], Source={StaticResource TileLayers}}"
|
2015-11-11 19:48:50 +01:00
|
|
|
Center="{Binding MapCenter}" MinZoomLevel="2" ZoomLevel="11"
|
2012-12-12 17:03:33 +01:00
|
|
|
MouseMove="MapMouseMove" MouseLeave="MapMouseLeave">
|
2014-12-17 21:38:28 +01:00
|
|
|
|
2013-04-12 19:59:16 +02:00
|
|
|
<map:MapImage x:Name="mapImage" South="53.54031" North="53.74871" West="8.08594" East="8.43750"
|
2013-04-21 23:56:08 +02:00
|
|
|
Source="10_535_330.jpg" Opacity="0.5"/>
|
2014-12-17 21:38:28 +01:00
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
<map:MapGraticule Opacity="0.6"/>
|
|
|
|
|
|
|
|
|
|
<!-- use ItemTemplate or ItemContainerStyle alternatively -->
|
2013-11-17 16:52:03 +01:00
|
|
|
<map:MapItemsControl ItemsSource="{Binding Polylines}"
|
2012-11-22 21:42:29 +01:00
|
|
|
ItemTemplate="{StaticResource PolylineItemTemplate}"/>
|
2013-11-17 16:52:03 +01:00
|
|
|
<!--<map:MapItemsControl ItemsSource="{Binding Polylines}"
|
2012-11-22 21:42:29 +01:00
|
|
|
ItemContainerStyle="{StaticResource PolylineItemStyle}"/>-->
|
|
|
|
|
|
2013-11-17 16:52:03 +01:00
|
|
|
<map:MapItemsControl ItemsSource="{Binding Points}"
|
2012-11-22 21:42:29 +01:00
|
|
|
ItemContainerStyle="{StaticResource PointItemStyle}"
|
|
|
|
|
SelectionMode="Extended"/>
|
|
|
|
|
|
2013-11-17 16:52:03 +01:00
|
|
|
<map:MapItemsControl ItemsSource="{Binding Pushpins}"
|
2012-11-22 21:42:29 +01:00
|
|
|
ItemContainerStyle="{StaticResource PushpinItemStyle}"/>
|
|
|
|
|
|
2013-04-04 18:01:13 +02:00
|
|
|
<Path map:MapPanel.Location="53.5,8.2" Stroke="Blue" StrokeThickness="3" Fill="#1F007F00">
|
|
|
|
|
<Path.Data>
|
2015-02-10 21:59:39 +01:00
|
|
|
<EllipseGeometry RadiusX="1852" RadiusY="1852" Transform="{Binding ScaleTransform, ElementName=map}"/>
|
2013-04-04 18:01:13 +02:00
|
|
|
</Path.Data>
|
|
|
|
|
</Path>
|
|
|
|
|
|
2015-02-18 19:20:59 +01:00
|
|
|
<map:MapPath Stroke="Blue" Fill="Aqua" Opacity="0.5">
|
2015-02-10 21:59:39 +01:00
|
|
|
<map:MapPath.Data>
|
|
|
|
|
<GeometryGroup FillRule="EvenOdd">
|
|
|
|
|
<EllipseGeometry Center="8.2,63.5" RadiusX="0.025" RadiusY="0.025"/>
|
|
|
|
|
<EllipseGeometry Center="8.2,63.51" RadiusX="0.015" RadiusY="0.015"/>
|
|
|
|
|
</GeometryGroup>
|
|
|
|
|
</map:MapPath.Data>
|
|
|
|
|
</map:MapPath>
|
|
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
<map:Pushpin map:MapPanel.Location="53.5,8.2" Background="Yellow" Foreground="Blue" Content="N 53° 30' E 8° 12'"/>
|
|
|
|
|
</map:Map>
|
2014-11-19 21:11:14 +01:00
|
|
|
|
2014-10-19 21:50:23 +02:00
|
|
|
<Border HorizontalAlignment="Right" VerticalAlignment="Bottom" Background="#7FFFFFFF">
|
2014-12-17 21:38:28 +01:00
|
|
|
<RichTextBlock Margin="4,2" FontSize="10" map:HyperlinkText.InlinesSource="{Binding TileLayer.Description, ElementName=map}"/>
|
2014-10-19 21:50:23 +02:00
|
|
|
</Border>
|
2014-11-19 21:11:14 +01:00
|
|
|
|
2012-11-22 21:42:29 +01:00
|
|
|
<Grid Grid.Row="1">
|
|
|
|
|
<Grid.ColumnDefinitions>
|
|
|
|
|
<ColumnDefinition/>
|
|
|
|
|
<ColumnDefinition Width="Auto"/>
|
|
|
|
|
</Grid.ColumnDefinitions>
|
2013-08-17 08:41:11 +02:00
|
|
|
<TextBlock x:Name="mouseLocation" Margin="4" VerticalAlignment="Bottom" FontFamily="Segoe UI Mono"/>
|
2012-11-22 21:42:29 +01:00
|
|
|
<StackPanel Grid.Column="1" Orientation="Horizontal" HorizontalAlignment="Right">
|
2013-04-12 19:59:16 +02:00
|
|
|
<StackPanel Margin="5">
|
|
|
|
|
<TextBlock Text="Zoom Level" Margin="0,0,0,2" HorizontalAlignment="Center" Foreground="Gray" FontSize="10"/>
|
|
|
|
|
<Slider Width="100" SmallChange="0.01"
|
|
|
|
|
Maximum="{Binding MaxZoomLevel, ElementName=map}"
|
|
|
|
|
Minimum="{Binding MinZoomLevel, ElementName=map}"
|
|
|
|
|
Value="{Binding TargetZoomLevel, ElementName=map, Mode=TwoWay}"/>
|
|
|
|
|
</StackPanel>
|
|
|
|
|
<StackPanel Margin="5">
|
|
|
|
|
<TextBlock Text="Heading" Margin="0,0,0,2" HorizontalAlignment="Center" Foreground="Gray" FontSize="10"/>
|
|
|
|
|
<Slider Width="100" SmallChange="5" LargeChange="45" Minimum="0" Maximum="360"
|
|
|
|
|
Value="{Binding TargetHeading, ElementName=map, Mode=TwoWay}"/>
|
|
|
|
|
</StackPanel>
|
|
|
|
|
<StackPanel Margin="5">
|
|
|
|
|
<TextBlock Text="Image Opacity" Margin="0,0,0,2" HorizontalAlignment="Center" Foreground="Gray" FontSize="10"/>
|
|
|
|
|
<Slider Width="100" Minimum="0" Maximum="1"
|
|
|
|
|
Value="{Binding Opacity, ElementName=mapImage, Mode=TwoWay}"/>
|
|
|
|
|
</StackPanel>
|
2014-10-19 21:50:23 +02:00
|
|
|
<CheckBox Margin="5" VerticalAlignment="Bottom" Content="Seamarks"
|
|
|
|
|
Checked="SeamarksChecked" Unchecked="SeamarksUnchecked"/>
|
2014-12-17 21:38:28 +01:00
|
|
|
<ComboBox Width="130" Margin="5" VerticalAlignment="Bottom"
|
|
|
|
|
SelectedValuePath="Tag" SelectedValue="{Binding TileLayer, ElementName=map, Mode=TwoWay}">
|
|
|
|
|
<ComboBoxItem Tag="{Binding [OpenStreetMap], Source={StaticResource TileLayers}}">OpenStreetMap</ComboBoxItem>
|
|
|
|
|
<ComboBoxItem Tag="{Binding [Thunderforest OpenCycleMap], Source={StaticResource TileLayers}}">OpenCycleMap</ComboBoxItem>
|
|
|
|
|
<ComboBoxItem Tag="{Binding [Thunderforest Landscape], Source={StaticResource TileLayers}}">Landscape</ComboBoxItem>
|
|
|
|
|
<ComboBoxItem Tag="{Binding [Thunderforest Outdoors], Source={StaticResource TileLayers}}">Outdoors</ComboBoxItem>
|
|
|
|
|
<ComboBoxItem Tag="{Binding [Thunderforest Transport], Source={StaticResource TileLayers}}">Transport</ComboBoxItem>
|
|
|
|
|
<ComboBoxItem Tag="{Binding [Thunderforest Transport Dark], Source={StaticResource TileLayers}}">Transport Dark</ComboBoxItem>
|
|
|
|
|
<ComboBoxItem Tag="{Binding [MapQuest OpenStreetMap], Source={StaticResource TileLayers}}">MapQuest Open</ComboBoxItem>
|
|
|
|
|
<!--<ComboBoxItem Tag="{Binding [Bing Maps Road], Source={StaticResource TileLayers}}">Bing Maps Road</ComboBoxItem>
|
|
|
|
|
<ComboBoxItem Tag="{Binding [Bing Maps Aerial], Source={StaticResource TileLayers}}">Bing Maps Aerial</ComboBoxItem>
|
|
|
|
|
<ComboBoxItem Tag="{Binding [Bing Maps Hybrid], Source={StaticResource TileLayers}}">Bing Maps Hybrid</ComboBoxItem>-->
|
2012-11-22 21:42:29 +01:00
|
|
|
</ComboBox>
|
|
|
|
|
</StackPanel>
|
|
|
|
|
</Grid>
|
|
|
|
|
</Grid>
|
|
|
|
|
</UserControl>
|