Thursday, January 19, 2012

Use the Bing Maps Silverlight Control for Windows Phone(Source MSDN)

  1. Make sure you have downloaded and installed the Windows Phone SDK from the App Hub.
  2. Launch Visual Studio 2010 Express for Windows Phone from the Windows Start menu.
  3. Create a new project by clicking the File | New Project menu command.
  4. The New Project window will be displayed. Expand the Visual C# templates, and then select the Silverlight for Windows Phone templates.
  5. Select the Windows Phone Application template. Fill in the project Name as desired.
  6. Click OK. A new project will be created and MainPage.xaml will be opened in the Visual Studio designer window.
The next step is to lay out the controls of the application using the Visual Studio designer. After adding the controls, the final layout will look similar to the following screenshot:
MapLayout

To add the controls of the application


  1. In the Toolbox in Visual Studio, select the Map control. Create a new Map control on the designer. The default name of the control will be map1.
  2. In the Toolbox in Visual Studio, select the Button control. Create four new Button controls on the designer below the Map control. Set the text in the four buttons to beRoad ModeAerial ModeZoom In, and Zoom Out. Name the four buttons buttonRoadbuttonAerialbuttonZoomIn, and buttonZoomOut.
            <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
                <my:Map Height="462" HorizontalAlignment="Left" Margin="6,6,0,0" Name="map1" VerticalAlignment="Top" Width="444" />
    
                <Button Content="Road Mode" Height="72" HorizontalAlignment="Left" Margin="6,474,0,0" Name="buttonRoad" VerticalAlignment="Top" Width="207" />
                <Button Content="Aerial Mode" Height="72" HorizontalAlignment="Left" Margin="243,474,0,0" Name="buttonAerial" VerticalAlignment="Top" Width="207" />
                <Button Content="Zoom In" Height="72" HorizontalAlignment="Left" Margin="6,535,0,0" Name="buttonZoomIn" VerticalAlignment="Top" Width="207" />
                <Button Content="Zoom Out" Height="72" HorizontalAlignment="Left" Margin="243,535,0,0" Name="buttonZoomOut" VerticalAlignment="Top" Width="207" />
            </Grid>
    
    
    
  3. If you want the exact same layout shown in the image, copy and paste the XAML above and use it to replace the grid layout in your MainPage.xaml file.
  4. You can also rename the application window titles as you desire.
This step will add the code to implement the four buttons.

To add code

  1. Add a using statement for using Microsoft.Phone.Controls.Maps; in the MainPage.xaml.cs file.
  2. Double-click the Road Mode button control. This will create a buttonRoad_Click event handler in the MainPage.xaml.cs file. Implement the method by setting the mode:
            private void buttonRoad_Click(object sender, RoutedEventArgs e)
            {
                map1.Mode = new RoadMode();
            }
    
    
  3. Double-click the Aerial Mode button control. This will create a buttonAerial_Click event handler in the MainPage.xaml.cs file. Implement the method by setting the mode:
            private void buttonAerial_Click(object sender, RoutedEventArgs e)
            {
                map1.Mode = new AerialMode();
            }
    
    
  4. Double-click the Zoom In button control. This will create a buttonZoomIn_Click event handler in the MainPage.xaml.cs file. Implement the method by setting the zoom value:
            private void buttonZoomIn_Click(object sender, RoutedEventArgs e)
            {
                double zoom;
                zoom = map1.ZoomLevel;
                map1.ZoomLevel = ++zoom;
            }
    
    
  5. Double-click the Zoom Out button control. This will create a buttonZoomOut_Click event handler in the MainPage.xaml.cs file. Implement the method by setting the zoom value:
            private void buttonZoomOut_Click(object sender, RoutedEventArgs e)
            {
                double zoom;
                zoom = map1.ZoomLevel;
                map1.ZoomLevel = --zoom;
            }
    
    
  6. The XAML for the buttons will be updated to include the event handlers:
            <Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
                <my:Map Height="462" HorizontalAlignment="Left" Margin="6,6,0,0" Name="map1" VerticalAlignment="Top" Width="444" />
                <Button Content="Zoom In" Height="72" HorizontalAlignment="Left" Margin="6,535,0,0" Name="buttonZoomIn" VerticalAlignment="Top" Width="207" Click="buttonZoomIn_Click" />
                <Button Content="Road Mode" Height="72" HorizontalAlignment="Left" Margin="6,474,0,0" Name="buttonRoad" VerticalAlignment="Top" Width="207" Click="buttonRoad_Click" />
                <Button Content="Zoom Out" Height="72" HorizontalAlignment="Left" Margin="243,535,0,0" Name="buttonZoomOut" VerticalAlignment="Top" Width="207" Click="buttonZoomOut_Click" />
                <Button Content="Aerial Mode" Height="72" HorizontalAlignment="Left" Margin="243,474,0,0" Name="buttonAerial" VerticalAlignment="Top" Width="207" Click="buttonAerial_Click" />
            </Grid>
    

The application is now complete. This step will let you build, run, and debug the application.
MapRunning


To build and debug the application

  1. Build the solution by selecting the Debug | Build Solution menu command. The project should build without any errors in the Error List window. You can open the Error List window, if it is not already open, by selecting the View | Other Windows | Error List menu command. If there are errors, review the steps above, correct any errors, and then build the solution again.
  2. Run the application by selecting the Debug | Start Debugging menu command. This will open the emulator window and launch the application. Make sure that your desktop computer has Internet access. You can then test your application by clicking the buttons and verifying that map control responds.
  3. You can set debug breakpoints in the code by placing the cursor on the desired line of code and selecting the Debug | Toggle Breakpoint menu command.
  4. To stop debugging, you can select the Debug | Stop Debugging menu command.


4 comments:

  1. can i colored any part from this map?

    ReplyDelete
    Replies
    1. Check out this...

      http://msdn.microsoft.com/en-us/library/aa940991.aspx

      Delete
  2. http://social.msdn.microsoft.com/Forums/en/vemapcontroldev/thread/c2b47a99-6472-49e2-8bf9-1bd17bbea967

    ReplyDelete

Thank you for Commenting Will reply soon ......

Featured Posts

Installing And Exploring Auto Dark Mode Software

Windows Auto--Night--Mode: Simplify Your Theme Switching   Windows Auto--Night--Mode is a free and lightweight tool that makes switching bet...