Monday, May 31, 2010

Creating a Basic Application Using the Silverlight Map Control





Create a Silverlight Project

To begin, create a Silverlight project in Visual Studio.
  1. Open Visual Studio 2008.
  2. Select File the main menu.
  3. Select New, and then Project from the menu.
  4. In the New Project dialog box, under the language of your choice (for example, Visual C#), select Silverlight.
  5. Select a Silverlight Application from the available templates and then click OK.
    clip_image002
  6. When asked, make sure the Host the Silverlight application in a new Web site option is checked. Because of URL access restrictions in Silverlight, your Web page must be hosted using the HTTP scheme for it to be able to access Bing Maps tiles. For more information about Silverlight URL access restrictions, see http://msdn.microsoft.com/en-us/library/cc189008(VS.95).aspx.
    clip_image003
Display a Map

Next, reference the map control dlls in your project and display the default map in your application.
  1. With the Silverlight project selected (not the Web project), select Project then Add Reference from the Visual Studio main menu.
  2. In the Add Reference dialog box, click the Browse tab.
  3. Browse to the location of your Bing Maps Silverlight Control installation. Open the Libraries folder, select the Microsoft.Maps.MapControl.dll and the Microsoft.Maps.MapControl.Common.dll files and click OK.
  4. Add the map control assembly to MainPage.xaml of your Silverlight project by creating a namespace in your UserControl. The MainPage.xaml now looks like this:
<UserControl x:Class="SilverlightApplication1.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:m="clr-namespace:Microsoft.Maps.MapControl;assembly=Microsoft.Maps.MapControl">
<Grid x:Name="LayoutRoot">
</Grid>
</UserControl>
  1. Once the map control assembly is referenced, then you can add the map element <m:Map/> to your page. Put this element within the Grid.
  2. To authenticate your use of the map control, you also need to set credentials. To do this, add a CredentialsProvider attribute to the <m:Map/> element. Set the CredentialsProvider attribute to the Bing Maps Key that you obtained from the Bing Maps Account Center. Your final MainPage.xaml looks like this:
<UserControl x:Class="SilverlightApplication1.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:m="clr-namespace:Microsoft.Maps.MapControl;assembly=Microsoft.Maps.MapControl">
<Grid x:Name="LayoutRoot">
<m:Map CredentialsProvider="your key"/>
</Grid>
</UserControl>
  1. Run your Silverlight Map Control application to display a default map.
Change the Map Mode using XAML

To customize the map or other UIElements, you can set properties in your MainPage.xaml file.
  1. To change the mode, or style, of the map, set the Mode of the map element to “Aerial”. Your MainPage.xaml now looks like this:
<UserControl x:Class="SilverlightApplication1.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:m="clr-namespace:Microsoft.Maps.MapControl;assembly=Microsoft.Maps.MapControl">
<Grid x:Name="LayoutRoot" Background="White">
<m:Map CredentialsProvider="your key" Mode="Aerial" />
</Grid>
</UserControl>
Now run your project to see the map in Aerial mode.
Change the Map Mode using C#

Alternatively you can use Visual C# to change the map mode.
  1. Start by giving your map element a name so that you can access this element from within C#. Your MainPage.xaml will look like this:
<UserControl x:Class="SilverlightApplication1.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:m="clr-namespace:Microsoft.Maps.MapControl;assembly=Microsoft.Maps.MapControl">
<Grid x:Name="LayoutRoot" Background="White">
<m:Map CredentialsProvider="your key" Name="myMap" />
</Grid>
</UserControl>
  1. Then in your MainPage.xaml.cs file, reference the map control namespace with a using statement.
  2. Finally, set the map mode when the MainPage is constructed. Your MainPage.xaml.cs file now looks like:
using System.Windows.Controls;
using Microsoft.Maps.MapControl;
namespace SilverlightApplication1
{
public partial class MainPage : UserControl
{
public MainPage()
{
InitializeComponent();
myMap.Mode = new AerialMode();
}
}
}
  1. Now run your project to see the map in Aerial mode.

You can download sample application Click here

No comments:

Post a Comment