Як я можу отримати назву міста з точки широти та довготи?


92

Чи є спосіб отримати назву міста з точки широти та довготи за допомогою API Google Maps api для javascript?

Якщо так, чи можу я побачити приклад?


Вам потрібно буде знайти веб-службу, яка пропонує це.
Deviland

Відповіді:


118

Це називається зворотним геокодування


Чудово! Я прочитав це, і тепер надмірна кількість запитів;) спасибі.
Dennis Martinez

Для IP-адреси та для одного користувача однаково, якщо ви використовуєте javascript API, але якщо ви використовуєте PHP, наприклад, і вважаєте, що досягнете цих обмежень, потрібно буде обмежити кількість запитів до 1 на секунду або проксі-сервери, але будьте обережні з проксі, Google не дурний, і ви не можете їх забити. Більше інформації тут: developers.google.com/maps/documentation/business/articles/…
Енді Гі

26

Ось повний зразок:

<!DOCTYPE html>
<html>
  <head>
    <title>Geolocation API with Google Maps API</title>
    <meta charset="UTF-8" />
  </head>
  <body>
    <script>
      function displayLocation(latitude,longitude){
        var request = new XMLHttpRequest();

        var method = 'GET';
        var url = 'http://maps.googleapis.com/maps/api/geocode/json?latlng='+latitude+','+longitude+'&sensor=true';
        var async = true;

        request.open(method, url, async);
        request.onreadystatechange = function(){
          if(request.readyState == 4 && request.status == 200){
            var data = JSON.parse(request.responseText);
            var address = data.results[0];
            document.write(address.formatted_address);
          }
        };
        request.send();
      };

      var successCallback = function(position){
        var x = position.coords.latitude;
        var y = position.coords.longitude;
        displayLocation(x,y);
      };

      var errorCallback = function(error){
        var errorMessage = 'Unknown error';
        switch(error.code) {
          case 1:
            errorMessage = 'Permission denied';
            break;
          case 2:
            errorMessage = 'Position unavailable';
            break;
          case 3:
            errorMessage = 'Timeout';
            break;
        }
        document.write(errorMessage);
      };

      var options = {
        enableHighAccuracy: true,
        timeout: 1000,
        maximumAge: 0
      };

      navigator.geolocation.getCurrentPosition(successCallback,errorCallback,options);
    </script>
  </body>
</html>

Чи є спосіб дізнатися місцезнаходження користувача за широтою та довготою без дозволу користувача?
Vikas Verma

8
@VikasVerma, що було б серйозним порушенням конфіденційності, якщо вам дозволено знаходити місцезнаходження користувача без їхньої згоди
omerio

@omerio дякую, але я зробив там код, я змусив користувача натиснути кнопку дозволити, якщо він / вона хоче продовжити.
Vikas Verma

1
Це насправді дало мою точну домашню адресу. Саме те, що я хочу. Як витягти так само, як місто, штат чи поштовий індекс?
ydobonebi

6

У node.js ми можемо використовувати node-геокодер npm-модуль для отримання адреси з lat, lng.,

geo.js

var NodeGeocoder = require('node-geocoder');

var options = {
  provider: 'google',
  httpAdapter: 'https', // Default
  apiKey: ' ', // for Mapquest, OpenCage, Google Premier
  formatter: 'json' // 'gpx', 'string', ...
};

var geocoder = NodeGeocoder(options);

geocoder.reverse({lat:28.5967439, lon:77.3285038}, function(err, res) {
  console.log(res);
});

вихід:

вузол geo.js

[ { formattedAddress: 'C-85B, C Block, Sector 8, Noida, Uttar Pradesh 201301, India',
    latitude: 28.5967439,
    longitude: 77.3285038,
    extra: 
     { googlePlaceId: 'ChIJkTdx9vzkDDkRx6LVvtz1Rhk',
       confidence: 1,
       premise: 'C-85B',
       subpremise: null,
       neighborhood: 'C Block',
       establishment: null },
    administrativeLevels: 
     { level2long: 'Gautam Buddh Nagar',
       level2short: 'Gautam Buddh Nagar',
       level1long: 'Uttar Pradesh',
       level1short: 'UP' },
    city: 'Noida',
    country: 'India',
    countryCode: 'IN',
    zipcode: '201301',
    provider: 'google' } ]

Дякуємо за дуже чіткий та робочий відгук, чи буде якась різниця між вибором "node-geocoder" та "@ google / maps"? Вони, схоже, роблять одне і те ж
Ade

1
обидва результати однакові, але node-geocoder - це спрощений модуль для отримання адреси, а @ google / maps - api для отримання адреси, яку нам потрібно налаштувати.
KARTHIKEYAN.


4

Ось сучасне рішення з використанням обіцянки:

function getAddress (latitude, longitude) {
    return new Promise(function (resolve, reject) {
        var request = new XMLHttpRequest();

        var method = 'GET';
        var url = 'http://maps.googleapis.com/maps/api/geocode/json?latlng=' + latitude + ',' + longitude + '&sensor=true';
        var async = true;

        request.open(method, url, async);
        request.onreadystatechange = function () {
            if (request.readyState == 4) {
                if (request.status == 200) {
                    var data = JSON.parse(request.responseText);
                    var address = data.results[0];
                    resolve(address);
                }
                else {
                    reject(request.status);
                }
            }
        };
        request.send();
    });
};

І назвіть це так:

getAddress(lat, lon).then(console.log).catch(console.error);

Обіцянка повертає об'єкт адреси в "then" або код стану помилки в "catch"


3
Це не працювало б без ключа доступу. Параметр датчика теж застарів
Жоро Тенев

