よくある質問

プロダクトの詳細

ネットワークと接続

データ

UI のカスタマイズ

ルーティング

シミュレータ

Workflows

モビリティ サービス

プロダクトの詳細

アプリには、各ユーザーが同意する必要がある Navigation SDK 利用規約の通知を含むダイアログを実装する必要があります。このダイアログでは、ユーザーが利用規約に同意できます。利用規約のテキスト ファイルは Navigation SDK に付属しています。NavigationApi.showTermsAndConditionsDialog メソッドを使用して、利用規約を含むダイアログを表示します。
Google マップ モバイルでサポートされている言語はすべて、Navigation SDK で自動的に使用できるようになります。デバイスにはデフォルトのシステム言語があり、アプリはその設定を変更できませんが、アプリは 70 を超える言語にアクセスできます。

はい。開始すると、LocationListener はバックグラウンドで実行され続けます。アプリは道路に沿って位置をスナップし、方位を維持します。

はい。ルートが作成または変更されると、RouteChangeListener はポリラインを提供します。

いいえ。Navigation SDK では、デバイスに Google マップ モバイルをインストールする必要はありません。
いいえ。現時点では、Navigation SDK でこの機能は提供されていません。
はい。交通方向はデフォルトで使用可能で、表示されます。
Navigation SDK はどのバージョンの JDK をサポートしていますか?
Navigation SDK は、Oracle で積極的にサポートされている LTS バージョンの Java SE をサポートしています。これらのバージョンは、Oracle Java SE サポート ロードマッププレミア サポート対象として記載されています。

ネットワークと接続

Navigation SDK はネットワーク接続が不安定な場合、どのように処理しますか?
Navigation SDK は、各ルートのルートを事前にキャッシュに保存します。事前キャッシュに保存される情報には、15 ~ 20 分間のルーティング情報と、ユーザーがルートから外れた場合の代替ルート情報が含まれます。Navigation SDK は、デバイスの GPS とセンサーを使用して位置情報をおおよその値で取得します。
Navigation SDK は、GPS の信号が弱い場合や GPS の信号が失われた場合をどのように処理しますか?

ナビゲーションを開始し、Navigation SDK が GPS 信号を 1 回以上受信すると、次の状況で「GPS を検索しています...」というメッセージが表示されます。

  • 最後に GPS 信号を受信してから 10 秒以上経過している場合。
  • 最後に GPS 信号を受信してから、ルーティング中の位置が 500 m 以上移動した場合。

SDK が GPS シグナルを長時間受信しない場合、アプリでチェーンの位置で示されるルートの進行状況が遅くなり、完全に停止することがあります。この場合、地図上の矢印は、最後に受信した GPS 信号で示された位置に留まります。GPS 信号を受信しなかった場合、SDK はナビゲーション モードを自動的に終了しません。ただし、再度シグナルを受信するまでガイダンスを提供できない場合があります。

オフライン モードはありますか?
いいえ。現時点では、Navigation SDK にはオフライン モードはありません。ただし、ルートの事前キャッシュに保存された情報は提供されます。

データ

ルートを開始する前に、ルートのすべての停留所/目的地を取得できますか?

はい。ルートの経路を取得するには、Navigator.getRouteSegments() を呼び出します。

ルートの開始時にターンバイターン方式のルート案内を利用できますか?
はい。Navigation SDK は、ルート セグメントのリストを取得します。また、ユーザーはヘッダーのルート案内カードをスワイプして、各操作を確認できます。
アプリユーザーにはどのように所要時間が通知されますか?

アプリのユーザーに予定時刻情報を提供する手順は次のとおりです。

  1. Navigator.getTimeAndDistanceList() を使用して、すべてのウェイポイントの時間と距離を取得します。
  2. ドライバーの到着予定時刻の場合と同様に、この情報をクライアント アプリケーションに転送します。
