123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118 |
- // Copyright 2019 Google LLC.
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- //
- syntax = "proto3";
- package google.maps.roads.v1op;
- import "google/api/client.proto";
- import "google/protobuf/wrappers.proto";
- import "google/type/latlng.proto";
- option go_package = "google.golang.org/genproto/googleapis/maps/roads/v1op;roads";
- option java_multiple_files = true;
- option java_outer_classname = "RoadsProto";
- option java_package = "com.google.maps.roads.v1op";
- service RoadsService {
- option (google.api.default_host) = "roads.googleapis.com";
- // This method takes a sequence of latitude,longitude points and snaps them to
- // the most likely road segments. Optionally returns additional points giving
- // the full road geometry. Also returns a place ID for each snapped point.
- rpc SnapToRoads(SnapToRoadsRequest) returns (SnapToRoadsResponse) {
- option (google.api.method_signature) = "path";
- }
- // This method takes a list of latitude,longitude points and snaps them each
- // to their nearest road. Also returns a place ID for each snapped point.
- rpc ListNearestRoads(ListNearestRoadsRequest)
- returns (ListNearestRoadsResponse) {
- option (google.api.method_signature) = "points";
- }
- }
- // A request to the SnapToRoads method, requesting that a sequence of points be
- // snapped to road segments.
- message SnapToRoadsRequest {
- // The path to be snapped as a series of lat, lng points. Specified as
- // a string of the format: lat,lng|lat,lng|...
- string path = 1;
- // Whether to interpolate the points to return full road geometry.
- bool interpolate = 2;
- // The asset ID of the asset to which this path relates. This is used for
- // abuse detection purposes for clients with asset-based SKUs.
- string asset_id = 3;
- // The type of travel being tracked. This will constrain the paths we snap to.
- TravelMode travel_mode = 4;
- }
- // An enum representing the mode of travel used for snapping.
- enum TravelMode {
- TRAVEL_MODE_UNSPECIFIED = 0;
- DRIVING = 1;
- CYCLING = 2;
- WALKING = 3;
- }
- // A snapped point object, representing the result of snapping.
- message SnappedPoint {
- // The lat,lng of the snapped location.
- google.type.LatLng location = 1;
- // The index into the original path of the equivalent pre-snapped point.
- // This allows for identification of points which have been interpolated if
- // this index is missing.
- google.protobuf.UInt32Value original_index = 2;
- // The place ID for this snapped location (road segment). These are the same
- // as are currently used by the Places API.
- string place_id = 3;
- }
- // The response from the SnapToRoads method, returning a sequence of snapped
- // points.
- message SnapToRoadsResponse {
- // A list of snapped points.
- repeated SnappedPoint snapped_points = 1;
- // User-visible warning message, if any, which can be shown alongside a valid
- // result.
- string warning_message = 2;
- }
- // A request to the ListNearestRoads method, requesting that a sequence of
- // points be snapped individually to the road segment that each is closest to.
- message ListNearestRoadsRequest {
- // The points to be snapped as a series of lat, lng points. Specified as
- // a string of the format: lat,lng|lat,lng|...
- string points = 1;
- // The type of travel being tracked. This will constrain the roads we snap to.
- TravelMode travel_mode = 2;
- }
- // The response from the ListNearestRoads method, returning a list of snapped
- // points.
- message ListNearestRoadsResponse {
- // A list of snapped points.
- repeated SnappedPoint snapped_points = 1;
- }
|