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

ルートまたはルート マトリックスを計算する際は、ルートの通行料金を考慮する必要があります。一部の都市では、ルートの通行料金の見積もりを適切な通貨で計算できます。

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

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

通行料金の計算方法

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

通行料金情報を正確に計算するために、Routes API では次のオプションを指定できます。

  • ルートで使用される車両の排出量タイプ(VehicleEmissionType)。排出量タイプが指定されていない場合は、ガソリン燃料車両の通行料金が返されます。
  • 該当する可能性がある運転手または車両の通行券(TollPass)。通行証が指定されていない場合、API は現金価格を返します。
  • 有料道路を回避するため、RouteModifieravoidTolls に設定します。

通行証使用時の通行料金の計算

地域によっては、通行証券を搭載した運転手や車両が、持参していない運転手や車両で支払う通行料金が異なる場合があります。たとえば、米国ワシントン州シアトルで Good To Go! の有料パスを購入した場合、そのパスがない場合よりも少ない通行料を支払うことになります。

インドネシアなど、一部の地域では、通行証が必要な道路があります。通行証が必要な経路で通行証料金が指定されていない場合、料金は返されません。

リクエストの一部として通行料金を指定すると、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
            }
          ]
        }
      }
    }
  ]
}