Índice:
- Etapa 1: O que você precisa
- Etapa 2: vá para o Unwired Labs
- Etapa 3: inscreva-se para obter o token de API
- Etapa 4: Verifique seu e-mail
- Etapa 5: Bibliotecas de que você precisará
- Etapa 6: adicionar código no Arduino para conectar com LocationAPI
- Etapa 7: abra o monitor serial para ver se você está conectado
- Etapa 8: Obtenha as coordenadas
- Etapa 9: Vá para o Google Maps
- Etapa 10: envie a localização para o seu celular
2025 Autor: John Day | [email protected]. Última modificação: 2025-01-13 06:58
Você está curioso para saber como seu NodeMCU pode rastrear sua localização? É possível, mesmo sem um módulo GPS e sem display. A saída será as coordenadas de onde você está localizado e você as verá em seu monitor serial.
A configuração a seguir foi usada para NodeMCU 1.0 (Módulo ESP-12E) com Arduino IDE.
- Windows 10
- Arduino IDE v. 1.8.4
Etapa 1: O que você precisa
O que você precisa para seguir este tutorial são os seguintes componentes:
- Cabo micro usb
- NodeMCU ESP8266
Além disso, você precisará de:
- LocationAPI (de Unwired Labs)
- Acesso a wi-fi ou ponto de acesso
Etapa 2: vá para o Unwired Labs
A geolocalização é muito útil porque, quando o GPS está desligado, você ainda pode usar a geolocalização para rastrear sua localização. Nosso host que fornece geolocalização será https://www.unwiredlabs.com/. Acesse esse site e inscreva-se (o botão laranja no canto superior direito).
Etapa 3: inscreva-se para obter o token de API
Na página de inscrição, você deve preencher seu nome, e-mail (seu token de API será enviado para seu e-mail) e caso de uso (por exemplo, uso pessoal). Selecione o seu tipo de conta. A versão gratuita funciona bem, mas lembre-se de que você é limitado e não pode rastrear sua localização 24 horas por dia, 7 dias por semana. Vamos começar!
Etapa 4: Verifique seu e-mail
Vá para seu e-mail e você verá seu token de API. Copie o token da API, porque você precisa disso para o código que usaremos. É assim que o e-mail se parece:
Olá!
Obrigado por se inscrever no Unwired Labs LocationAPI! Seu token de API é 'seu código de API está aqui' (sem aspas). Isso dará 100 solicitações / dia de graça - para sempre.
Se você gostaria de acompanhar 5 dispositivos gratuitamente, responda com os seguintes detalhes e faremos upgrade de sua conta em 12 horas:
1. Tipo de implantação (Hardware / Aplicativo / Outro):
2. Sobre o seu projeto:
3. Site:
Você pode acessar seu painel aqui: https://unwiredlabs.com/dashboard. Se você tiver problemas ou tiver dúvidas, responda a este e-mail e eu ajudarei você!
Boa localização!
Sagar
Laboratórios sem fio
Etapa 5: Bibliotecas de que você precisará
A próxima etapa é abrir o Arduino e ir para gerenciar as bibliotecas. Você precisa instalar a biblioteca ArduinoJson. As outras bibliotecas já estão integradas. Quando estiver pronto, você pode começar a escrever o código.
Etapa 6: adicionar código no Arduino para conectar com LocationAPI
Faça um novo esboço e adicione o seguinte código no Arduino. Escreva seu próprio nome de wi-fi / ponto de acesso e sua senha. Cole o token de API que você recebeu no e-mail. Faça upload do seu código para o NodeMCU.
#incluir
#incluir
#include "ESP8266WiFi.h"
// seu SSID de rede (nome) e senha de rede
char myssid = "Seu nome de wi-fi / ponto de acesso"; char mypass = "Sua senha";
// Uniredlabs Hostname & Geolocation Endpoint url
const char * Host = "www.unwiredlabs.com"; String endpoint = "/v2/process.php";
// UnwiredLabs API_Token. Inscreva-se aqui para obter um token grátis
Token de string = "d99cccda52ec0b";
String jsonString = "{ n";
// Variáveis para armazenar a resposta do Uniredlabs
latitude dupla = 0,0; longitude dupla = 0,0; precisão dupla = 0,0;
void setup () {
Serial.begin (115200);
// Defina o WiFi para o modo de estação e desconecte-se de um AP se ele estiver conectado anteriormente
WiFi.mode (WIFI_STA); WiFi.disconnect (); Serial.println ("Configuração concluída");
// Começamos nos conectando a uma rede WiFi
Serial.print ("Conectando a"); Serial.println (myssid); WiFi.begin (myssid, mypass);
enquanto (WiFi.status ()! = WL_CONNECTED) {
atraso (500); Serial.print ("."); } Serial.println ("."); }
void loop () {
char bssid [6]; DynamicJsonBuffer jsonBuffer;
// WiFi.scanNetworks retornará o número de redes encontradas
int n = WiFi.scanNetworks (); Serial.println ("digitalização concluída");
if (n == 0) {
Serial.println ("Nenhuma rede disponível"); } else {Serial.print (n); Serial.println ("redes encontradas"); }
// agora construa o jsonString…
jsonString = "{ n"; jsonString + = "\" token / ": \" "; jsonString + = token; jsonString + =" / ", / n"; jsonString + = "\" id / ": \" saikirandevice01 / ", / n"; jsonString + = "\" wifi / ": [n"; para (int j = 0; j <n; ++ j) {jsonString + = "{ n"; jsonString + = "\" bssid / ": \" "; jsonString + = (WiFi. BSSIDstr (j)); jsonString + =" / ", / n"; jsonString + = "\" sinal / ":"; jsonString + = WiFi. RSSI (j); jsonString + = "\ n"; if (j <n - 1) {jsonString + = "}, / n"; } else {jsonString + = "} n"; }} jsonString + = ("] n"); jsonString + = ("} n"); Serial.println (jsonString);
Cliente WiFiClientSecure;
// Conecte-se ao cliente e faça a chamada API
Serial.println ("Solicitando URL: https://" + (String) Host + endpoint); if (client.connect (Host, 443)) {Serial.println ("Conectado"); client.println ("POST" + endpoint + "HTTP / 1.1"); client.println ("Host:" + (String) Host); client.println ("Conexão: fechar"); client.println ("Content-Type: application / json"); client.println ("User-Agent: Arduino / 1.0"); client.print ("Content-Length:"); client.println (jsonString.length ()); client.println (); client.print (jsonString); atraso (500); }
// Leia e analise todas as linhas da resposta do servidor
while (client.available ()) {String line = client.readStringUntil ('\ r'); JsonObject & root = jsonBuffer.parseObject (linha); if (root.success ()) {latitude = root ["lat"]; longitude = raiz ["lon"]; precisão = raiz ["precisão"];
Serial.println ();
Serial.print ("Latitude ="); Serial.println (latitude, 6); Serial.print ("Longitude ="); Serial.println (longitude, 6); Serial.print ("Precisão ="); Serial.println (precisão); }}
Serial.println ("fechando conexão");
Serial.println (); client.stop ();
atraso (5000);
}
Etapa 7: abra o monitor serial para ver se você está conectado
Vá para ferramentas no Arduino e abra o monitor serial. Para ver se você está conectado à Internet, você deve ver o seguinte no monitor serial:
Configuração feita
Conectando-se a (seu nome wi-fi) … verificação concluída
Etapa 8: Obtenha as coordenadas
Se funcionou com sucesso, você deve ver sob a varredura feita uma lista completa de dados. A única coisa de que precisamos é o código no URL solicitante, portanto, precisaremos da latitude e da longitude. Estas são as coordenadas.
Solicitando URL:
Conectado
Latitude = 52.385259
Longitude = 5,196099
Precisão = 41,00
fechando a conexão
Após 5 segundos, o código será atualizado constantemente e você provavelmente verá a alteração da latitude, longitude e precisão. Isso porque a API está tentando rastrear o local da forma mais precisa possível.
Etapa 9: Vá para o Google Maps
Vá para https://www.google.com/maps/ e digite suas coordenadas na barra de pesquisa. As coordenadas precisam ser escritas da seguinte maneira: 52.385259, 5.196099. O Google Maps deve mostrar onde você está localizado no mapa.
Etapa 10: envie a localização para o seu celular
E … Você está pronto! Portanto, se você deseja enviar a localização para o seu celular, é possível. O Google Maps enviará um e-mail com suas coordenadas, se desejar.
Boa localização!