У меня есть изоморфное приложение, которое также загружается на сервер и клиент. Меня беспокоит загрузка результатов для приложения на сервер. Мне нужно вызвать службу API карт Google, чтобы получить широту и долготу для места, например «www.mysite.com/search/New-York--NY-United-States». затем мне нужно найти его широту и долготу из API карт Google с приведенным ниже кодом в php (мой API находится в php)
$address= $this->input->get('address');
$geo = file_get_contents('http://maps.googleapis.com/maps/api/geocode/json?address='.urlencode($address).'&sensor=false');
$geo = json_decode($geo, true);
if ($geo['status'] = 'OK') {
$lat = $geo['results'][0]['geometry']['location']['lat'];
$lng = $geo['results'][0]['geometry']['location']['lng'];
}
Затем, основываясь на этой широте и долготе, я ищу свои результаты, как показано ниже.
$radius = 6371;
$distance = 250;
// latitude boundaries
$maxlat = $lat + rad2deg($distance / $radius);
$minlat = $lat - rad2deg($distance / $radius);
// longitude boundaries (longitude gets smaller when latitude increases)
$maxlng = $lng + rad2deg($distance / $radius / cos(deg2rad($lat)));
$minlng = $lng - rad2deg($distance / $radius / cos(deg2rad($lat)));
С помощью приведенного выше кода я рассчитываю максимальную и минимальную широту и долготу, а затем ищу свои результаты, применяя условия, как показано ниже.
$this->db->where('rv.LATITUDE >=', $minlat);
$this->db->where('rv.LATITUDE <=', $maxlat);
$this->db->where('rv.LONGTITUDE >=', $minlng);
$this->db->where('rv.LONGTITUDE <=', $maxlng);
Как получить широту и долготу, не вызывая API карт Google, и как оптимизировать его, чтобы получить результаты быстрее. Пожалуйста, дайте предложения по этому вопросу.