// Copyright 2016 Google Inc. // // 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.type; option go_package = "google.golang.org/genproto/googleapis/type/latlng;latlng"; option java_multiple_files = true; option java_outer_classname = "LatLngProto"; option java_package = "com.google.type"; option objc_class_prefix = "GTP"; // An object representing a latitude/longitude pair. This is expressed as a pair // of doubles representing degrees latitude and degrees longitude. Unless // specified otherwise, this must conform to the // WGS84 // standard. Values must be within normalized ranges. // // Example of normalization code in Python: // // def NormalizeLongitude(longitude): // """Wraps decimal degrees longitude to [-180.0, 180.0].""" // q, r = divmod(longitude, 360.0) // if r > 180.0 or (r == 180.0 and q <= -1.0): // return r - 360.0 // return r // // def NormalizeLatLng(latitude, longitude): // """Wraps decimal degrees latitude and longitude to // [-90.0, 90.0] and [-180.0, 180.0], respectively.""" // r = latitude % 360.0 // if r <= 90.0: // return r, NormalizeLongitude(longitude) // elif r >= 270.0: // return r - 360, NormalizeLongitude(longitude) // else: // return 180 - r, NormalizeLongitude(longitude + 180.0) // // assert 180.0 == NormalizeLongitude(180.0) // assert -180.0 == NormalizeLongitude(-180.0) // assert -179.0 == NormalizeLongitude(181.0) // assert (0.0, 0.0) == NormalizeLatLng(360.0, 0.0) // assert (0.0, 0.0) == NormalizeLatLng(-360.0, 0.0) // assert (85.0, 180.0) == NormalizeLatLng(95.0, 0.0) // assert (-85.0, -170.0) == NormalizeLatLng(-95.0, 10.0) // assert (90.0, 10.0) == NormalizeLatLng(90.0, 10.0) // assert (-90.0, -10.0) == NormalizeLatLng(-90.0, -10.0) // assert (0.0, -170.0) == NormalizeLatLng(-180.0, 10.0) // assert (0.0, -170.0) == NormalizeLatLng(180.0, 10.0) // assert (-90.0, 10.0) == NormalizeLatLng(270.0, 10.0) // assert (90.0, 10.0) == NormalizeLatLng(-270.0, 10.0) message LatLng { // The latitude in degrees. It must be in the range [-90.0, +90.0]. double latitude = 1; // The longitude in degrees. It must be in the range [-180.0, +180.0]. double longitude = 2; }