Usamos cookies para medir audiência e melhorar sua experiência. Você pode aceitar ou recusar a qualquer momento. Veja sobre o iMasters.
Bom dia pessoal, estou criando uma função dentro do meu sistema para mostrar o mapa do cliente.
o que tenho é apenas o endereço, cep essas coisas e pelo que vi na documentação do google maps precisa da latitude e longitude.
Pesquisando pela internet não consegui fazer nenhuma função me trazer a longitude e latitude a partir do cep ou do endereço.
Alguem tem algo que possa me ajudar nessa empreita?
Eu cheguei a ver, mais a latitude e longitude que preciso é do cliente que esta no banco de dados os dados dele para abrir o google maps.
consegui puxar por json.
Agora minha duvida e como pegar apenas os dados que preciso.
dei um json_decode e um var_dump para ver o que me retorna e retorna assim:
array(2) { ["results"]=> array(1) { [0]=> array(5) { ["address_components"]=> array(7) { [0]=> array(3) { ["long_name"]=> string(16) "Rua ElÃas Gomes" ["short_name"]=> string(15) "R. ElÃas Gomes" ["types"]=> array(1) { [0]=> string(5) "route" } } [1]=> array(3) { ["long_name"]=> string(3) "485" ["short_name"]=> string(3) "485" ["types"]=> array(1) { [0]=> string(13) "street_number" } } [2]=> array(3) { ["long_name"]=> string(16) "Sta Maria Nazare" ["short_name"]=> string(16) "Sta Maria Nazare" ["types"]=> array(3) { [0]=> string(9) "political" [1]=> string(11) "sublocality" [2]=> string(19) "sublocality_level_1" } } [3]=> array(3) { ["long_name"]=> string(9) "Anápolis" ["short_name"]=> string(9) "Anápolis" ["types"]=> array(2) { [0]=> string(27) "administrative_area_level_2" [1]=> string(9) "political" } } [4]=> array(3) { ["long_name"]=> string(6) "Goiás" ["short_name"]=> string(2) "GO" ["types"]=> array(2) { [0]=> string(27) "administrative_area_level_1" [1]=> string(9) "political" } } [5]=> array(3) { ["long_name"]=> string(6) "Brazil" ["short_name"]=> string(2) "BR" ["types"]=> array(2) { [0]=> string(7) "country" [1]=> string(9) "political" } } [6]=> array(3) { ["long_name"]=> string(9) "75001-970" ["short_name"]=> string(9) "75001-970" ["types"]=> array(1) { [0]=> string(11) "postal_code" } } } ["formatted_address"]=> string(74) "R. ElÃas Gomes, 485 - Sta Maria Nazare, Anápolis - GO, 75001-970, Brazil" ["geometry"]=> array(3) { ["location"]=> array(2) { ["lat"]=> float(-16.3211627) ["lng"]=> float(-48.9420697) } ["location_type"]=> string(7) "ROOFTOP" ["viewport"]=> array(2) { ["northeast"]=> array(2) { ["lat"]=> float(-16.319813719708) ["lng"]=> float(-48.940720719709) } ["southwest"]=> array(2) { ["lat"]=> float(-16.322511680291) ["lng"]=> float(-48.943418680292) } } } ["place_id"]=> string(27) "ChIJ8WvvQmikXpMRAYEaQ96-UT4" ["types"]=> array(3) { [0]=> string(13) "establishment" [1]=> string(17) "point_of_interest" [2]=> string(7) "premise" } } } ["status"]=> string(2) "OK" }
Os dados em JSON ficam em estrutura de array
Então basta você aplicar um json_decode e printar as chaves correspondentes de acordo com o posicionamento dela na matriz.
por exemplo
$x = json_decode($meujson, true);
echo $x["result"][0]["address_components"][0]["long_name"];
Fiz batendo o olho porque estou no trabalho e não organizei a estrutura mas agora é so printar de acordo com a chaveGuilherme não deu, já fiz de todo jeito.
Array
(
[results] => Array
(
[0] => Array
(
[address_components] => Array
(
[0] => Array
(
[long_name] => Rua Elías Gomes
[short_name] => R. Elías Gomes
[types] => Array
(
[0] => route
)
)
[1] => Array
(
[long_name] => 485
[short_name] => 485
[types] => Array
(
[0] => street_number
)
)
[2] => Array
(
[long_name] => Sta Maria Nazare
[short_name] => Sta Maria Nazare
[types] => Array
(
[0] => political
[1] => sublocality
[2] => sublocality_level_1
)
)
[3] => Array
(
[long_name] => Anápolis
[short_name] => Anápolis
[types] => Array
(
[0] => administrative_area_level_2
[1] => political
)
)
[4] => Array
(
[long_name] => Goiás
[short_name] => GO
[types] => Array
(
[0] => administrative_area_level_1
[1] => political
)
)
[5] => Array
(
[long_name] => Brazil
[short_name] => BR
[types] => Array
(
[0] => country
[1] => political
)
)
[6] => Array
(
[long_name] => 75001-970
[short_name] => 75001-970
[types] => Array
(
[0] => postal_code
)
)
)
[formatted_address] => R. Elías Gomes, 485 - Sta Maria Nazare, Anápolis - GO, 75001-970, Brazil
[geometry] => Array
(
[location] => Array
(
[lat] => -16.3211627
[lng] => -48.9420697
)
[location_type] => ROOFTOP
[viewport] => Array
(
[northeast] => Array
(
[lat] => -16.319813719708
[lng] => -48.940720719709
)
[southwest] => Array
(
[lat] => -16.322511680291
[lng] => -48.943418680292
)
)
)
[place_id] => ChIJ8WvvQmikXpMRAYEaQ96-UT4
[types] => Array
(
[0] => establishment
[1] => point_of_interest
[2] => premise
)
)
)
[status] => OK
)
Verificando eu fiz assim:
echo $arrData["result"]["geometry"]["location"]["lat"];
Pois pelo que vi do posicionamento o geometry esta na mesma posição que o array[0].
Tentei coocando o [0] tambem e não foi.
O mais facil e ideal é você utilizar a propria função do HTML5 para tal.
https://www.w3schools.com/html/html5_geolocation.asp