• WPF加载高德地图


    WPF开发者QQ群: 340500857 

    前言 

    有小伙伴问如何加载高德地图。

     

    欢迎转发、分享、点赞,谢谢大家~。

     

    源码中放了我的 BingMap Key 请大家不要滥用,谢谢。

    也可以自行申请 BingMap Key 

    https://www.bingmapsportal.com/

     

    效果预览(更多效果请下载源码体验):

    一、MainWindow.xaml代码如下:

    <Window x:Class="WpfBingMap.MainWindow"
            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"
            xmlns:map="clr-namespace:Microsoft.Maps.MapControl.WPF;assembly=Microsoft.Maps.MapControl.WPF"
            xmlns:mapOverlays="clr-namespace:Microsoft.Maps.MapControl.WPF.Overlays;assembly=Microsoft.Maps.MapControl.WPF"
            xmlns:PresentationOptions="http://schemas.microsoft.com/winfx/2006/xaml/presentation/options"
            xmlns:local="clr-namespace:WpfBingMap"
            mc:Ignorable="d"
            Title="地图" Width="1024" Height="768">
        <Window.Resources>
            <LinearGradientBrush x:Key="MainColor" EndPoint="0.5,1" StartPoint="0.5,0">
                <GradientStop Color="#FF020621" Offset="0"/>
                <GradientStop Color="#FF364BD8" Offset="1"/>
                <GradientStop Color="#FF5A6BD8" Offset="0.499"/>
            </LinearGradientBrush>
            <ControlTemplate x:Key="CarTemplate" TargetType="map:Pushpin">
                <Grid ToolTip="物资车辆">
                    <Ellipse Width="35" Height="35" Fill="White" StrokeThickness="3" Stroke="Red"/>
                    <Image Source="Images/Car/Car2.png" Width="25" Height="25"/>
                </Grid>
              
            </ControlTemplate>
    
            <Geometry x:Key="PathFlag" PresentationOptions:Freeze="True">M687.5 125C500 125 375 13.7 187.5 62.5V31.3C187.5 31.3 187.5 0 156.3 0C125 0 125 31.3 125 31.3V1000H187.5V625C375 562.5 500 687.5 687.5 687.5C875 687.5 937.5 625 937.5 625V62.5C937.5 62.5 875 125 687.5 125Z</Geometry>
            <SineEase x:Key="SineOut" EasingMode="EaseOut" />
    
            <Storyboard x:Key="AnimateRound" RepeatBehavior="Forever">
                <DoubleAnimation Storyboard.TargetProperty="ScaleX" Storyboard.TargetName="Scale"
                                 Duration="0:0:01" To="2" 
                                 EasingFunction="{StaticResource SineOut}" />
                <DoubleAnimation Storyboard.TargetProperty="ScaleY" Storyboard.TargetName="Scale"
                                 Duration="0:0:01" To="2" 
                                 EasingFunction="{StaticResource SineOut}" />
                <DoubleAnimation Storyboard.TargetProperty="Opacity"  
                                 Duration="0:0:01" To="0" 
                                 EasingFunction="{StaticResource SineOut}" />
            </Storyboard>
            <Style x:Key="alarmStyle" TargetType="map:Pushpin">
                <Setter Property="PositionOrigin" Value="Center"/>
                <Setter Property="Width" Value="60"/>
                <Setter Property="Height" Value="60"/>
                <Setter Property="Template">
                    <Setter.Value>
                        <ControlTemplate TargetType="map:Pushpin">
                            <Grid>
                                <Ellipse Height="40" Width="40" Fill="Red" RenderTransformOrigin="0.5,0.5">
                                    <Ellipse.OpacityMask>
                                        <RadialGradientBrush>
                                            <GradientStop Offset="0" Color="Transparent" />
                                            <GradientStop Offset="1" Color="Black" />
                                        </RadialGradientBrush>
                                    </Ellipse.OpacityMask>
                                    <Ellipse.RenderTransform>
                                        <ScaleTransform x:Name="Scale"/>
                                    </Ellipse.RenderTransform>
                                    <Ellipse.Triggers>
                                        <EventTrigger RoutedEvent="Loaded">
                                            <BeginStoryboard Storyboard="{StaticResource AnimateRound}">
                                            </BeginStoryboard>
                                        </EventTrigger>
                                    </Ellipse.Triggers>
                                </Ellipse>
                                <Viewbox Width="30" Height="30" 
                                         VerticalAlignment="Top" 
                                         HorizontalAlignment="Center"
                                         Margin="20,0,0,0">
                                    <Path Data="{StaticResource PathFlag}" Fill="Orange"/>
                                </Viewbox>
                            </Grid>
                        </ControlTemplate>
                    </Setter.Value>
                </Setter>
    </Style>
        </Window.Resources>
        <Grid>
            <map:Map x:Name="map" ZoomLevel="5" Center="39.9132801985722,116.392009995601"
                      CredentialsProvider="AgXB7m7fVYxKpjEZV9rGdrRPvLgawYhi4Wvw99kk4RDspoalC3B_vQ8GKJAoxrve">
                <map:Map.Mode>
                    <map:MercatorMode/>
                </map:Map.Mode>
                <!--<local:OpenstreetmapTileLayer UriFormat="https://tile.openstreetmap.org/{z}/{x}/{y}.png"/>-->
                <local:AMapTitleLayer/>
                <map:MapItemsControl ItemsSource="{Binding PushpinArray,RelativeSource={RelativeSource AncestorType=local:MainWindow}}">
                    <map:MapItemsControl.ItemTemplate>
                        <DataTemplate>
                            <map:Pushpin Location="{Binding Location}" Cursor="Hand" 
                                         MouseDown="Pushpin_MouseDown"
                                         ToolTip="{Binding Title}"
                                             Background="Red">
                                <TextBlock Text="{Binding ID}"/>
                            </map:Pushpin>
                        </DataTemplate>
                    </map:MapItemsControl.ItemTemplate>
                </map:MapItemsControl>
                <map:Pushpin Location="36.6797276003243,118.495410536117" Style="{StaticResource alarmStyle}"/>
                <Canvas Width="50" Height="80" 
                  map:MapLayer.Position="31.9121578992881,107.233555852083" 
                  map:MapLayer.PositionOrigin="BottomCenter" Opacity="0.7">
                    <Path Data="M 0,0 L 50,0 50,50 25,80 0,50 0,0" Fill="ForestGreen" Stroke="Wheat" StrokeThickness="2" />
                    <TextBlock FontSize="10" Foreground="White" Padding="10" TextAlignment="Center">
                            这里是 <LineBreak />
                            四川 <LineBreak />
                            通江县 <LineBreak />
                    </TextBlock>
                </Canvas>
                <map:MapLayer x:Name="CarLayer"/>
            </map:Map>
          
            <DockPanel>
                <Grid DockPanel.Dock="Top">
                    <!--<Rectangle Width="400" Height="60" RenderTransformOrigin="0.5,0.5">
                        <Rectangle.RenderTransform>
                            <SkewTransform AngleX="40"/>
                        </Rectangle.RenderTransform>
                        
                        <Rectangle.Fill>
                            <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
                                <GradientStop Color="#FF020621" Offset="0"/>
                                <GradientStop Color="#FF364BD8" Offset="1"/>
                                <GradientStop Color="#FF5A6BD8" Offset="0.499"/>
                            </LinearGradientBrush>
                        </Rectangle.Fill>
                    </Rectangle>-->
                    <Path Data="M75.811064,0 L275.81107,0 275.81107,39.999999 267.12714,39.999999 267.12798,40.000499 67.127973,40.000499 0,0.00050140842 75.811064,0.00050140842 z"
                  Width="200" Height="30" Stretch="Fill" Opacity=".8" Stroke="#FFCCFEFF" StrokeThickness="1.5" Fill="{StaticResource MainColor}">
                        <Path.RenderTransform>
                            <SkewTransform AngleX="-40"/>
                        </Path.RenderTransform>
                    </Path>
                    <TextBlock Text="预警指挥平台" Foreground="White" 
                               VerticalAlignment="Center" HorizontalAlignment="Center"
                               FontSize="16" FontWeight="Black"/>
                </Grid>
                <Grid DockPanel.Dock="Left" Width="200"
                      HorizontalAlignment="Left" >
                    <Grid.RowDefinitions>
                        <RowDefinition Height="Auto"/>
                        <RowDefinition/>
                        <RowDefinition Height="Auto"/>
                    </Grid.RowDefinitions>
                    <Rectangle Grid.RowSpan="3" Fill="#FF364BD8" Opacity=".8" Stroke="#FFCCFEFF" StrokeThickness="1.5"/>
                    <TextBlock Text="数据信息" FontSize="16" Foreground="White" Margin="10,10,0,0"/>
                    <ItemsControl ItemsSource="{Binding PushpinArray,RelativeSource={RelativeSource AncestorType=local:MainWindow}}"
                                  Margin="4,10" Grid.Row="1">
                        <ItemsControl.ItemTemplate>
                            <DataTemplate>
                                <Grid Margin="4" x:Name="PART_Grid"
                                      MouseLeftButtonDown="PART_Grid_MouseLeftButtonDown"
                                      Tag="{Binding ID}">
                                    <Grid.Resources>
                                        <Style TargetType="TextBlock">
                                            <Setter Property="Foreground" Value="White"/>
                                            <Setter Property="FontSize" Value="16"/>
    </Style>
                                    </Grid.Resources>
                                    <Grid.ColumnDefinitions>
                                        <ColumnDefinition Width="Auto"/>
                                        <ColumnDefinition/>
                                    </Grid.ColumnDefinitions>
                                    <Ellipse Width="20" Height="20" Fill="OrangeRed"/>
                                    <TextBlock Text="{Binding ID}" HorizontalAlignment="Center"/>
                                    <TextBlock Margin="4,0" Grid.Column="1" Text="{Binding Title}"/>
                                </Grid>
                                <DataTemplate.Triggers>
                                    <Trigger Property="IsMouseOver" Value="True">
                                        <Setter Property="Background" TargetName="PART_Grid" Value="#FF020621"/>
                                    </Trigger>
                                </DataTemplate.Triggers>
                            </DataTemplate>
                        </ItemsControl.ItemTemplate>
                    </ItemsControl>
                    <Button Content="物资轨迹" Click="BtnCar_Click" Grid.Row="2" Height="40"/>
                </Grid>
            </DockPanel>
        </Grid>
    </Window>

    二、MainWindow.xaml.cs代码如下:

    /**
     * 作者闫驚鏵
     * https://github.com/yanjinhuagood/WPFDevelopers.git
     * **/
    
    using Microsoft.Maps.MapControl.WPF;
    using System;
    using System.Collections;
    using System.Collections.Generic;
    using System.Collections.ObjectModel;
    using System.IO;
    using System.Linq;
    using System.Text;
    using System.Windows;
    using System.Windows.Controls;
    using System.Windows.Data;
    using System.Windows.Documents;
    using System.Windows.Input;
    using System.Windows.Media;
    using System.Windows.Media.Animation;
    using System.Windows.Media.Imaging;
    using System.Windows.Navigation;
    using System.Windows.Shapes;
    using System.Windows.Threading;
    
    /*
     * 
     * 39.0654365763652,115.513103745601,0
    38.5861378332358,114.897869370601,0
    38.0690298850334,114.238689683101,0
    37.4436424646135,113.491619370601,0
    36.8833163124675,112.832439683101,0
    36.6015984304246,112.480877183101,0
    36.2125510101126,112.041424058101,0
    
    35.6074752751952,111.426189683101,0
    
    34.9977887035825,110.591228745601,0
    34.456028305434,109.932049058101,0
    33.9836399832877,109.580486558101,0
    33.5086116028286,108.965252183101,0
    33.1046158275268,108.525799058101,0
    
    32.6617655474571,108.042400620601,0
    32.179523137361,107.515056870601,0
    
     * **/
    
    namespace WpfBingMap
    {
        /// <summary>
        /// MainWindow.xaml 的交互逻辑
        /// </summary>
        public partial class MainWindow : Window
        {
            private LocationCollection _polyLocations;
            private MapPolyline mapPolyline;
            private Pushpin carPushpin;
            private DispatcherTimer dispatcherTimer;
            private List<Location> locations;
    
            public IEnumerable PushpinArray
            {
                get { return (IEnumerable)GetValue(PushpinArrayProperty); }
                set { SetValue(PushpinArrayProperty, value); }
            }
    
            public static readonly DependencyProperty PushpinArrayProperty =
                DependencyProperty.Register("PushpinArray", typeof(IEnumerable), typeof(MainWindow), new PropertyMetadata(null));
    
    
            public MainWindow()
            {
                InitializeComponent();
                //this.map.Mode = new MercatorMode();
                //this.map.Children.Add(new AMapTitleLayer());
                //this.map.MouseDown += Map_MouseDown;
                var pushpins = new List<PushpinModel>();
                pushpins.Add(new PushpinModel { ID=1, Location = new Location(39.8151940395589, 116.411970893135),Title="和义东里社区" });
                pushpins.Add(new PushpinModel { ID = 2, Location = new Location(39.9094878843105, 116.33299936282) ,Title="中国水科院南小区"});
                pushpins.Add(new PushpinModel { ID = 3, Location = new Location(39.9219204792284, 116.203500574855),Title="石景山山姆会员超市" });
                pushpins.Add(new PushpinModel { ID = 4, Location = new Location(39.9081417418219, 116.331244439925), Title = "茂林居小区" });
                PushpinArray = pushpins;
    
                 _polyLocations = new LocationCollection();
                //_polyLocations.Add(new Location(39.9082973053021, 116.63105019548));
                //_polyLocations.Add(new Location(39.9155572462212, 116.192505993178));
                //_polyLocations.Add(new Location(39.8065773542251, 116.276113341099));
                _polyLocations.Add(new Location(39.9082973053021, 116.63105019548));
                _polyLocations.Add(new Location(31.9121578992881, 107.233555852083));
    
                mapPolyline = new MapPolyline 
                {
                    Stroke = Brushes.Green,
                    StrokeThickness = 2,
                    Locations = _polyLocations,
                };
                CarLayer.Children.Add(mapPolyline);
    
                carPushpin = new Pushpin
                {
                    Template = this.Resources["CarTemplate"] as ControlTemplate,
                    //Location = new Location(39.9082973053021, 116.63105019548),//_polyLocations[0],
                    Location = new Location(31.9121578992881, 107.233555852083),
                    PositionOrigin = PositionOrigin.Center,
                };
               
                CarLayer.Children.Add(carPushpin);
    
                dispatcherTimer = new DispatcherTimer();
                dispatcherTimer.Interval = TimeSpan.FromSeconds(1.5);
                dispatcherTimer.Tick += DispatcherTimer_Tick;
                
            }
            int index = 0;
            private void DispatcherTimer_Tick(object sender, EventArgs e)
            {
                //carPushpin.Location = carPushpin.Location
                //var currtLocation = carPushpin.Location;
                //if (currtLocation == _polyLocations[1])
                //{
                //    dispatcherTimer.Stop();
                //    return;
                //}
    
                //currtLocation.Longitude = currtLocation.Longitude - 0.233555852083;
                //currtLocation.Latitude = currtLocation.Latitude - 0.9121578992881;
                //map.Center = currtLocation;
                //map.ZoomLevel = 16;
                if (index < 0)
                {
                    index = locations.Count - 1;
                    dispatcherTimer.Stop();
                    return; 
                }
                carPushpin.Location = locations[index];
                index--;
                //map.Center = carPushpin.Location;
            }
    
            private void BtnCar_Click(object sender, RoutedEventArgs e)
            {
                locations = new List<Location>();
                locations.Add(new Location(39.9082973053021, 116.63105019548));
                locations.Add(new Location(39.0654365763652, 115.513103745601));
                locations.Add(new Location(38.5861378332358, 114.897869370601));
                locations.Add(new Location(38.0690298850334, 114.238689683101));
                locations.Add(new Location(37.4436424646135, 113.491619370601));
                locations.Add(new Location(36.8833163124675, 112.832439683101));
                locations.Add(new Location(36.6015984304246, 112.480877183101));
                locations.Add(new Location(36.2125510101126, 112.041424058101));
                locations.Add(new Location(35.6074752751952, 111.426189683101));
                locations.Add(new Location(34.9977887035825, 110.591228745601));
                locations.Add(new Location(34.456028305434, 109.932049058101));
                locations.Add(new Location(33.9836399832877, 109.580486558101));
                locations.Add(new Location(33.5086116028286, 108.965252183101));
                locations.Add(new Location(33.1046158275268, 108.525799058101));
                locations.Add(new Location(32.6617655474571, 108.042400620601));
                locations.Add(new Location(32.179523137361, 107.515056870601));
                locations.Add(new Location(31.9121578992881, 107.233555852083));
                index = locations.Count - 1;
                dispatcherTimer.Start();
                //var tt = Enumerable.Range((int)_polyLocations[1].Latitude, (int)_polyLocations[0].Latitude).ToList();
                //for (int i = 0; i < tt.Count(); i++)
                //{
                //    Console.WriteLine(tt[i]);
                //}
    
            }
            private void Map_MouseDown(object sender, MouseButtonEventArgs e)
            {
                Point mousePosition = e.GetPosition(this);
                Location pinLocation = this.map.ViewportPointToLocation(mousePosition);
                
                Console.WriteLine(pinLocation);
    
            }
    
            private void Pushpin_MouseDown(object sender, MouseButtonEventArgs e)
            {
                var model = sender as Pushpin;
                map.Center = model.Location;
                map.ZoomLevel = 16;
            }
    
            private void PART_Grid_MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
            {
                var grid = sender as Grid;
                var model = PushpinArray.OfType<PushpinModel>().FirstOrDefault(x=>x.ID.Equals(grid.Tag));
                map.Center = model.Location;
                map.ZoomLevel = 16;
            }
    
           
        }
        public class PushpinModel
        {
            public Location Location { get; set; }
            public int ID { get; set; }
            public string Title { get; set; }
        }
        //public class OpenstreetmapTileSource: TileSource
        //{
        //    public override Uri GetUri(int x, int y, int zoomLevel)
        //    {
        //        //var url = string.Format("https://www.openstreetmap.org/#map={z}/{x}/{y}",zoomLevel,x,y);
        //        //return new Uri(url, UriKind.Absolute);
        //        var uri= new Uri(UriFormat.
        //                   Replace("{x}", x.ToString()).
        //                   Replace("{y}", y.ToString()).
        //                   Replace("{z}", zoomLevel.ToString()));
        //        Console.WriteLine(uri);
        //        return uri;
        //    }
        //}
        //public class OpenstreetmapTileLayer : MapTileLayer 
        //{
        //    public OpenstreetmapTileLayer()
        //    {
        //        TileSource = new OpenstreetmapTileSource();
        //    }
    
        //    public string UriFormat
        //    {
        //        get { return TileSource.UriFormat; }
        //        set { TileSource.UriFormat = value; }
        //    }
        //}
        public class AMapTitleLayer : MapTileLayer
        {
            public AMapTitleLayer()
            {
                TileSource = new AMapTileSource();
            }
    
            public string UriFormat
            {
                get { return TileSource.UriFormat; }
                set { TileSource.UriFormat = value; }
            }
        }
        public class AMapTileSource: TileSource
        {
            public override Uri GetUri(int x, int y, int zoomLevel)
            {
                //string url = "https://webrd01.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=8&x=" + x + "&y=" + y + "&z=" + zoomLevel;
                //https://www.amap.com/service/regeo?longitude=115.975052&latitude=39.778747
                //string url = "https://wprd01.is.autonavi.com/appmaptile?x=" + x + "&y=" + y + "&z=" + zoomLevel + "&lang=zh_cn&size=1&scale=1&style=8";
                string url = string.Format("http://wprd01.is.autonavi.com/appmaptile?x={0}&y={1}&z={2}&lang=zh_cn&size=1&scl=1&style=7",x,y,zoomLevel);
                return new Uri(url, UriKind.Absolute);
            }
        }
    
    
    }

     更多教程欢迎关注微信公众号:

    WPF开发者QQ群: 340500857 

    blogs: https://www.cnblogs.com/yanjinhua/p/14345136.html

    源码Github:https://github.com/yanjinhuagood/WPFDevelopers.git

    作者:驚鏵

  • 相关阅读:
    Go语言学习资源
    优秀编程学习网站
    我对架构的理解
    【转】TCP协议中的三次握手和四次挥手(图解)
    【转】asp.net c# 网上搜集面试题目大全(附答案)
    spring framework 4 源码阅读
    浮点类型
    把二元查找树转变成排序的双向链表
    用模板写快速排序-链表
    用模板写快速排序-数组
  • 原文地址:https://www.cnblogs.com/yanjinhua/p/14809674.html
Copyright © 2020-2023  润新知