ナビゲーションがフォアグラウンドにない場合、RoadSnappedLocationProvider を使用してユーザーの現在地を取得できますか?

はい。RoadSnappedLocationProvider はデフォルトでバックグラウンドで実行されます。

Navigation SDK はジオフェンスをサポートしていますか?

いいえ。ナビゲーションのコンテキストでは、remainingTimeOrdistanceChangeListener はジオフェンスよりも優れています。ジオフェンスは道路の形状を考慮していない場合があり、ユーザーがナビゲートしている正確なポイントに中心が合っていない場合があります。

この機能は remainingTimeOrdistanceChangeListener を使用して近似できます。

  1. しきい値を設定して、コールバックの頻度を決定します。
  2. 目的地までの残りの距離を確認します。

たとえば、しきい値を 100 m に設定すると、目的地までの距離が 100 m 変化したときにコールバックが届きます。距離が近づくにつれて、このしきい値を小さい値に更新して、コールバックの頻度を上げることができます。次に、残りの距離を確認して、集荷/配達場所に十分に近づいているかどうかを判断します。

ナビゲーション アプリがバックグラウンドで動作しているときに通知を無効にできますか?

はい。Navigator.setHeadsUpNotificationEnabled を使用して通知を管理します。このメソッドにはブール値引数があります。FALSE は通知を無効にし、TRUE は通知を有効にします。

トランザクション レコーダーは、一意の ID を使用して集荷と配達を追跡します。この ID は、プロダクト分析の目的で Google によってログに記録されます。Mobility Services をご利用の場合は、NavigationTransactionRecorder を実装してトランザクションの記録をログに記録することをおすすめします。

UI のカスタマイズ

最適なルート オプションを色分けできますか?
いいえ。特定のルート オプションを色分けすることは現時点ではサポートされていません。
Navigation SDK で最終目的地の到着予定時刻を表示できますか?

はい。次の方法を使用します。

  1. Navigator.getTimeAndDistanceList() を使用して、すべてのウェイポイントの時間と距離を取得します。
  2. NavigationFragment.setEtaCardEnabled(false) を使用して、現在のウェイポイントの到着予定時刻を非表示にします。
  3. 最終目的地の到着予定時刻をレンダリングします。
到着予定時刻の更新を非表示にするにはどうすればよいですか?

navigationView.setEtaCardEnabled(false) を呼び出して、到着予定時刻カードを無効にできます。

ヘッダー カードとフッター カードでは、どのような UI カスタマイズが可能ですか?

StylingOptions を使用して、背景色のスタイルを設定します。ヘッダーとフッターを表示または非表示にするには、NavigationFragmentsetHeaderEnabled メンバー関数と setFooterEnabled メンバー関数を使用します。

ルーティング

特定のルートをユーザーに提供したり、代替ルートを削除したりできますか?
いいえ。デフォルトでは、複数のルートが提供され、最速のルートが優先されます。リクエストに「高速道路と通行料を避ける」などの設定を追加することで、デフォルトのルートに影響を与えることができます。ウェイポイントを追加すると、ルートにも影響します。
アプリのユーザーに、デフォルトの目的地とは異なる目的地のラベルを表示できますか?

はい。デスティネーションのカスタム タイトルと緯度/経度を使用して Marker を作成します。Navigation SDK は、NavigationMap にカスタム タイトルと座標を表示します。

Navigation SDK を使用して、定義されたパスからの逸脱をトラッキングできますか?

はい。Navigator.setRouteChangedListener を使用すると、ルートの変更や新しいルートの推奨時に通知を受け取ることができます。

  1. Navigator.setRouteChangedListener メソッドを使用して、ルート上のデバイスの位置を確認するリスナーを登録します。
  2. コールバック イベント ハンドラ onRouteChanged にコードを追加します。
    • 更新された到着予定時刻と距離情報をアプリのユーザーに送信します。
    • デバイスの位置を追跡する。
    • [省略可] ユーザーが指定されたルートから外れた場合に対応するために、アプリで必要な他の機能を追加します。
