Windows Phone 7.5 & Bing!
2011年7月末、
今回紹介している内容は、
Windows PhoneのBing検索
Windows Phoneには検索ボタンがあり、
data:image/s3,"s3://crabby-images/4c20e/4c20e0d1642ff2461848488cbd382ee697258c33" alt="図1 Bing検索 図1 Bing検索"
Windows Phone 7.
- 音声による検索
- カメラによるQRコードやバーコードの読み取り、
CDやDVDのジャケットの読み取り - OCRによるテキストの翻訳と検索
- 鼻歌など音声による音楽の検索
- 周辺施設の検索
(Bing Maps連携機能)
Windows Phone 7.
図2は、
data:image/s3,"s3://crabby-images/3698c/3698cff8440cafc88da94000bacd21ac83333311" alt="図2 QRコードの読み取り 図2 QRコードの読み取り"
テキストの翻訳・
data:image/s3,"s3://crabby-images/f98c3/f98c318de7c2b27d577d3537e3c68439bd0e1547" 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/8ad84/8ad849cbff4336b11e38e162c39ad8e9043aeebe" 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/49b12/49b1286c28acd56867f4f8d8498533804ff2538b" 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/97ba4/97ba483df2e9ac3f994a52e0c09fd8ff4ec04955" alt="図6 現在地の設定 図6 現在地の設定"
Windows Phoneでは、
地図の表示
Maps Controlの基本的な使い方を紹介します。Visual StudioでWindows Phoneアプリケーション プロジェクトを作成し、
data:image/s3,"s3://crabby-images/603d3/603d33519f31697a07c98aa1ae4b6468427e7219" 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/4ceed/4ceed2a0dc7925926ff6feab83e79f7fdfaf2385" 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/7bcf8/7bcf8f82d07036f732157e08ae634b73ee30b214" 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/2b93b/2b93b8637594c8ff37e0ea64a45272e577895548" 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/396d1/396d1229ec487a55f90da393a506eef59f1a335b" 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/97ffb/97ffb9ae53d3d0599639409aff5565f392fa2f4e" 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/c989f/c989f6c2571029ac9fa7712069de9f38f14eac3e" 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/b1003/b1003981086cae673778cdbfa9d4409666b97c0b" 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/7e66e/7e66e12d67a7e35e835626821a8b9645ef02753f" alt="図15 Bing Maps AJAX Controlの表示 図15 Bing Maps AJAX Controlの表示"
ただし、
おわりに
今回は以上です。いかがでしたでしょうか。Windows Phone 7.
Windows Phoneによる開発は、