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

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

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

サポートされている通行料の場所の一覧については、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
            }
          ]
        }
      }
    }
  ]
}