ユーザーはルートを完了せずにナビゲーションを終了できますか?

はい。Navigator.stopGuidance() メソッドを呼び出して、ナビゲーションを停止します。

シミュレータ

シミュレーターはルートの変更をサポートしていますか?

はい。simulateLocationsAlongNewRoute を呼び出して、ルート変更を含む経路をシミュレートします。simulateLocationsAlongExistingRoute メソッドは、既存のルートの変更を無視します。

Workflows

ナビゲーション フラグメントを含むアクティビティを閉じた後に通知を閉じるにはどうすればよいですか?

ナビゲーション通知は、ナビゲーション中、アクティビティが閉じられているときに表示されたままになります。車両が目的地に到着すると、ナビゲーションが停止し、通知は表示されなくなります。

通知のクリックを処理するには、Navigator.startGuidance(intent resumeIntent) を使用します。resume intent は、アプリのユーザーが通知をクリックしたときに呼び出されます。通常、Navigator.startguidance(getIntent()) はメイン アクティビティから呼び出されます。このアクティビティは、アプリのユーザーが通知をクリックしたときにアクティビティを再呼び出します。

モビリティ サービス

モビリティ サービスのお客様が Navigation SDK を使用する場合、どのような違いがありますか?

Google Maps Platform モビリティ サービスは、運輸および物流企業の企業ニーズをサポートする API と SDK のコレクションを提供します。モビリティ サービスのお客様の場合、Navigation SDK は通常、ルート最適化、配車、タスク トラッキング、フリート分析などの関連サービスと組み合わせて使用されます。また、モビリティ サービスのお客様には Navigation SDK の料金が異なります。詳細については、Mobility Services のドキュメントをご覧ください。

モビリティ サービスは現在、一部のお客様のみご利用いただけます。詳しくは、営業担当者にお問い合わせください。

モビリティ サービスのお客様かどうかを確認するにはどうすればよいですか?
現在、モビリティ サービスのお客様として Navigation SDK を実装しているかどうか不明な場合は、コードで ReportBillableEvent 呼び出しを探してください。ReportBillableEvent メソッドを呼び出すのは、モビリティ サービスのお客様のみです。

モビリティ サービスのお客様は Navigation SDK をどのように課金されますか?
モビリティ サービスのお客様の場合、Navigation SDK の課金と料金は、Google Maps Platform とのサービス契約によって異なります。Mobility Services の実装が正しく課金されていることを確認する方法については、課金の検証をご覧ください。モビリティ サービスの課金について詳しくは、営業担当者にお問い合わせください。

モビリティ サービスのお客様のみが使用できる Navigation SDK API はどれですか。

Navigation SDK には、Mobility Services のお客様のみが使用できる API がいくつかあります。これらのお客様は、Google からトランザクションごとに請求されます。モビリティ サービスをご利用でない場合は、次の方法は使用できません。

Mobility Services をご利用の場合、Mobility Services 以外の実装の Navigation SDK も使用できますか?

はい。モビリティ サービスのお客様は、モビリティ サービスとモビリティ サービス以外の実装の両方で Navigation SDK を使用できます。ただし、アプリで一度に使用できる実装タイプは 1 つのみです。また、Mobility Services の実装で使用するものとは別に、新しい Google Cloud プロジェクト、請求先アカウント、API キーを作成する必要があります。詳細については、Navigation SDK のセットアップの概要をご覧ください。

ナビゲーション SDK の Mobility Services 以外の実装の使用について詳しくは、アプリを 1 つの実装タイプから別の実装タイプに移行する方法など、Google アカウント担当者にお問い合わせください。

注: 現在モビリティ サービスのお客様で、モビリティ サービスの API と SDK のコレクションについて詳しくお知りになりたい場合は、Google Maps Platform の営業担当者にお問い合わせください