はじめに
RTWのリリース後、
Windows Mobile 6.
RTWからの新しいコントロール「Bing Maps」
さて、
実際にVisual Studio上からの操作に入る前に、
data:image/s3,"s3://crabby-images/ea809/ea809d2beedbcea89b7ed208a5224a5e50bd015d" alt="図1 エラーが表示されたBing Maps 図1 エラーが表示されたBing Maps"
Bing Maps Keyを取得する
Bing Mapsの利用にはKeyが必要になりますので、
data:image/s3,"s3://crabby-images/a3604/a3604c62838ad57f0f5036e63bb92a313e8244bc" alt="図2 既にWindows Live IDがある場合は「Sing in」を 図2 既にWindows Live IDがある場合は「Sing in」を"
必要事項を明記のうえ、
data:image/s3,"s3://crabby-images/63b2a/63b2a068c1a7e403c1890d0941f4582c27f5572f" alt="図3 Mapsアカウントの作成 図3 Mapsアカウントの作成"
アカウントの作成が問題なく完了すると、
data:image/s3,"s3://crabby-images/01327/01327de6a9135f2da9244cd4d91eb4f7018131f1" alt="図4 アカウントの詳細情報 図4 アカウントの詳細情報"
左端にあるメニューの中から
data:image/s3,"s3://crabby-images/6ad1c/6ad1c2acfd7061389a683b849c6e5472167c881a" alt="図5 「Create or view keys」をクリックします 図5 「Create or view keys」をクリックします"
過去にBing Maps Keyを発行したアプリについても情報が記載されています。今回は新しくKeyを作成しましょう。
data:image/s3,"s3://crabby-images/33571/335714de44475753bf361f4751e641080085f4f2" alt="図6 Bing Maps Keyの発行 図6 Bing Maps Keyの発行"
こちらもキーの作成が問題なく完了すると、
data:image/s3,"s3://crabby-images/168a9/168a98db2962410c24c1244ad1f0d98f78fea4d2" alt="図7 Bing Maps Keyが表示されます 図7 Bing Maps Keyが表示されます"
Bing Maps Sampleアプリを作ってみよう
ツールバーの
ToolboxからMapコントロールを選び、
<!--ContentPanel - place additional content here-->
<Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
<my:Map Height="596" HorizontalAlignment="Left"
Margin="0,6,0,0" Name="map1"
VerticalAlignment="Top" Width="450" />
</Grid>
CredentialsProviderプロパティに先ほど取得したBing Maps Keyを入れてください。
<!--ContentPanel - place additional content here-->
<Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
<my:Map Height="596" HorizontalAlignment="Left"
Margin="0,6,0,0" Name="map1"
VerticalAlignment="Top" Width="450"
CredentialsProvider="【Bing Maps Keyを入れる】" />
</Grid>
さてアプリを実行してみましょう。エラーが消えているのが確認できましたでしょうか。
data:image/s3,"s3://crabby-images/9da0f/9da0f3e94061a836f16353f1501112e27c711806" alt="図8 図8"
位置座標を設定して表示する
大阪駅を中心に表示させてみましょう。大阪駅の位置は大ざっぱですが、
data:image/s3,"s3://crabby-images/278f5/278f5cb2eecc9cf5c1d4706a0cc879e35328a707" alt="図9 プロパティウィンドウで設定を行う 図9 プロパティウィンドウで設定を行う"
コードから動的に場所を変更したい場合は、
// for location
using System.Device.Location;
マップのLoadedイベントで、
private void map1_Loaded(object sender, RoutedEventArgs e)
{
map1.Center = new GeoCoordinate(34.701189, 135.496016);
}
航空写真モードで表示する
Mapコントロールに対する操作を行うため、
一つ目のIconButtonでは地図の表示モードを
<phone:PhoneApplicationPage.ApplicationBar>
<shell:ApplicationBar IsVisible="True" IsMenuEnabled="True">
<shell:ApplicationBarIconButton
IconUri="/Images/icon.png"
Click="btnRoadMode_Click" Text="地図" />
<shell:ApplicationBarIconButton
IconUri="/Images/icon.png"
Click="btnAerialMode_Click" Text="写真" />
</shell:ApplicationBar>
</phone:PhoneApplicationPage.ApplicationBar>
ソースコードのほうに、
表示モードを地図にするにはRoadModeのインスタンスを設定します。
private void btnRoadMode_Click(object sender, EventArgs e)
{
map1.Mode = new Microsoft.Phone.Controls.Maps.RoadMode();
}
data:image/s3,"s3://crabby-images/8bdf9/8bdf9a84259279d12e5e48cee52a6873a97e535e" alt="図10 地図の表示モード 図10 地図の表示モード"
航空写真で表示するには、
private void btnAerialMode_Click(object sender, EventArgs e)
{
map1.Mode = new Microsoft.Phone.Controls.Maps.AerialMode();
}
data:image/s3,"s3://crabby-images/9ddab/9ddabe97a1a4bc0ddaa81b4b402d9e26033fe68d" alt="図11 航空写真の表示モード 図11 航空写真の表示モード"
さいごに
Bing Mapsコントロールを使って、
次回は、
以上で今回は終わりです。ありがとうございました。