Mendapatkan data
Ada banyak cara untuk memperoleh data lokasi yang terkumpul. Di sini, kami menjelaskan dua teknik untuk mendapatkan data yang akan digunakan dengan fitur sesuaikan dengan jalan pada Roads API.
GPX
GPX adalah format berbasis XML terbuka untuk membagikan rute, jalur, dan titik jalan yang direkam oleh perangkat GPS. Contoh ini menggunakan parser XmlPull, parser XML ringan yang tersedia untuk lingkungan server Java dan seluler.
/** * Parses the waypoint (wpt tags) data into native objects from a GPX stream. */ private List<LatLng> loadGpxData(XmlPullParser parser, InputStream gpxIn) throws XmlPullParserException, IOException { // We use a List<> as we need subList for paging later List<LatLng> latLngs = new ArrayList<>(); parser.setInput(gpxIn, null); parser.nextTag(); while (parser.next() != XmlPullParser.END_DOCUMENT) { if (parser.getEventType() != XmlPullParser.START_TAG) { continue; } if (parser.getName().equals("wpt")) { // Save the discovered latitude/longitude attributes in each <wpt>. latLngs.add(new LatLng( Double.valueOf(parser.getAttributeValue(null, "lat")), Double.valueOf(parser.getAttributeValue(null, "lon")))); } // Otherwise, skip irrelevant data } return latLngs; }
Berikut beberapa data GPX mentah yang dimuat ke peta.
Layanan lokasi Android
Cara terbaik untuk merekam data GPS dari perangkat Android bervariasi bergantung pada kasus penggunaan Anda. Lihat kelas pelatihan Android tentang Menerima Pembaruan Lokasi, serta contoh Lokasi Google Play di GitHub.
Memproses jalur panjang
Karena fitur sesuaikan dengan jalan menyimpulkan lokasi berdasarkan jalur lengkap, bukan titik individual, Anda harus berhati-hati saat memproses jalur panjang (yaitu, jalur yang melebihi batas 100 titik per permintaan).
Untuk memperlakukan setiap permintaan sebagai satu jalur panjang, Anda harus menyertakan beberapa tumpang-tindih, sehingga titik akhir dari permintaan sebelumnya disertakan sebagai titik awal permintaan berikutnya. Jumlah titik yang akan disertakan bergantung pada akurasi data Anda. Anda harus menyertakan lebih banyak titik untuk permintaan dengan akurasi rendah.
Contoh ini menggunakan Java Client for Google Maps Services untuk mengirim permintaan ber-paging dan kemudian menggabungkan kembali data, termasuk titik yang diinterpolasi, ke dalam daftar yang ditampilkan.
/** * Snaps the points to their most likely position on roads using the Roads API. */ private List<SnappedPoint> snapToRoads(GeoApiContext context) throws Exception { List<SnappedPoint> snappedPoints = new ArrayList<>(); int offset = 0; while (offset < mCapturedLocations.size()) { // Calculate which points to include in this request. We can't exceed the API's // maximum and we want to ensure some overlap so the API can infer a good location for // the first few points in each request. if (offset > 0) { offset -= PAGINATION_OVERLAP; // Rewind to include some previous points. } int lowerBound = offset; int upperBound = Math.min(offset + PAGE_SIZE_LIMIT, mCapturedLocations.size()); // Get the data we need for this page. LatLng[] page = mCapturedLocations .subList(lowerBound, upperBound) .toArray(new LatLng[upperBound - lowerBound]); // Perform the request. Because we have interpolate=true, we will get extra data points // between our originally requested path. To ensure we can concatenate these points, we // only start adding once we've hit the first new point (that is, skip the overlap). SnappedPoint[] points = RoadsApi.snapToRoads(context, true, page).await(); boolean passedOverlap = false; for (SnappedPoint point : points) { if (offset == 0 || point.originalIndex >= PAGINATION_OVERLAP - 1) { passedOverlap = true; } if (passedOverlap) { snappedPoints.add(point); } } offset = upperBound; } return snappedPoints; }
Berikut data dari atas setelah menjalankan permintaan sesuaikan dengan jalan. Garis merah adalah data mentah dan garis biru adalah data yang disesuaikan.
Penggunaan kuota yang efisien
Respons terhadap permintaan sesuaikan dengan jalan mencakup daftar ID tempat yang dipetakan ke titik yang Anda berikan, berpotensi dengan titik tambahan jika Anda menetapkan interpolate=true
.
Untuk menggunakan kuota yang diizinkan secara efisien untuk permintaan batas kecepatan, Anda hanya boleh membuat kueri untuk ID tempat unik dalam permintaan Anda. Contoh ini menggunakan Java Client for Google Maps Services untuk mengkueri batas kecepatan dari daftar ID tempat.
/** * Retrieves speed limits for the previously-snapped points. This method is efficient in terms * of quota usage as it will only query for unique places. * * Note: Speed limit data is only available for requests using an API key enabled for a * Google Maps APIs Premium Plan license. */ private Map<String, SpeedLimit> getSpeedLimits(GeoApiContext context, List<SnappedPoint> points) throws Exception { Map<String, SpeedLimit> placeSpeeds = new HashMap<>(); // Pro tip: Save on quota by filtering to unique place IDs. for (SnappedPoint point : points) { placeSpeeds.put(point.placeId, null); } String[] uniquePlaceIds = placeSpeeds.keySet().toArray(new String[placeSpeeds.keySet().size()]); // Loop through the places, one page (API request) at a time. for (int i = 0; i < uniquePlaceIds.length; i += PAGE_SIZE_LIMIT) { String[] page = Arrays.copyOfRange(uniquePlaceIds, i, Math.min(i + PAGE_SIZE_LIMIT, uniquePlaceIds.length)); // Execute! SpeedLimit[] placeLimits = RoadsApi.speedLimits(context, page).await(); for (SpeedLimit sl : placeLimits) { placeSpeeds.put(sl.placeId, sl); } } return placeSpeeds; }
Berikut adalah data dari atas dengan batas kecepatan yang ditandai di setiap ID tempat unik.
Interaksi dengan API lain
Salah satu manfaat menampilkan ID tempat dalam respons sesuaikan dengan jalan adalah Anda dapat menggunakan ID tempat di banyak Google Maps Platform API. Contoh ini menggunakan Java Client for Google Maps Services untuk melakukan geocode pada tempat yang ditampilkan dari permintaan sesuaikan dengan jalan di atas.
/** * Geocodes a snapped point using the place ID. */ private GeocodingResult geocodeSnappedPoint(GeoApiContext context, SnappedPoint point) throws Exception { GeocodingResult[] results = GeocodingApi.newRequest(context) .place(point.placeId) .await(); if (results.length > 0) { return results[0]; } return null; }
Di sini, penanda batas kecepatan telah diberi anotasi dengan alamat dari Geocoding API.
Kode contoh
Pertimbangan
Kode yang mendukung dokumen ini tersedia sebagai satu aplikasi Android untuk tujuan ilustrasi. Dalam praktiknya, Anda tidak boleh mendistribusikan kunci API sisi server di aplikasi Android karena kunci Anda tidak dapat diamankan dari akses tidak sah dari pihak ketiga. Sebagai gantinya, untuk mengamankan kunci, Anda harus men-deploy kode yang menghadap API sebagai proxy sisi server dan membuat aplikasi Android Anda mengirim permintaan menggunakan proxy, untuk memastikan permintaan diizinkan.
Download
Download kode dari GitHub.