新しいBing Maps
2010年11月、
まず、
data:image/s3,"s3://crabby-images/b14b8/b14b825c483f9bc6504804f7b59d35b51ff60663" alt="図1 Bing Maps 図1 Bing Maps"
これまでは、
また、
data:image/s3,"s3://crabby-images/5d05f/5d05fbe4b6934b0ce95d72dd47cc803aaa6b5aba" alt="図2 Bing Maps 3D 図2 Bing Maps 3D"
Silverlight版とAjax版を実際に使用して比べると、
Bing Maps AJAX Control 7.0
Bing Maps AJAX Controlは、
Version 6.
- ダッシュボードの変更 および
- 道路地図のタイル画像の変更
があります。デザインについては新しいBing Mapsで既に述べたとおりです。
data:image/s3,"s3://crabby-images/51c5b/51c5b5bd02f84a5fd17f5b87cf83b1f0841fa746" alt="図3 Bing Maps AJAX Control 7.0 図3 Bing Maps AJAX Control 7.0"
data:image/s3,"s3://crabby-images/bd09e/bd09ef20add0e09255a3c7d2f2b8d3436aff512e" alt="図4 Bing Maps AJAX Control 6.3 図4 Bing Maps AJAX Control 6.3"
さらに次の変更も行われています。
- パフォーマンスの改善
(3倍高速に、 ダウンロードサイズは1/ 3に) - Bird’s eye
(概観図) (図5) の改善 - iPhoneのWebブラウザーサポート
data:image/s3,"s3://crabby-images/a3ae7/a3ae768f9677462990a53923ccf87596e51664f6" alt="図5 Bird’s eye(概観図) 図5 Bird’s eye(概観図)"
そして開発者視点での大きな変更として、
Webページに地図を貼る
さて、
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Sample</title>
<script type="text/javascript" src="http://ecn.dev.virtualearth.net/mapcontrol/mapcontrol.ashx?v=7.0&mkt=ja-jp"></script>
<script type="text/javascript">
function GetMap() {
var options = {
credentials: "BingMapsKey",
mapTypeId: Microsoft.Maps.MapTypeId.road,
center: new Microsoft.Maps.Location(45.5, -122.5),
zoom: 6}
var map = new Microsoft.Maps.Map(document.getElementById("map"), options);
var center = map.getCenter();
var pin = new Microsoft.Maps.Pushpin(center, { text: 'あ' });
map.entities.push(pin);
}
</script>
</head>
<body onload="GetMap();">
<div id='map' style="position: relative; width: 400px; height: 400px"></div>
</body>
</html>
結果は図6のようになります。この時点で、
data:image/s3,"s3://crabby-images/858e2/858e2ff7bb3a280fd1b1f49742b401790aaccfdc" alt="図6 地図の表示 図6 地図の表示"
Bing Maps Keyの作成
Bing Maps AJAX Controlを使用するにあたり、
Bing Maps Keyの作成には、
data:image/s3,"s3://crabby-images/91d31/91d3164378258f21afecc09e32c9e349e35853a9" alt="図7 Maps Account Center――Bing Maps Keyの作成 図7 Maps Account Center――Bing Maps Keyの作成"
このBing Maps Keyによって認証を行い、
作成したBing Maps Keyは先ほどのファイルのコード中、
地図の表示
作成したHTMLファイルの内容を順に説明します。先頭にDOCTYPE宣言を記述します。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
HTMLファイルの文字セットはUTF-8が推奨されています。ファイルはUTF-8エンコードで保存するようにしましょう。headタグ内には、
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
Bing Maps AJAX Controlは次のようにscriptタグを使用してJavaScriptのライブラリーとしてロードします。
<script type="text/javascript" src="http://ecn.dev.virtualearth.net/mapcontrol/mapcontrol.ashx?v=7.0&mkt=ja-jp"></script>
地図の表示する場所は、
<div id='map' style="position: relative; width: 400px; height: 400px"></div>
次にJavaScriptのコード部分です。Webページの読み込み完了後に地図を表示するコードを実行します。具体的には、
function GetMap() {
// MapOptins, ViewOptions
var options = {
credentials: "AlTbyg8jCqAh-7bSGqCuYtC0S8hPUzPerImBnMeleIbj2z_4h9JaOnoO4BOiPam7",
mapTypeId: Microsoft.Maps.MapTypeId.road,
center: new Microsoft.Maps.Location(45.5, -122.5),
zoom: 6}
// Map オブジェクトの作成
var map = new Microsoft.Maps.Map(document.getElementById("map"), options);
}
オプションは、
各オプションの内容は次の通りです。
オプション | 説明 |
---|---|
credentials | Bing Maps Key |
mapTypeId | 地図の種類 MapTypeId列挙体を指定します。
|
center | 表示する地図の中心の経緯度 Locationオブジェクトを指定 |
zoom | ズームレベル |
上記以外にもいろいろな指定が可能ですが、
以上が、
// 表示されている地図の中心の経緯度(Locationオブジェクト)を取得
var center = map.getCenter();
// Pushpin オブジェクトの作成
var pin = new Microsoft.Maps.Pushpin(center, { text: 'あ' });
// プッシュピンの追加
map.entities.push(pin);
今回はここまでです。地図上にプッシュピンなどを表示する方法は次回以降にも紹介します。