Developer Wilayah Ekonomi Eropa (EEA)

Pilih kolom yang akan ditampilkan

Saat meminta rute atau matriks rute, Anda harus menggunakan mask kolom untuk menentukan informasi apa yang harus ditampilkan oleh respons. Tidak ada daftar default kolom yang ditampilkan. Jika Anda tidak menentukan mask kolom, metode akan menampilkan error.

Penggunaan mask kolom juga memastikan Anda tidak meminta data yang tidak perlu, yang pada gilirannya membantu latensi respons dan menghindari pengembalian informasi yang tidak diperlukan sistem Anda.

Anda menentukan daftar kolom yang Anda butuhkan dalam mask kolom respons. Kemudian, Anda meneruskan mask kolom respons ke salah satu metode menggunakan parameter URL $fields atau fields, atau menggunakan header HTTP atau gRPC X-Goog-FieldMask.

Untuk mengetahui informasi selengkapnya tentang parameter URL, lihat Parameter Sistem.

Menentukan mask kolom respons

Mask kolom respons adalah daftar jalur yang dipisahkan koma, dengan setiap jalur menentukan kolom unik dalam pesan respons. Jalur dimulai dari pesan respons tingkat teratas dan menggunakan jalur yang dipisahkan dengan titik ke kolom yang ditentukan.

Buat dan tentukan jalur kolom sebagai berikut:

  1. Temukan kolom yang berisi informasi yang Anda butuhkan. Untuk mengetahui detailnya, lihat Referensi Kolom.
  2. Tentukan jalur untuk kolom yang Anda butuhkan dan buat mask kolom untuknya: Untuk mengetahui detailnya, lihat Tentukan mask kolom yang ingin Anda gunakan.
  3. Gabungkan mask kolom untuk semua kolom yang Anda butuhkan, dengan memisahkan mask kolom menggunakan koma. Misalnya, untuk meminta distanceMeters untuk segmen rute, ditambah durasi untuk setiap langkah segmen rute, masukkan keduanya, yang dipisahkan dengan koma, tanpa spasi:

    routes.legs.distanceMeters,routes.legs.steps.duration
  4. Kirim mask kolom dengan permintaan API Anda. Misalnya, dalam permintaan curl, Anda akan menentukan mask kolom dengan -H dan X-Goog-FieldMask:

    -H X-Goog-FieldMask: routes.legs.distanceMeters,routes.legs.steps.duration
Untuk contoh dan detail selengkapnya, lihat bagian berikut.

Referensi Kolom

Untuk melihat kolom yang dapat Anda minta dalam respons melalui mask kolom, lihat referensi Compute Routes atau Compute Route Matrix Routes API yang ditautkan dalam daftar berikut. Tentukan kolom dalam camel case seperti yang ditunjukkan dalam referensi. Misalnya, routePreference.

Referensi ini mencakup kolom yang tersedia; namun, Anda harus merujuk ke hierarki kolom untuk menentukan jalur lengkap mask kolom. Untuk mengetahui detail tentang cara mendapatkan hierarki kolom, lihat Menentukan mask kolom yang ingin Anda gunakan.

  • Masker kolom rute komputasi
    • REST: Menentukan kolom objek Route dalam respons yang akan ditampilkan, yang diawali dengan routes., misalnya, routes.distanceMeters.
    • gRPC: Menentukan kolom objek Route dalam respons yang akan ditampilkan.
  • Masker kolom Compute Route Matrix

Menentukan mask kolom yang akan digunakan

Berikut cara menentukan kolom yang ingin Anda gunakan, dan membuat mask kolom untuknya:

  1. Minta semua kolom menggunakan mask kolom *.
  2. Lihat hierarki kolom dalam respons untuk kolom yang Anda inginkan.
  3. Buat mask kolom menggunakan hierarki kolom yang ditampilkan pada langkah sebelumnya, menggunakan format ini:

    topLevelField[.secondLevelField][.thirdLevelField][...]

Misalnya, untuk respons sebagian ini dari rute:

"routes": [
    {
        "legs": [
            {  "steps": [
                    {"distanceMeters": 119},
                    {"distanceMeters": 41}  ]
            }
        ],
        "distanceMeters": 160
    }
]

Jika Anda hanya ingin menampilkan kolom distanceMeters untuk segmen rute; yaitu, distanceMeters terakhir dalam contoh sebelumnya, mask kolom Anda adalah sebagai berikut:

routes.legs.distanceMeters

Jika Anda ingin menampilkan kolom distanceMeters untuk setiap langkah segmen rute; yaitu, distanceMeters di bagian steps dalam contoh sebelumnya, mask kolom Anda adalah sebagai berikut:

routes.legs.steps.distanceMeters

Jika Anda ingin menampilkan keduanya, dengan hasil di atas, mask kolom Anda adalah sebagai berikut:

routes.legs.distanceMeters,routes.legs.steps.distanceMeters

Contoh jalur mask kolom

Bagian ini berisi contoh lainnya tentang cara menentukan jalur kolom sebagai bagian dari mask kolom respons dalam panggilan REST dan gRPC.

Panggilan REST ke computeRoutes

Pada contoh pertama, Anda menggunakan panggilan REST ke metode computeRoutes untuk menghitung rute. Dalam contoh ini, di header, Anda menentukan mask kolom untuk menampilkan kolom distanceMeters dan duration rute dalam respons. Jangan lupa untuk menambahkan awalan routes pada nama kolom.

X-Goog-FieldMask: routes.distanceMeters,routes.duration

Panggilan REST ke computeRouteMatrix

Untuk metode REST computeRouteMatrix yang digunakan untuk menghitung matriks rute, di header, tentukan untuk menampilkan originIndex, destinationIndex, dan duration untuk setiap kombinasi asal dan tujuan:

X-Goog-FieldMask: originIndex,destinationIndex,duration

Panggilan gRPC

Untuk gRPC, tetapkan variabel yang berisi mask kolom respons. Kemudian, Anda dapat meneruskan variabel tersebut ke permintaan.

const (
  fieldMask = "routes.distanceMeters,routes.duration,routes.polyline.encodedPolyline"
)

Pertimbangan jalur kolom

Hanya sertakan kolom yang Anda perlukan dalam respons untuk menampilkan hanya kolom yang Anda butuhkan:

  • Mengurangi waktu pemrosesan, sehingga hasil Anda ditampilkan dengan latensi yang lebih rendah.
  • Memastikan performa latensi yang stabil. Jika Anda memilih semua kolom, atau jika Anda memilih semua kolom di tingkat teratas, Anda mungkin mengalami penurunan performa saat kolom baru ditambahkan dan kemudian disertakan secara otomatis dalam respons Anda.
  • Menghasilkan ukuran respons yang lebih kecil, yang berarti throughput jaringan yang lebih tinggi.
  • Memastikan Anda tidak meminta data yang tidak perlu, sehingga membantu menghindari waktu pemrosesan dan biaya penagihan yang tidak perlu.

Untuk mengetahui detail selengkapnya tentang cara membuat mask kolom, lihat field_mask.proto.