ルートの通行料金を計算する

ルートまたはルート マトリックスを計算する場合は、ルートの通行料金を考慮することをおすすめします。一部の都市では、ルートの推定通行料を適切な通貨で計算できます。

ルート マトリックスの通行料金を取得するには、ルート マトリックスの通行料金を計算するをご覧ください。

サポートされている有料道路の場所の一覧については、TollPass のリファレンスをご覧ください。

通行料金の計算方法

Routes API は、運転手または車両が利用できる通行料金の割引やパス、最も便利な支払い方法を考慮して、通行料金の見積もりを計算します。特定のルートで利用可能な通行料金がない場合、Routes API は料金不明の有料道路の存在を示します。

通行料金を正確に見積もるには、リクエストに次の情報を含めてください。

  • ルートで使用される車両の排出量タイプVehicleEmissionType)。排出量タイプが指定されていない場合は、ガソリン車の料金が返されます。
  • 車両とドライバーが持つすべての通行券は、TollPass を使用します。この API は、通行券を使用して正確な通行料金を決定します。リクエスト内の通行証がルートの近くにない場合は、現金価格を返します。
  • 必要に応じて有料道路を使わないようにします。可能であれば有料道路を避けたい場合は、avoidTollsRouteModifier として追加します。

通行証を使って通行料金を計算する

通行券を使って通行料金を計算するには、リクエストの一部として通行券を指定します。API はパスの料金を返します。

  • 無効な通行券を指定した場合、その通行証は無視されます。

  • 複数の通行券を配列として指定すると、API は各パスについて経路の料金計算を試みます。

通行証券の処理方法は地域によって異なります。

  • 通行料は低くなることがある: 一部の地域では、通行証がある運転手や車両は、通行証がない人とは異なる通行料を支払う場合があります。たとえば、米国ワシントン州シアトルで「よくできました!」の通行券がある場合、通行料はパスがない場合よりも安くなります。

  • 道路によっては通行証が必要なことがあります: インドネシアなど一部の地域では、通行証が必要な道路があります。通行券が必要なルートで通行券を指定しない場合、API は通行料金を返しません。

ルートの通行料金を計算する

次の例では、computeRoutes メソッドを使用して、通行券の使用時に推定料金を含む通行料金情報を返します。この例では、次の操作を行います。

  • 通行料金情報の計算を有効にするには、extraComputations 配列フィールドを TOLLS に設定します。

  • リクエストの routeModifiers フィールドを使用して、車両タイプと通行券の種類を指定します。返される通行料金は、指定された車両タイプとパスで使用される料金に基づいています。複数のパスを指定すると、最も安価な料金が返されます。

  • レスポンス フィールド マスクを使用して、レスポンスで通行料金情報を返すようにメソッドを構成します。この例では、リクエストのレスポンス フィールド マスクに次のプロパティが含まれています。

    • routes.travelAdvisory.tollInfo フィールド: 経路全体の情報を返します。

    • routes.legs.travelAdvisory.tollInfo は、各区間の情報を返します。

通行料金情報のリクエスト

curl -X POST -d '{
  "origin":{
    "location":{
      "latLng":{
        "latitude":42.340173523716736,
        "longitude":-71.05997968330408
      }
    }
  },
  "destination":{
    "location":{
      "latLng":{
        "latitude":42.075698891472804,
        "longitude": -72.59806562080408
      }
    }
  },
  "travelMode": "DRIVE",
  "extraComputations": ["TOLLS"],
  "routeModifiers":{
    "vehicleInfo":{
      "emissionType": "GASOLINE"
    },
    "tollPasses": [
      "US_MA_EZPASSMA",
      "US_WA_GOOD_TO_GO"
    ]
  }
}' \
-H 'Content-Type: application/json' \
-H 'X-Goog-Api-Key: YOUR_API_KEY' \
-H 'X-Goog-FieldMask: routes.duration,routes.distanceMeters,routes.travelAdvisory.tollInfo,routes.legs.travelAdvisory.tollInfo' \
'https://routes.googleapis.com/directions/v2:computeRoutes'

通行料金情報を含むレスポンス

レスポンスには、TollInfo(REST)オブジェクトまたは TollInfo(gRPC)オブジェクトで通行料金に関する情報が含まれます。この例では、ルート全体とルートの各区間の通行料金情報を返します。

{
  "routes": [
    {
      "legs": [
        {
          "travelAdvisory": {
            "tollInfo": {
              "estimatedPrice": [
                {
                  "currencyCode": "USD",
                  "units": "4",
                  "nanos": 400000000
                }
              ]
            }
          }
        }
      ],
      "distanceMeters": 150338,
      "duration": "6650s",
      "travelAdvisory": {
        "tollInfo": {
          "estimatedPrice": [
            {
              "currencyCode": "USD",
              "units": "4",
              "nanos": 400000000
            }
          ]
        }
      }
    }
  ]
}