【注意】 このドキュメントは、W3CのGeolocation API Specification 2nd Edition W3C Recommendation 8 November 2016の和訳です。
このドキュメントの正式版はW3Cのサイト上にある英語版であり、このドキュメントには翻訳に起因する誤りがありえます。誤訳、誤植などのご指摘は、訳者までお願い致します。
First Update: 2016年11月14日
公開以後に報告されたエラーや問題がないか正誤表を確認してください。
翻訳版も参照してください。
Copyright © 2016 W3C® (MIT, ERCIM, Keio, Beihang). W3C liability, trademark and document use rules apply.
この仕様は、ホスティング・デバイスに関連付けられた地理的な位置情報へのスクリプトによるアクセスを提供するAPIを定義しています。
現行のW3Cの刊行物およびこの技術報告の最新の改訂版のリストはhttps://www.w3.org/TR/のW3C技術報告インデックスにあります。
このドキュメントは、2013年のジオロケーションAPI勧告を編集したバージョンであり、すべての誤りを修正するという2013年の勧告に対して行われた変更が含まれています。このドキュメントの前の勧告との差分を記したバージョンも比較のために利用できます。正誤表にまだ記録されていない不確かなコンテキストに関する未解決の問題があることに注意してください。
このドキュメントは、ジオロケーション・ワーキンググループによって勧告として公開されました。このドキュメントに関してコメントを行いたい場合には、public-geolocation@w3.org(購読、アーカイブ。説明も参照してください)にお送りください。どのようなコメントでも歓迎します。
このドキュメントは、W3Cメンバー、ソフトウェア開発者、他のW3Cグループ、および他の利害関係者によりレビューされ、W3C勧告として管理者の協賛を得ました。これは確定済みドキュメントであり、参考資料として用いたり、別のドキュメントで引用することができます。勧告の作成におけるW3C の役割は、仕様に注意を引き付け、広範囲な開発を促進することです。これによってウェブの機能性および相互運用性が増強されます。
グループは勧告候補の終了基準を満たしたことを示す実装報告書を作成しました。少なくとも5つのユーザ・エージェントの実装があり、ジオロケーションAPI仕様のすべての機能が2つ以上のユーザ・エージェントで実装されました。また、ウェブサイト・テストに適合するウェブサイトが少なくとも2つありました。
このドキュメントは、2004年2月5日のW3C特許方針の下で活動しているグループによって作成されました。W3Cは、このグループの成果物に関連するあらゆる特許の開示の公開リストを維持し、このページには特許の開示に関する指示も含まれています。不可欠な請求権(Essential Claim(s))を含んでいると思われる特許に関して実際に知っている人は、W3C特許方針の6項に従って情報を開示しなければなりません。
このドキュメントは、2015年9月1日のW3Cプロセス・ドキュメントによって管理されています。
すべての項において明示的に非規範的と記しているとおり、この仕様のすべての図、例、注は、非規範的です。その他はすべて規範的です。
このドキュメントの規範的な部分の「しなければならない(MUST)」「してはならない(MUST NOT)」「必須である/要求される(REQUIRED)」「すべきである/する必要がある(SHOULD)」「すべきでない/する必要がない(SHOULD NOT)」「推奨される(RECOMMENDED)」「することができる/してもよい(MAY)」「選択できる/任意である(OPTIONAL)」というキーワードは、RFC2119で記述されているように解釈されるべきです。読みやすさのために、これらの用語をすべて大文字で表しているとは限りません。[RFC2119]
アルゴリズムの一部として命令文で表される要件(「先頭の空白文字を削除」や「エラーを返し、これらのステップを中止」など)は、アルゴリズムの導入に用いるキーワード(「しなければならない(MUST)」、「すべきである/する必要がある(SHOULD)」、「することができる/してもよい(MAY)」など)の意味で解釈すべきです。
アルゴリズムや特定のステップとして表現している適合要件は、最終的な結果が同等である限り、どのような方法で実装してもかまいません。(特に、この仕様で定義しているアルゴリズムは、分かりやすさを目指しており、効率の良さは目指していません。)
ユーザ・エージェントは、そのままでは制約のない入力に対し、例えば、サービスへの攻撃を防いだり、メモリの不足を監視したり、プラットフォーム固有の制限に対処したりするなど、実装固有の制限を課すことができます。
この仕様はWeb IDL仕様の用語を用いているため、この仕様で定義しているAPIをECMAScriptで実装する場合には、Web IDL仕様で定義されているECMAScript Bindingsと一致する形で実装しなければなりません。[WEBIDL]
この項は非規範的です。
ジオロケーションAPIは、緯度と経度のような、実装を提供しているデバイスのみに関連付けられている位置情報に対する、ハイレベルなインターフェースを定義します。API自体は、基礎となる位置情報の情報源に依存しません。一般的な位置情報の情報源には、ユーザによる入力に加え、GPS(Global Positioning System)や、IPアドレス、RFID、WiFiやBluetooth MACアドレスなどのネットワーク信号から推測される位置情報、GSM/CDMAセルIDなどがあります。APIがデバイスの実際の位置を返す保証はありません。
このAPIは、キャッシュされた位置情報のクエリを明示的に行う性能に加え、「単発」の位置情報リクエストと、位置情報の繰り返し更新の両方を可能にすることを目指しています。位置情報は、緯度と経度の座標で表されます。この仕様のジオロケーションAPIは、[AZALOC]、[GEARSLOC]、[LOCATIONAWARE]などの、業界における初期の取り組みを基礎としています。
次のコードは、基本的な位置情報の取得方法に関する説明を抜粋したものです。
「単発」の位置情報リクエストの例
function showMap(position) { // (position.coords.latitude, position.coords.longitude)を中心 // とする地図を表示する。 } // 単発の位置情報をリクエストする。 navigator.geolocation.getCurrentPosition(showMap);
位置情報の繰り返し更新のリクエストの例
function scrollMap(position) { // (position.coords.latitude, position.coords.longitude)が中心 // となるように、地図をスクロールする。 } // 繰り返し更新をリクエストする。 var watchId = navigator.geolocation.watchPosition(scrollMap); function buttonClickHandler() { // ユーザがボタンをクリックしたら、更新を中止する。 navigator.geolocation.clearWatch(watchId); }
位置情報の繰り返し更新のリクエストとエラー対応の例
function scrollMap(position) { // (position.coords.latitude, position.coords.longitude)が中心 // となるように、地図をスクロールする。 } function handleError(error) { // error.messageでdiv要素を更新する。 } // 繰り返し更新をリクエストする。 var watchId = navigator.geolocation.watchPosition(scrollMap, handleError); function buttonClickHandler() { // ユーザがボタンをクリックしたら、更新を中止する。 navigator.geolocation.clearWatch(watchId); }
潜在的にキャッシュされている位置情報をリクエストする例
// 位置情報をリクエストする。キャッシュ期間が10分以内の位置を受け // 入れる。ユーザ・エージェントが持っているキャッシュされた位置オ // ブジェクトが十分に新しくなければ、自動的に新しいオブジェクトを // 取得する。 navigator.geolocation.getCurrentPosition(successCallback, errorCallback, {maximumAge:600000}); function successCallback(position) { // 上記の「maximumAge」オプションの使用により、位置オブジェクト // は最大10分前までのものであることが保証される。 } function errorCallback(error) { // error.messageでdiv要素を更新する。 }
新しくキャッシュされた位置情報の返答をユーザ・エージェントに強制
// 位置をリクエストする。キャッシュ期間が10分以内の、キャッシュされた // 位置のみを受け入れる。ユーザ・エージェントが持っているキャッシュさ // れた位置オブジェクトが十分に新しくなければ、直ちにエラー・コールバ // ックが呼び出されるでしょう。 navigator.geolocation.getCurrentPosition(successCallback, errorCallback, {maximumAge:600000, timeout:0}); function successCallback(position) { // 上記の「maximumAge」オプションの使用により、位置オブジェクトは最 // 大10分前までのものであることが保証される。0ミリ秒の「タイムアウト」 // を使用すれば、適切なキャッシュされた位置情報が利用できなければ、 // ユーザ・エージェントは非同期にコードTIMEOUTでエラー・コールバック // を呼び出し、新しい位置情報の取得プロセスを開始しないでしょう。 } function errorCallback(error) { switch(error.code) { case error.TIMEOUT: // 適切なキャッシュされた位置情報が存在しない場合の迅速なフォールバック。 doFallback(); // 新しい位置オブジェクトを取得する。 navigator.geolocation.getCurrentPosition(successCallback, errorCallback); break; case ... // 他のエラーのケースを処理する。 }; } function doFallback() { // 十分に新しいキャッシュされた位置情報は利用できない。 // デフォルトの位置情報に対するフォールバック。 }
任意の利用可能なキャッシュされた位置情報の返答をユーザ・エージェントに強制
// 位置をリクエストする。いかなるキャッシュ期間でも、キャッシュされた位置 // のみを受け入れる。ユーザ・エージェントがキャッシュされた位置情報を全く持 // っていなければ、直ちにエラー・コールバックが呼び出されるでしょう。 navigator.geolocation.getCurrentPosition(successCallback, errorCallback, {maximumAge:Infinity, timeout:0}); function successCallback(position) { // 「maximumAge」を無限に設定することにより、位置オブジェクトはキャッシュさ // れたものであることが保証される。0ミリセカンドの「タイムアウト」を使用する // と、キャッシュされた位置が全く利用できない場合、ユーザ・エージェントは、 // 直ちにコードTIMEOUTでエラー・コールバックを呼び出し、新しい位置情報の取得 // プロセスを開始しないでしょう。 if (position.timestamp < freshness_threshold && position.coords.accuracy < accuracy_threshold) { // 位置情報は比較的新しくて正確。 } else { // 位置情報はかなり古くかつ/または不正確。 } } function errorCallback(error) { switch(error.code) { case error.TIMEOUT: // キャッシュされた位置情報が全く存在しない場合の迅速なフォールバック。 doFallback(); // 新しい位置オブジェクトを取得する。 navigator.geolocation.getCurrentPosition(successCallback, errorCallback); break; case ... // 他のエラーのケースを処理する。 }; } function doFallback() { // キャッシュされた位置情報は利用できない。 // デフォルト位置情報に対するフォールバック。 }
この項は非規範的です。
この仕様は、ホスティング・デバイスに関連付けられた地理的な位置情報を取得するためのスクリプトAPIの提供のみを範囲としています。地理的な位置情報は、世界測地系座標[WGS84]で提供されます。
この仕様の範囲には、いかなる種類のマークアップ言語の提供も含まれていません。
この仕様の範囲には、地理的な位置を識別するURIを構築するための新たなURIスキームの定義は含まれていません。
この仕様で定義しているAPIは、ホスティング・デバイスの地理的な位置を取得するために用いられます。ほとんどの場合、この情報はそのデバイスのユーザの位置も開示するため、ユーザのプライバシーが危険にさらされる可能性があります。この仕様に適合する実装は、ユーザのプライバシーを保護するメカニズムを提供しなければならず、このメカニズムは、ユーザが明確に許可しない限り、このAPIで位置情報が利用できるようにならないことを保証すべきです。
ユーザ・エージェントは、ユーザが明確に許可していないウェブサイトに位置情報を送信してはなりません。下記で述べているように、事前にユーザとの信頼関係が構築できていない場合、ユーザ・エージェントは、ユーザ・インターフェースを通じて許可を得なければなりません。ユーザ・インターフェースには、ドキュメントのURI[URI]のホスト・コンポーネントが含まれていなければなりません。ユーザ・インターフェースで得られた許可が、現在のブラウジング・セッションの範囲を越えて(つまり、ブラウジング・コンテキスト[BROWSINGCONTEXT]が別のURLにナビゲートされる時間を超えて)保持されている場合、それを取消できなければならず、ユーザ・エージェントは許可が取消されればそれを尊重しなければなりません。
一部のユーザ・エージェントは、そのようなユーザ・インターフェースを必要としない信頼関係を事前に構築するでしょう。例えば、ウェブ・サイトが地理的な位置情報を特定するリクエストを行なう時にはウエブ・ブラウザはユーザ・インターフェースを表示するかもしれませんが、E911(訳注:米国の携帯電話における緊急通報)機能を実行するために位置情報を用いる場合は、VOIP電話はユーザ・インターフェースを表示しないかもしれません。
受信者は、必要な場合にのみ位置情報をリクエストしなければなりません。受信者は、与えられたタスクのためにのみ位置情報を用いなくてはなりません。受信者は、ユーザから位置情報の保持を明確に許可されている場合を除き、そのタスクの完了時にその情報を廃棄しなければなりません。受信者は、この情報を不正なアクセスから保護するための措置を講じなければなりません。位置情報を保存する場合は、ユーザがこの情報を更新・削除できるようにすべきです。
位置情報の受信者は、ユーザが明確な許可なく位置情報を再送信してはなりません。再送信時には注意すべきであり、暗号化の利用が推奨されます。
受信者は、位置データを収集しているという事実、収集目的、データの保持期間、データの保護方法、データを共有する場合の共有方法、ユーザがデータにアクセス、更新、削除できる方法、データに関してユーザが有するその他の選択肢を明確かつ目立つように開示しなければなりません。この開示には、上記のガイドラインの例外に関する説明が含まれていなければなりません。
この項は非規範的です。
ジオロケーションAPIの実装者は、前項で挙げた要件に加え、ユーザのプライバシーに悪影響を及ぼしうる次の点についても考慮することが推奨されます。ユーザは、自分の位置をウェブサイトに開示する許可をユーザ・エージェントにうっかり与えてしまう場合があります。また、ユーザに関する限り、あるURLで提供されていたコンテンツが変更され、以前に与えられた位置に関する許可が適用されなくなる場合もあります。あるいは、単にユーザが考えを変えるかもしれません。
これらの状況を予測したり防止したりすることは本質的に困難です。緩和策や徹底的な防御策は実装の責任であり、この仕様では規定していません。しかし、実装者は、これらの手段を設計する際に、ユーザが位置情報の共有について意識できるようにし、許可の取り消しが可能なインターフェースに容易にアクセスできるようにすることをお勧めします。
Geolocation
オブジェクトは、ホスティング・デバイスに関連する位置情報をプログラムで決定するために、スクリプトで用います。位置情報は、ユーザ・エージェントの特定のアルゴリズムを適用し、Position
オブジェクトを作成し、それに基づいて、オブジェクトに適切なデータを入力することで得られます。
partial interface Navigator { readonly attribute Geolocation geolocation; };
[NoInterfaceObject] interface Geolocation { void getCurrentPosition(PositionCallback successCallback, optional PositionErrorCallback errorCallback, optional PositionOptions options); long watchPosition(PositionCallback successCallback, optional PositionErrorCallback errorCallback, optional PositionOptions options); void clearWatch(long watchId); }; callback PositionCallback = void (Position position); callback PositionErrorCallback = void (PositionError positionError);
getCurrentPosition()
メソッドは、1つか、2つか、3つの引数をとります。これが呼び出されれば直ちに応答し、デバイスの現在の位置情報の取得を非同期に試みなければなりません。試みが成功すれば、successCallback
が新しいPosition
オブジェクトで呼び出され(つまり、handleEvent
オペレーションがコールバック・オブジェクト上で呼び出され)、デバイスの現在の位置情報を反映しなければなりません。試みが失敗すれば、errorCallback
が新しいPositionError
オブジェクトで呼び出され、失敗の理由を反映しなければなりません。
getCurrentPosition
メソッドの実装は、次のステップを実行しなければなりません。
Position
オブジェクト(キャッシュ期間がmaximumAge変数の値より大きくない)が利用できる場合は、キャッシュされたPosition
オブジェクトでsuccessCallback
をパラメータとして呼び出し、この一連のステップを終了します。code
属性がTIMEOUTに設定されている新しいPositionError
オブジェクトでerrorCallback
(存在していれば)を呼び出し、この一連のステップを終了します。enableHighAccuracy
の定義を参照)。code
属性がTIMEOUTに設定されている新しいPositionError
オブジェクトでerrorCallback
(存在していれば)を呼び出し、この一連のステップを終了します。Position
オブジェクトでsuccessCallback
を呼び出し、この一連のステップを終了します。code
がPOSITION_UNAVAILABLEに設定されている新しいPositionError
オブジェクトでerrorCallback
(存在していれば)を呼び出します。watchPosition()
メソッドは、1つか、2つか、3つの引数をとります。これが呼び出されれば、監視オペレーションを一意に識別する長い値を直ちに返し、監視オペレーションを非同期に開始しなければなりません。このオペレーションは、デバイスの現在の位置情報の取得を最初に試みなければなりません。試みが成功すれば、successCallback
が新しいPosition
オブジェクトで呼び出され(つまり、handleEvent
オペレーションがコールバック・オブジェクト上で呼び出され)、デバイスの現在の位置情報を反映しなければなりません。試みが失敗すれば、errorCallback
が新しいPositionError
オブジェクトで呼び出され、失敗の理由を反映しなければなりません。その後、監視オペレーションは、デバイスの位置のモニタリングを継続し、この位置が変わるたびに適切なコールバックを呼び出さなければなりません。監視オペレーションは、clearWatch
メソッドが対応する識別子で呼び出されるまで、継続しなければなりません。
監視プロセスの実装は、次の一連のステップを実行しなければなりません。
Position
オブジェクト(キャッシュ期間がmaximumAge変数の値より大きくない)が利用できる場合は、キャッシュされたPosition
オブジェクトでsuccessCallback
をパラメータとして呼び出します。enableHighAccuracy
の定義を参照)。code
属性がTIMEOUTに設定されている新しいPositionError
オブジェクトでerrorCallback
(存在していれば)を呼び出し、ステップ6に飛びます。Position
オブジェクトでsuccessCallback
を呼び出します。このステップは、コールバック・レート制限の対象でありえます(下記を参照)。code
がPOSITION_UNAVAILABLEに設定されている新しいPositionError
オブジェクトでerrorCallback
(存在していれば)を呼び出します。このステップは、コールバック・レート制限の対象でありえます(下記を参照)。監視プロセスのステップ5.2.2で、新しい位置情報が得られ、この位置情報が以前に報告された位置情報と大きく異なる場合にのみ、successCallback
が呼び出されます。何をもって重大な違いとするのかの定義は、実装に委ねられます。さらに、5.2.2と5.2.3のステップで、実装は、過度な量の資源を不注意に消費しないようにするためにコールバックの頻度に制限を課すことができます。
getCurrentPosition
とwatchPosition
のどちらの場合も、実装は、最初に位置情報を共有する許可をユーザから得ない限り、決してsuccessCallback
を呼び出してはなりません。さらに、その実装は、上記のgetCurrentPosition
かwatchPosition
のどちらかのステップを実行する前に、位置情報を共有する許可をユーザから必ず得るべきです。ユーザが許可を与えれば、上記のような適切なコールバックが呼び出されなければなりません。ユーザが許可を否定すれば、上記のステップで遭遇した他のエラーに関係なく、errorCallback
(存在していれば)がcode
PERMISSION_DENIEDで呼び出されなければなりません。ユーザの許可を得るために費やされる時間を、PositionOptions
パラメータのtimeout
属性でカバーされる期間に含んではなりません。timeout
属性は、位置情報取得オペレーションのみに適用しなければなりません。
clearWatch()
メソッドは1つの引数をとります。これが呼び出されれば、与えられたwatchId
引数の値を最初にチェックしなければなりません。この値が以前に開始したどの監視プロセスにも対応していなければ、メソッドはそれ以上のアクションを行わずに、直ちに返答しなければなりません。そうでない場合は、watchId
引数で識別された監視プロセスは直ちに止められなければならず、それ以上のコールバックが呼び出されてはなりません。
getCurrentPosition()
とwatchPosition()
のメソッドは、PositionOptions
オブジェクトをそれらの3番目の引数として受け入れます。
ECMAScriptでは、PositionOptions
オブジェクトは、enableHighAccuracy
、timeout
およびmaximumAge
という名のオプションのプロパティーとともに、正規の本来のオブジェクトを用いて表されます。
dictionary PositionOptions { boolean enableHighAccuracy = false; [Clamp] unsigned long timeout = 0xFFFFFFFF; [Clamp] unsigned long maximumAge = 0; };
ECMAScriptでは、enableHighAccuracy
、timeout
およびmaximumAge
というプロパティーは、すべてオプションです。PositionOptionsオブジェクトを作成する場合、開発者はこれらのプロパティーをどれでも指定できます。
enableHighAccuracy
属性は、アプリケーションが最も良い結果を受け取りたいという示唆を与えます。その結果、応答時間が遅くなったり、電力消費量が増えたりする可能性があります。ユーザは、この性能を拒否することもできます。また、デバイスはフラグが指定されていなかったときよりも正確な結果を提供できない可能性もあります。この属性の本来の目的は、高精度なジオロケーションの確定を要求しないことを、実装に対してアプリケーションが通知できるようにすることです。したがって、実装では、大量の電力を消費するジオロケーション・プロバイダー(例えば、GPS)を用いないようにすることができます。これは特に、携帯電話のような電池式のデバイスで作動するアプリケーションに有用です。
timeout
属性は、対応するsuccessCallback
が呼び出されるまでに、呼び出しからgetCurrentPosition()
またはwatchPosition()
への受け渡しに許されている最長時間(ミリ秒で)を示します。既定のタイムアウト時間が経過する前に、実装が新しいPosition
をうまく取得できず、その間に他のエラーが生じていなければ、対応するerrorCallback
は、code
属性がTIMEOUTに設定されているPositionError
オブジェクトで呼び出されなければなりません。timeout
属性がカバーする期間には、ユーザからの許可の取得に費やす時間が含まれないことに注意してください。timeout
属性は、位置情報取得オペレーションのみに当てはまります。
getCurrentPosition()
呼び出しの場合、errorCallback
は最大1回呼び出されるでしょう。watchPosition()
の場合、errorCallback
は繰り返し呼び出されるかもしれません。最初のタイムアウトは、watchPosition()
が呼び出された瞬間か、ユーザの許可(必要な場合に)が得られた瞬間に関係があります。次のタイムアウトは、ホスティング・デバイスの位置が変わったため、新しいPosition
オブジェクトを取得しなければならないと実装が断定した瞬間に関係があります。
maximumAge
属性は、アプリケーションが、ミリ秒で指定された時間よりも期間が大きくないキャッシュされた位置情報を喜んで受け入れることを示します。maximumAge
が0に設定されていれば、実装は新しい位置オブジェクトの取得を直ちに試みなければなりません。maximumAge
を無限(Infinity)に設定すると、実装はキャッシュ期間にかかわらず、キャッシュされた位置情報の返答を決定しなければなりません。指定されたmaximumAge
よりも期間が大きくない、キャッシュされた位置情報を実装が利用できない場合、新しい位置オブジェクトを取得しなければなりません。watchPosition()
の場合、maximumAge
は、実装によって返された最初の位置オブジェクトを参照します。
Position
インターフェースは、このAPIが返したジオロケーション情報のためのコンテナです。このバージョンの仕様では、型Coordinates
とtimestamp
の1つの属性が認められています。将来のAPIのバージョンでは、この位置(例えば、住所)に関する他の情報を提供する追加の属性が認められるかもしれません。
[NoInterfaceObject] interface Position { readonly attribute Coordinates coords; readonly attribute DOMTimeStamp timestamp; };
coords
属性には、高度と速度などの他のオプションの属性に加え、地理的な座標情報がそれらの関連する精度とともに含まれています。
timestamp
属性は、Position
オブジェクトが得られた時間を表し、DOMTimeStamp[DOMTIMESTAMP]として表されます。
[NoInterfaceObject] interface Coordinates { readonly attribute double latitude; readonly attribute double longitude; readonly attribute double? altitude; readonly attribute double accuracy; readonly attribute double? altitudeAccuracy; readonly attribute double? heading; readonly attribute double? speed; };
このインターフェースで属性が用いる地理的な座標参照系は、世界測地系(2d)[WGS84]です。その他の参照系はサポートされていません。
latitude
とlongitude
の属性は、10進数の度数で指定される地理的な座標です。
altitude
属性は、位置の高さを表し、[WGS84]楕円体からの高さをメートルで指定します。実装が高度の情報を提供できない場合、この属性の値はヌル(null)でなければなりません。accuracy属性は、緯度と経度の座標の精度のレベルを示します。これはメートルで指定し、すべての実装でサポートされなければなりません。accuracy属性の値は負でない実数でなければなりません。
accuracy
属性はメートルで指定します。実装が高度情報を提供できない場合、この属性の値はヌルでなければなりません。そうでない場合には、altitudeAccuracy属性の値は負でない実数でなければなりません。
altitudeAccuracy
属性はメートルで指定します。実装が高度情報を提供できない場合、この属性の値はヌルでなければなりません。そうでない場合には、altitudeAccuracy属性の値は負でない実数でなければなりません。
実装が返すaccuracy
とaltitudeAccuracy
の値は、95%の信頼レベルに相当すべきです。
heading
属性は、ホスティング・デバイスの移動方向を示し、真北に対して時計回りに、0° ≤ 方向 < 360°の範囲で、度数で指定します。実装がheading情報を提供できない場合、この属性の値はヌルでなければなりません。ホスティング・デバイスが静止している場合(つまり、speed
属性の値が0)、heading属性の値はNaNでなければなりません。
speed
属性は、ホスティング・デバイスの現在の速度の水平成分の大きさを示し、メートル毎秒で指定します。実装が速度情報を提供できない場合、この属性の値はヌルでなければなりません。そうでない場合には、速度属性の値は負でない実数でなければなりません。
[NoInterfaceObject] interface PositionError { const unsigned short PERMISSION_DENIED = 1; const unsigned short POSITION_UNAVAILABLE = 2; const unsigned short TIMEOUT = 3; readonly attribute unsigned short code; readonly attribute DOMString message; };
code
属性は、次のリストから適切なコードを返さなければなりません。
PERMISSION_DENIED
(数値1)POSITION_UNAVAILABLE
(数値2)TIMEOUT
(数値3)Position
オブジェクトの取得に成功する前に、timeout
プロパティーで指定された時間が経過した。message
属性は、遭遇したエラーの詳細を説明したエラー・メッセージを返さなければなりません。この属性は、主としてデバッグを目的としており、開発者はアプリケーションのユーザ・インターフェースでそれを直接使用すべきではありません。
外国の都市を訪れた人は、観光名所のデータベースを検索・閲覧できるウェブ・アプリケーションにアクセスできます。ウェブ・アプリケーションは、ジェオロケーションAPIを用いてユーザのおおよその位置情報にアクセスできるため、ユーザの位置に近い順に検索結果を並べることができます。
友人のグループがスコットランドの高地をハイキングしています。彼らの一部は、旅行中に短いメモを書き、様々な場所で写真を撮り、彼らの携帯端末内でオフラインで動作するウェブ・アプリケーションを用いて、それらを保存します。彼らが新しいコンテンツを追加するたびに、そのアプリケーションは、ジェオロケーションAPI(今度は、内蔵のGPSデバイスを用いる)からの位置データを用いて自動的にタグ付けを行います。彼らが町や村に到着し、ネットワークの範囲内にまた入るたびに、そのアプリケーションは、人気のあるブログ・サイトに彼らのメモと写真を自動的にアップロードしますが、これは、マッピング・サービスへのリンクを構築するためにジェオロケーション・データを用います。グループの旅行をたどるユーザは、これらのリンクをクリックして、メモが書かれ、写真が撮られた地域の衛星写真を見ることができます。別の例は、あるユーザが自身の毎日の経験を記録したコンテンツ(例えば、画像、ビデオ、音声)を作成する生活ブログです。このコンテンツは、時間、地理的位置、記録時のユーザの感情までも含んだ情報で自動的にアノテーションを付与できます。
ユーザは市内の知らない地域にいます。彼女は自身の位置を確認したいと思い、ジェオロケーションAPIを用いて、市内の地図上で彼女の正確な位置を示してくれるウェブ・ベースのマッピング・アプリケーションを利用するために携帯端末を用います。その後、彼女は、現在位置から希望する目的地への運転方向を提供してくれるようにウェブ・アプリケーションに依頼します。
マッピング・アプリケーションは、進路変更のたびに詳細な指示を行うことにより、ユーザがルートに沿って移動することを補助できます。そのアプリケーションは、登録によってこれを行い、ユーザの位置情報の更新を繰り返し受け取るためにジェオロケーションAPIを用います。これらの更新は、実装しているユーザ・エージェントが、ユーザの位置が変わったと判断するとすぐに伝えられ、それによって、アプリケーションは、ユーザが行う必要がありえる方向転換を予測できるようになります。
観光ガイドのウェブ・アプリケーションは、ユーザの位置をモニターし、注目すべき場所が周辺にあれば、視覚または音声により通知を行うためにジェオロケーションAPIを使用できます。ユーザが、あるタスクに関連した目標物の近くにいれば、オンライン・タスク管理システムはリマインダーを発動できます。
ユーザが現在いる地域の天気やニュースを表示するウィジェットなどのウェブ・アプリケーションは、位置情報更新の登録手続きを行うためにジェオロケーションAPIを使用できます。ユーザの位置が変われば、ウィジェットは、それに応じて内容を適応させることができます。
ソーシャル・ネットワーク・アプリケーションでは、ユーザが位置情報を用いてステータスの更新を自動的にタグ付けできます。これは、ジェオロケーションAPIでユーザの位置をモニターすることで行います。個々のユーザは、他のユーザと共有する位置情報の粒度(例えば、都市レベルか近隣レベルか)をコントロールできます。ユーザは、彼の友人のネットワークを追跡し、彼らの現在の位置に関するリアルタイムな更新情報を入手することもできます。
Alec Berntson、Alissa Cooper、Steve Block、Greg Bolsinga、Lars Erik Bolstad、Aaron Boodman、Dave Burke、Chris Butler、Max Froumentin、Shyam Habarakada、Marcin Hanclik、Ian Hickson、Brad Lassey、Angel Machin、Cameron McCormack、Daniel Park、Stuart Parmenter、Olli Pettay、Chris Prince、Arun Ranganathan、Aza Raskin、Carl Reed、Thomas Roessler、Dirk Segers、Allan Thomson、Martin Thomson、Doug Turner、Erik Wilde、Matt Womer、Mohamed Zergaoui