Windows Phone 7.5 & Bing!
2011年7月末、
今回紹介している内容は、
Windows PhoneのBing検索
Windows Phoneには検索ボタンがあり、
data:image/s3,"s3://crabby-images/1fb6a/1fb6adbb63cb1243617a5004221d06579bbd72f1" alt="図1 Bing検索 図1 Bing検索"
Windows Phone 7.
- 音声による検索
- カメラによるQRコードやバーコードの読み取り、
CDやDVDのジャケットの読み取り - OCRによるテキストの翻訳と検索
- 鼻歌など音声による音楽の検索
- 周辺施設の検索
(Bing Maps連携機能)
Windows Phone 7.
図2は、
data:image/s3,"s3://crabby-images/408b0/408b0a0a7dec96e5da1d90ff3a03d64c6aad681b" alt="図2 QRコードの読み取り 図2 QRコードの読み取り"
テキストの翻訳・
data:image/s3,"s3://crabby-images/27f09/27f09117e3a9d81ef12fec80f23a6d089ae0a347" alt="図3 OCRによる翻訳と検索 図3 OCRによる翻訳と検索"
Windows PhoneのBing Maps
Windows Phoneには、
地図の表示や検索に加えて搭載された機能は次のものがあります。
- 音声による検索
- GPSナビゲーション
- 交通情報の表示
- 電話の向きに合わせて地図の回転
- お気に入りの場所の登録、
タイルへの表示 - 周辺施設の検索
現時点では、
乗り換え案内については、
Bing検索アプリの開発
さて、
Bing APIはWindows PhoneやSilverlightなどに依存したAPIではないため、
サービス参照の追加で次のアドレスを入力します
- http://
api. bing. net/ search. wsdl?AppID=BingAppId&Version=2. 2
data:image/s3,"s3://crabby-images/0059c/0059c97934692b69355868080593856e885d31e4" alt="図4 サービス参照の追加 図4 サービス参照の追加"
デザイナ画面でXAMLを次のように編集します。検索用のTextBoxとButton、
<Grid x:Name="LayoutRoot" Background="Transparent">
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28">
<TextBlock x:Name="ApplicationTitle" Text="MY APPLICATION" Style="{StaticResource PhoneTextNormalStyle}"/>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition />
<ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions>
<TextBox x:Name="QueryTextBox" />
<Button Grid.Column="1" Content="Search" Click="Button_Click" />
</Grid>
</StackPanel>
<Grid x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
<ListBox x:Name="ResultListBox" />
</Grid>
</Grid>
C#のコードは次のように記述します。今回は、
// (追加する using ステートメント)
// using BingSearch.ServiceReference1; // BingSearch はプロジェクト名から付いた名前空間
private void Button_Click(object sender, RoutedEventArgs e)
{
var client = new BingPortTypeClient();
client.SearchCompleted += (s, args) =>
{
if (args.Error != null) return;
Dispatcher.BeginInvoke(() =>
{
foreach (var r in args.Result.Web.Results)
{
ResultListBox.Items.Add(r.Title);
}
});
};
client.SearchAsync(new SearchRequest()
{
Sources = new SourceType[] {SourceType.Web},
Query = QueryTextBox.Text,
AppId = "50A2BBFB359B16A9DBAD771F89943BF54A5F7384",
Version = "2.2",
Market = "ja-jp"
});
}
実行結果は図5のようになります。
data:image/s3,"s3://crabby-images/2fcbf/2fcbfe699b8b4ffb60583661545fe0cd510bf477" alt="図5 Webの検索 図5 Webの検索"
Webサービスの参照を利用した場合、
Bing APIについては第19回と20回でも紹介しています。興味のある方はこちらも参照してみてください。
Bing APIでは、
地図アプリの開発
Windows Phone 7の地図関連の開発をみてみましょう。Windows Phone 7には、
また、
開発環境も強化されています。Windows Phone 7のエミュレーターで現在地を設定でき、
data:image/s3,"s3://crabby-images/9e488/9e48884101feb9c58f3685ed51303c2399217c40" alt="図6 現在地の設定 図6 現在地の設定"
Windows Phoneでは、
地図の表示
Maps Controlの基本的な使い方を紹介します。Visual StudioでWindows Phoneアプリケーション プロジェクトを作成し、
data:image/s3,"s3://crabby-images/5727a/5727ae88788361a1f00d68c09167a4c589d1a5be" alt="図7 Maps Controlの貼り付け 図7 Maps Controlの貼り付け"
XAMLのコードを少し編集して次のようにします。上図は既に変更しています。
<my:Map Name="MyMap" CredentialsProvider="BingMapsKey" />
BingMapsKeyのところは、
地図の表示は以上です。実行するとBing Mapsを操作できます。
表示する位置やズームレベルの変更は、
<my:Map Name="MyMap" CredentialsProvider="BingMapsKey"
Center="35.68,139.767"
ZoomLevel="16" />
結果は図8のようになります。
data:image/s3,"s3://crabby-images/c4ff2/c4ff26a92182954698646fe0448a9107fe3a447e" alt="図8 地図の表示 図8 地図の表示"
SetViewメソッドを使用した例を示します。またコードでは、
// (追加する using ステートメント)
using Microsoft.Phone.Controls.Maps;
using System.Device.Location;
public partial class MainPage : PhoneApplicationPage
{
private GeoCoordinateWatcher GeoCoordinateWatcher;
public MainPage()
{
InitializeComponent();
// 現在地に移動
this.GeoCoordinateWatcher = new GeoCoordinateWatcher();
GeoCoordinateWatcher.PositionChanged += (s, e) =>
{
MyMap.SetView(e.Position.Location, MyMap.ZoomLevel);
};
GeoCoordinateWatcher.Start();
}
}
プッシュピンの表示
次はプッシュピンを追加してみましょう。XAMLで記述する場合は次のようになります。
<my:Map Name="MyMap" CredentialsProvider="BingMapsKey">
<my:Pushpin Location="35.68,139.767">
<TextBlock Text="東京駅" Margin="3" />
</my:Pushpin>
</my:Map>
C#コードから追加すると次のようになります。
// (追加する using ステートメント)
// using Microsoft.Phone.Controls.Maps;
// using System.Device.Location;
public MainPage()
{
InitializeComponent();
var pin = new Pushpin();
pin.Location = new GeoCoordinate(35.68, 139.767);
pin.Content = new TextBlock() { Text = "東京駅", Margin = new Thickness(3) };
MyMap.Children.Add(pin);
}
実行結果は図9のようになります。Windows PhoneのMaps Controlのプッシュピンは、
data:image/s3,"s3://crabby-images/f7a77/f7a7769ea2277250f722a8e9cea42d3778a54d4f" alt="図9 プッシュピンの表示 図9 プッシュピンの表示"
プッシュピンの中は自由にSilverlightのコントロールを自由に追加できます。MediaElementを使用して動画の表示も簡単です
<my:Map Name="MyMap" CredentialsProvider="BingMapsKey"
ZoomLevel="16"
Center="35.807564,137.243">
<my:Pushpin Location="35.807564,137.241769">
<MediaElement Source="sample.mp4" Width="240" />
</my:Pushpin>
</my:Map>
data:image/s3,"s3://crabby-images/e13cf/e13cfb1faf55570b3b53f310f4bde39de7ad46dd" alt="図10 動画の表示 図10 動画の表示"
添付プロパティを使用すれば、
<my:Map Name="MyMap" CredentialsProvider="BingMapsKey">
<Image Source="http://ecn.dev.virtualearth.net/mapcontrol/v7.0/i/poi_search.png"
my:MapLayer.PositionOrigin="BottomCenter"
Width="25" Height="39"
xmlns:loc="clr-namespace:System.Device.Location;assembly=System.Device">
<my:MapLayer.Position>
<loc:GeoCoordinate Latitude="35.807564" Longitude="137.241769" />
</my:MapLayer.Position>
</Image>
</my:Map>
結果は図11のようになります。
data:image/s3,"s3://crabby-images/9e715/9e7150df1144c6106051b3025228e2abf3bb0c4b" alt="図11 カスタムプッシュピンの表示 図11 カスタムプッシュピンの表示"
ポリゴン・ポリラインの表示
領域を表すポリゴン
var locations = new LocationCollection() {
new GeoCoordinate(38.22912, 137.6954),
new GeoCoordinate(35.16438, 135.9376),
new GeoCoordinate(36.18178, 135.6080),
new GeoCoordinate(36.18178, 135.6080),
new GeoCoordinate(35.36173, 136.9483),
new GeoCoordinate(35.16438, 135.9376)
};
var polyline = new MapPolyline()
{
Locations = locations,
Stroke = new SolidColorBrush(Colors.Red),
StrokeThickness = 5
};
MyMap.Children.Add(polyline);
実行結果は図12のようになります。
data:image/s3,"s3://crabby-images/99672/996728c0ea00a54e7cafc8191617c6a9708ce9a7" alt="図12 ポリラインの表示 図12 ポリラインの表示"
グラデーション表示や線の太さや点線などの指定も簡単です。
var locations = new LocationCollection() {
new GeoCoordinate(33.52262688242687,132.268200096829),
new GeoCoordinate(34.43365078432897,134.223766503079),
new GeoCoordinate(33.637037915415036,134.6137811515165),
new GeoCoordinate(32.791436727932236,132.7570916983915)
};
var gss = new GradientStopCollection() {
new GradientStop() { Color = Colors.Red, Offset = 0 },
new GradientStop() { Color = Colors.Orange, Offset = 0.2 },
new GradientStop() { Color = Colors.Yellow, Offset = 0.4 },
new GradientStop() { Color = Colors.Green, Offset = 0.6 },
new GradientStop() { Color = Color.FromArgb(255, 0, 0, 0x80), Offset = 0.8 },
new GradientStop() { Color = Colors.Purple, Offset = 1 }
};
var brush = new LinearGradientBrush(gss, 0);
var doubles = new DoubleCollection() { 0.5, 1, 0.5, 1 };
var polygon = new MapPolygon()
{
Locations = locations,
Fill = brush,
StrokeDashArray = doubles,
Stroke = new SolidColorBrush(Colors.Red),
StrokeThickness = 5,
Opacity = 0.7
};
MyMap.Children.Add(polygon);
実行結果は図13のようになります。
data:image/s3,"s3://crabby-images/77f1f/77f1ff075a5e7f270066491e9fb20db45fd45c26" alt="図13 ポリゴンの表示 図13 ポリゴンの表示"
表示の切り替え
Maps Controlでは、
地図の種類はMapクラスのModeプロパティで指定します。XAMLの場合はRoadまたはAerialを指定します。
<my:Map Name="MyMap" CredentialsProvider="BingMaps"
Mode="Aerial" />
コードで記述する場合は、
MyMap.Mode = new RoadMode(); // または AerialMode ()
注目するところは、
MapModeクラスから派生したFlatMapModeやMercatorModeクラスを使用すれば、
タイルの変更
地図を構成するタイルを変更または重ね合わせも可能です。独自のタイルを追加するには次のように記述します。
var tileLayer = new MapTileLayer();
var ts = new TileSource("http://tohoku.blob.core.windows.net/layer00/{quadkey}.png");
tileLayer.TileSources.Add(ts);
MyMap.Children.Add(tileLayer);
MyMap.SetView(new GeoCoordinate(38.2732865155, 141.0216306495), 17);
実行結果は図14のようになります。サンプルでは、
data:image/s3,"s3://crabby-images/09e6f/09e6f5a497fa5aec72ce754ad732d82c389e8288" alt="図14 カスタムタイルの表示 図14 カスタムタイルの表示"
Bing Maps AJAX Controlで実現したものは、 http://
上記コードは、
また、
MyMap.Mode = new Microsoft.Phone.Controls.Maps.Core.MercatorMode();
Bing Maps AJAX Controlの利用
さて、
data:image/s3,"s3://crabby-images/c3d22/c3d22f912e96fafb421ba87fa1506b1dbb9cd9d3" alt="図15 Bing Maps AJAX Controlの表示 図15 Bing Maps AJAX Controlの表示"
ただし、
おわりに
今回は以上です。いかがでしたでしょうか。Windows Phone 7.
Windows Phoneによる開発は、