MapsPanel.xaml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. <UserControl x:Class="PRSDesktop.MapsPanel"
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
  5. xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
  6. xmlns:syncfusion="http://schemas.syncfusion.com/wpf"
  7. xmlns:dynamicGrid="clr-namespace:InABox.DynamicGrid;assembly=InABox.Wpf"
  8. xmlns:prsDesktop="clr-namespace:PRSDesktop"
  9. mc:Ignorable="d"
  10. d:DesignHeight="450" d:DesignWidth="800">
  11. <UserControl.DataContext>
  12. <prsDesktop:MapViewModel x:Name="ViewModel" />
  13. </UserControl.DataContext>
  14. <UserControl.Resources>
  15. <prsDesktop:TestConverter x:Key="TestConverter" />
  16. <DataTemplate x:Key="MapMarkerTemplate" DataType="{x:Type syncfusion:CustomDataSymbol}" >
  17. <Border
  18. x:Name="_border"
  19. CornerRadius="0,10,10,10"
  20. BorderBrush="Black"
  21. BorderThickness="0.75"
  22. Background="{Binding ., Converter={StaticResource TestConverter}}"
  23. Padding="5,2,5,2"
  24. PreviewMouseDown="Image_PreviewMouseDown">
  25. <Label
  26. Content="{Binding ., Converter={StaticResource TestConverter}}"
  27. HorizontalContentAlignment="Center"
  28. VerticalContentAlignment="Center"
  29. FontSize="10"
  30. Background="Red"
  31. Foreground="Yellow"/>
  32. </Border>
  33. </DataTemplate>
  34. <!-- -->
  35. <!-- <DataTemplate x:Key="MapWayPointTemplate" DataType="{x:Type prsDesktop:MapMarker}"> -->
  36. <!-- <Border -->
  37. <!-- x:Name="_border" -->
  38. <!-- CornerRadius="0,10,10,10" -->
  39. <!-- BorderBrush="Black" -->
  40. <!-- BorderThickness="0.75" -->
  41. <!-- Background="Green" -->
  42. <!-- Padding="5,2,5,2" > -->
  43. <!-- <Label -->
  44. <!-- x:Name="Code" -->
  45. <!-- Content="Time" -->
  46. <!-- HorizontalContentAlignment="Center" -->
  47. <!-- VerticalContentAlignment="Center" -->
  48. <!-- FontSize="10" -->
  49. <!-- Background="Yellow" -->
  50. <!-- Foreground="Red"/> -->
  51. <!-- </Border> -->
  52. <!-- </DataTemplate> -->
  53. </UserControl.Resources>
  54. <Grid>
  55. <Grid.ColumnDefinitions>
  56. <ColumnDefinition Width="Auto" />
  57. <ColumnDefinition Width="*" />
  58. <ColumnDefinition Width="400" />
  59. </Grid.ColumnDefinitions>
  60. <Grid.RowDefinitions>
  61. <RowDefinition Height="Auto" />
  62. <RowDefinition Height="*" />
  63. </Grid.RowDefinitions>
  64. <Border Grid.Column="0" Grid.Row="0" Grid.RowSpan="2" Margin="0,0,2,0" BorderBrush="Gray"
  65. BorderThickness="0.75" Padding="5">
  66. <Slider x:Name="Zoom" Orientation="Vertical" ValueChanged="Zoom_ValueChanged" Minimum="1" Maximum="20"
  67. Value="11" />
  68. </Border>
  69. <syncfusion:SfMap x:Name="Map" Grid.Column="1" Grid.Row="0" Grid.RowSpan="2" BorderBrush="Gray"
  70. BorderThickness="0.75" PreviewMouseWheel="Map_PreviewMouseWheel"
  71. PreviewMouseDoubleClick="Map_PreviewMouseDoubleClick" PreviewMouseUp="Map_PreviewMouseUp">
  72. <syncfusion:SfMap.Layers>
  73. <syncfusion:ImageryLayer
  74. x:Name="ImageryLayer"
  75. LayerType="Bing"
  76. BingMapKey="5kn7uPPBBGKdmWYiwHJL~LjUY7IIgFzGdXpkpWT7Fsw~AmlksNuYOBHNQ3cOa61Nz2ghvK5EbrBZ3aQqvTS4OjcPxTBGNGsj2hKc058CgtgJ"
  77. BingMapStyle="Road"
  78. Center="-31.95105, 115.85939"
  79. Radius="10"
  80. Markers="{Binding Markers}"
  81. MarkerTemplate="{StaticResource MapMarkerTemplate}">
  82. <!-- <syncfusion:ImageryLayer.SubShapeFileLayers> -->
  83. <!-- <syncfusion:SubShapeFileLayer > -->
  84. <!-- <syncfusion:SubShapeFileLayer.MapElements > -->
  85. <!-- <syncfusion:MapPolyline Stroke="DarkBlue" StrokeThickness="5" Points="{Binding WayPoints}" /> -->
  86. <!-- </syncfusion:SubShapeFileLayer.MapElements> -->
  87. <!-- </syncfusion:SubShapeFileLayer> -->
  88. <!-- </syncfusion:ImageryLayer.SubShapeFileLayers> -->
  89. </syncfusion:ImageryLayer>
  90. </syncfusion:SfMap.Layers>
  91. </syncfusion:SfMap>
  92. <Border Grid.Column="2" Grid.Row="0" Margin="4,0,0,0" BorderBrush="Gray" BorderThickness="0.75"
  93. Background="WhiteSmoke">
  94. <StackPanel Orientation="Vertical">
  95. <Label Content="Map Options" HorizontalContentAlignment="Center" VerticalContentAlignment="Center" />
  96. <ComboBox x:Name="Viewstyle" Margin="5,0,5,5" SelectedIndex="0"
  97. SelectionChanged="Viewstyle_SelectionChanged" Visibility="Collapsed">
  98. <ComboBoxItem x:Name="OSMViewStyle" Content="Open Street Map" />
  99. <ComboBoxItem x:Name="BingStandardViewStyle" Content="Bing Standard View" />
  100. <ComboBoxItem x:Name="BingTerrainViewStyle" Content="Bing Terrain View" />
  101. <ComboBoxItem x:Name="BingTerrainLabelsViewStyle" Content="Bing Terrain with Labels" />
  102. <ComboBoxItem x:Name="GoogleMapsViewStyle" Content="Google Maps" />
  103. </ComboBox>
  104. <ComboBox x:Name="ViewType" Margin="5,0,5,5" Visibility="Visible" />
  105. <ComboBox x:Name="ViewGroup" Margin="5,0,5,5" DisplayMemberPath="Value" SelectedValuePath="Key" />
  106. </StackPanel>
  107. </Border>
  108. <dynamicGrid:DynamicTabControl
  109. x:Name="TabView"
  110. Grid.Column="2"
  111. Grid.Row="1"
  112. Margin="4,2,0,0"
  113. BorderBrush="Gray"
  114. BorderThickness="0.75"
  115. Background="WhiteSmoke"
  116. TabStripPlacement="Bottom"
  117. SelectionChanged="TabView_PageChanged">
  118. <dynamicGrid:DynamicTabItem Header="Marker List">
  119. <Grid>
  120. <Grid.ColumnDefinitions>
  121. <ColumnDefinition Width="*" />
  122. </Grid.ColumnDefinitions>
  123. <Grid.RowDefinitions>
  124. <RowDefinition Height="*" />
  125. <RowDefinition Height="Auto" />
  126. </Grid.RowDefinitions>
  127. <ListView Grid.Row="0" Grid.Column="0" x:Name="Markers" Margin="5,5,5,0"
  128. MouseDoubleClick="Markers_MouseDoubleClick"
  129. ScrollViewer.HorizontalScrollBarVisibility="Disabled"
  130. SelectionChanged="Markers_SelectionChanged">
  131. <ListView.Resources>
  132. <Style TargetType="{x:Type GridViewColumnHeader}">
  133. <Setter Property="HorizontalContentAlignment" Value="Left" />
  134. </Style>
  135. </ListView.Resources>
  136. <ListView.View>
  137. <GridView>
  138. <GridViewColumn Header="Code" DisplayMemberBinding="{Binding Code}" Width="100" />
  139. <GridViewColumn Header="Description" DisplayMemberBinding="{Binding Description}"
  140. Width="188" />
  141. <GridViewColumn Header="Updated"
  142. DisplayMemberBinding="{Binding Updated, StringFormat='{}{0:dd MMM yy}'}"
  143. Width="85" />
  144. </GridView>
  145. </ListView.View>
  146. </ListView>
  147. <DockPanel Grid.Row="2" Grid.Column="0">
  148. <Button x:Name="ResetView" DockPanel.Dock="Right" Content="Reset View" Margin="5" Width="70"
  149. Click="ResetView_Click" />
  150. <CheckBox x:Name="ShowAll" DockPanel.Dock="Left" Content="Include Hidden Markers" Margin="5"
  151. HorizontalContentAlignment="Left" VerticalContentAlignment="Center"
  152. Checked="IncludeVisibleMarkers_Checked" Unchecked="IncludeVisibleMarkers_Checked"
  153. IsThreeState="False" />
  154. </DockPanel>
  155. </Grid>
  156. </dynamicGrid:DynamicTabItem>
  157. <dynamicGrid:DynamicTabItem Header="Marker Details">
  158. <Grid>
  159. <Grid.ColumnDefinitions>
  160. <ColumnDefinition Width="Auto" />
  161. <ColumnDefinition Width="*" />
  162. </Grid.ColumnDefinitions>
  163. <Grid.RowDefinitions>
  164. <RowDefinition Height="Auto" />
  165. <RowDefinition Height="Auto" />
  166. <RowDefinition Height="Auto" />
  167. <RowDefinition Height="Auto" />
  168. <RowDefinition Height="*" />
  169. </Grid.RowDefinitions>
  170. <Label Grid.Row="0" Grid.Column="0" Margin="5" Content="Name" VerticalContentAlignment="Center" />
  171. <TextBox Grid.Row="0" Grid.Column="1" x:Name="Description" Margin="5"
  172. HorizontalContentAlignment="Left" VerticalContentAlignment="Center" />
  173. <Label Grid.Row="1" Grid.Column="0" Margin="5,0,5,5" Content="Updated"
  174. VerticalContentAlignment="Center" />
  175. <TextBox Grid.Row="1" Grid.Column="1" x:Name="LastUpdate" Margin="5,0,5,5"
  176. HorizontalContentAlignment="Left" VerticalContentAlignment="Center" />
  177. <Label Grid.Row="2" Grid.Column="0" Margin="5,0,5,5" Content="Updated By"
  178. VerticalContentAlignment="Center" />
  179. <TextBox Grid.Row="2" Grid.Column="1" x:Name="Device" Margin="5,0,5,5"
  180. HorizontalContentAlignment="Left" VerticalContentAlignment="Center" />
  181. <Border BorderBrush="Gray" BorderThickness="0.75" Padding="0,5,0,0" Grid.Row="3" Grid.Column="0"
  182. Grid.ColumnSpan="2" Margin="5" Background="White">
  183. <syncfusion:CalendarEdit x:Name="Date" ShowAbbreviatedMonthNames="True"
  184. AllowMultiplySelection="False" DateChanged="Date_DateChanged"
  185. BorderBrush="Transparent" />
  186. </Border>
  187. <ListView Grid.Row="4" Grid.Column="0" Grid.ColumnSpan="2" x:Name="History" Margin="5,0,5,5"
  188. MouseDoubleClick="History_MouseDoubleClick"
  189. ScrollViewer.HorizontalScrollBarVisibility="Disabled">
  190. <ListView.Resources>
  191. <Style TargetType="{x:Type GridViewColumnHeader}">
  192. <Setter Property="HorizontalContentAlignment" Value="Left" />
  193. </Style>
  194. </ListView.Resources>
  195. <ListView.View>
  196. <GridView>
  197. <GridViewColumn Header="Date"
  198. DisplayMemberBinding="{Binding Date, StringFormat='{}{0:HH:mm}'}"
  199. Width="40" />
  200. <GridViewColumn Header="Activity" DisplayMemberBinding="{Binding Description}"
  201. Width="315" />
  202. </GridView>
  203. </ListView.View>
  204. </ListView>
  205. </Grid>
  206. </dynamicGrid:DynamicTabItem>
  207. </dynamicGrid:DynamicTabControl>
  208. </Grid>
  209. </UserControl>