Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

clickanapolis

Pegar latitude e longitude

Recommended Posts

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?

Compartilhar este post


Link para o post
Compartilhar em outros sites

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" }

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

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 chave

Compartilhar este post


Link para o post
Compartilhar em outros sites

Guilherme 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.

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por violin101
      Caros amigos do grupo, saudações e um feliz 2025.
       
      Estou com uma pequena dúvida referente a Teclas de Atalho.

      Quando o Caps Lock está ativado o Comando da Tecla de Atalho não funciona.
      ou seja:
      se estiver para letra minúscula ====> funciona
      se estiver para letra maiúscula ====> não funciona
       
      Como consigo evitar essa falha, tanto para Letra Maiúscula quanto Minúscula ?

      o Código está assim:
      document.addEventListener( 'keydown', evt => { if (!evt.ctrlKey || evt.key !== 'r' ) return;// Não é Ctrl+r, portanto interrompemos o script evt.preventDefault(); });  
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Por favor, poderiam me ajudar.

      Estou com a seguinte dúvida:
      --> como faço para para implementar o input código do produto, para quando o usuário digitar o ID o sistema espera de 1s a 2s, sem ter que pressionar a tecla ENTER.

      exemplo:
      código   ----   descrição
           1       -----   produto_A
       
      Grato,
       
      Cesar
    • Por violin101
      Caros amigos, saudações.
       
      Humildemente peço desculpa por postar uma dúvida que tenho.

      Preciso salvar no MySql, os seguinte Registro:

      1 - Principal
      ====> minha dúvida começa aqui
      ==========> como faço para o Sistema Contar Automaticamente o que estiver despois do 1.____?
      1.01 - Matriz
      1.01.0001 - Estoque
      1.01.0002 - Oficina
      etc

      2 - Secundário
      2.01 - Loja_1
      2.01.0001 - Caixa
      2.01.0002 - Recepção
      etc
       
      Resumindo seria como se fosse um Cadastro de PLANO de CONTAS CONTÁBEIL.

      Grato,


      Cesar









       
    • Por violin101
      Caros amigos, saudações.

      Por favor, me perdoa em recorrer a orientação dos amigos.

      Preciso fazer um Relatório onde o usuário pode Gerar uma Lista com prazo para vencimento de: 15 / 20/ 30 dias da data atual.

      Tem como montar uma SQL para o sistema fazer uma busca no MySql por período ou dias próximo ao vencimento ?

      Tentei fazer assim, mas o SQL me traz tudo:
      $query = "SELECT faturamento.*, DATE_ADD(faturamento.dataVencimento, INTERVAL 30 DAY), fornecedor.* FROM faturamento INNER JOIN fornecedor ON fornecedor.idfornecedor = faturamento.id_fornecedor WHERE faturamento.statusFatur = 1 ORDER BY faturamento.idFaturamento $ordenar ";  
      Grato,
       
      Cesar
       
       
       
       
    • Por violin101
      Caros amigos, saudações
       
      Por favor, me perdoa em recorrer a orientação dos amigos, tenho uma dúvida.
       
      Gostaria de uma rotina onde o Sistema possa acusar para o usuário antes dos 30 dias, grifar na Tabela o aviso de vencimento próximo, por exemplo:
       
      Data Atual: 15/11/2024
                                           Vencimento
      Fornecedor.....................Data.....................Valor
      Fornecedor_1...........01/12/2024..........R$ 120,00 <== grifar a linha de Laranja
      Fornecedor_1...........01/01/2025..........R$ 130,00
      Fornecedor_2...........15/12/2024..........R$ 200,00 <== grifar a linha de Amarelo
      Fornecedor_2...........15/01/2025..........R$ 230,00
      Fornecedor_3...........20/12/2024..........R$ 150,00
       
      Alguém tem alguma dica ou leitura sobre este assunto ?

      Grato,
       
      Cesar
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.