Це насправді не працює
ProgrammingHobby

3

Наступний код добре працює, щоб отримати назву міста (за допомогою API Google Map Geo ):

HTML

<p><button onclick="getLocation()">Get My Location</button></p>
<p id="demo"></p>
<script src="http://maps.google.com/maps/api/js?key=YOUR_API_KEY"></script>

СЦЕНАРІЙ

var x=document.getElementById("demo");
function getLocation(){
    if (navigator.geolocation){
        navigator.geolocation.getCurrentPosition(showPosition,showError);
    }
    else{
        x.innerHTML="Geolocation is not supported by this browser.";
    }
}

function showPosition(position){
    lat=position.coords.latitude;
    lon=position.coords.longitude;
    displayLocation(lat,lon);
}

function showError(error){
    switch(error.code){
        case error.PERMISSION_DENIED:
            x.innerHTML="User denied the request for Geolocation."
        break;
        case error.POSITION_UNAVAILABLE:
            x.innerHTML="Location information is unavailable."
        break;
        case error.TIMEOUT:
            x.innerHTML="The request to get user location timed out."
        break;
        case error.UNKNOWN_ERROR:
            x.innerHTML="An unknown error occurred."
        break;
    }
}

function displayLocation(latitude,longitude){
    var geocoder;
    geocoder = new google.maps.Geocoder();
    var latlng = new google.maps.LatLng(latitude, longitude);

    geocoder.geocode(
        {'latLng': latlng}, 
        function(results, status) {
            if (status == google.maps.GeocoderStatus.OK) {
                if (results[0]) {
                    var add= results[0].formatted_address ;
                    var  value=add.split(",");

                    count=value.length;
                    country=value[count-1];
                    state=value[count-2];
                    city=value[count-3];
                    x.innerHTML = "city name is: " + city;
                }
                else  {
                    x.innerHTML = "address not found";
                }
            }
            else {
                x.innerHTML = "Geocoder failed due to: " + status;
            }
        }
    );
}

0

Так само, як @Sanchit Gupta.

у цій частині

if (results[0]) {
 var add= results[0].formatted_address ;
 var  value=add.split(",");
 count=value.length;
 country=value[count-1];
 state=value[count-2];
 city=value[count-3];
 x.innerHTML = "city name is: " + city;
}

просто втіліть масив результатів

if (results[0]) {
 console.log(results[0]);
 // choose from console whatever you need.
 var city = results[0].address_components[3].short_name;
 x.innerHTML = "city name is: " + city;
}

0

Доступно багато інструментів

  1. API Google Maps, як і всі написані
  2. використовувати ці дані " https://simplemaps.com/data/world-cities " завантажте безкоштовну версію та перетворіть Excel у JSON за допомогою якогось онлайн-конвертера, такого як " http://beautifytools.com/excel-to-json-converter.php "
  3. використовуйте IP-адресу, яка не є хорошою, оскільки користування IP-адресою когось може бути недобрим, користувачі думають, що ви можете їх зламати.

доступні також інші безкоштовні та платні інструменти


0

BigDataCloud також має хороший API для цього, також для користувачів nodejs.

вони мають API для клієнта - безкоштовно . Але також для бекенда , використовуючи API_KEY (безкоштовно відповідно до квоти).

Їх сторінка GitHub .

код виглядає так:

const client = require('@bigdatacloudapi/client')(API_KEY);

async foo() {
    ...
    const location: string = await client.getReverseGeocode({
          latitude:'32.101786566878445', 
          longitude: '34.858965073072056'
    });
}

0

Якщо ви не хочете використовувати API геокодування Google, тоді ви можете звернутися до кількох інших безкоштовних API для цілей розробки. наприклад, я використовував [mapquest] API для того, щоб отримати назву місця.

Ви можете легко отримати назву місця, реалізувавши наступну функцію

 const fetchLocationName = async (lat,lng) => {
    await fetch(
      'https://www.mapquestapi.com/geocoding/v1/reverse?key=API-Key&location='+lat+'%2C'+lng+'&outFormat=json&thumbMaps=false',
    )
      .then((response) => response.json())
      .then((responseJson) => {
        console.log(
          'ADDRESS GEOCODE is BACK!! => ' + JSON.stringify(responseJson),
        );
      });
  };


OP запитував рішення з API Карт Google, я думаю, ви не відповідаєте на питання.
Міхал Ткачик

Вибачте, але я просто запропонував альтернативний спосіб зробити це. і це прекрасно працює, якщо у нього є ключ API для кодування Google Geo.
pankaj chaturvedi

-3

Ви можете це зробити за допомогою чистого php та google geocode api

/*
 *
 * @param latlong (String) is Latitude and Longitude with , as separator for example "21.3724002,39.8016229"
 **/
function getCityNameByLatitudeLongitude($latlong)
{
    $APIKEY = "AIzaXXXXXXXXXXXXXXXXXXXXXXXXXXX"; // Replace this with your google maps api key 
    $googleMapsUrl = "https://maps.googleapis.com/maps/api/geocode/json?latlng=" . $latlong . "&language=ar&key=" . $APIKEY;
    $response = file_get_contents($googleMapsUrl);
    $response = json_decode($response, true);
    $results = $response["results"];
    $addressComponents = $results[0]["address_components"];
    $cityName = "";
    foreach ($addressComponents as $component) {
        // echo $component;
        $types = $component["types"];
        if (in_array("locality", $types) && in_array("political", $types)) {
            $cityName = $component["long_name"];
        }
    }
    if ($cityName == "") {
        echo "Failed to get CityName";
    } else {
        echo $cityName;
    }
}

1
Не рішення для JavaScript
Чінтан Патак
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.