Wi-FiとBluetoothを内蔵する低コスト、低消費電力なマイクロコントローラです。
他のデバイスを付けることで機能を拡張することもできます!
今回はGPSキットを利用します!
サイズは手のひらサイズほどです。今回はこちらを使っていきます
今回はVSCodeのPlatformIOを利用します。
PlatformIOはVSCodeの拡張機能のところで検索すると出てくるのでインストールしてください。 アリのようなアイコンが目印です! インストールが完了したらHomeからNewProjectの作成をしましょう 今回はESP32を活用するのでBoardの部分を Adafruit ESP32 Feather を選択しましょう 最後にFinishを選択してプロジェクトを作成してプロジェクトを作成します!
Firebaseのプロジェクト作成はHPの方でできますので分かりやすい名前で作成してください。 Firebaseのサイトはこちら(https://firebase.google.com/)
これで準備は完了です!続いてはGPSキットで位置情報の取得していきましょう!
#include <TinyGPS++.h>
TinyGPSPlus gps;
HardwareSerial ss(2);
double Lat;
double Lng;
void setup()
{
Serial.begin(115200);
ss.begin(9600);
}
void loop()
{
while(ss.available() > 0){
char c = ss.read();
gps.encode(c);
if(gps.location.lat()){
Lat = gps.location.lat();
Lng = gps.location.lng();
}
}
TinyGPSPlusというLiblaryを使って位置情報取得に成功しました! Latが緯度 Lngが経度を取得しています。 (思っていたよりも簡単?なのか?)
HomeのLibraliesでFirebase Arduino Client Library for ESP8266 and ESP32をプロジェクトに追加しましょう そして今回はPlatformIOが提供しているExamplesの中からコードを一部引用して作成していきます。 VSCodeよりもホームページの方が探しやすいのでページをこちらから移動します。 ExamplesからFirestore/CommitDocument/AppendArray/AppendArray.inoを今回は使用していきます。
#if defined(ESP32)
#include <WiFi.h>
#elif defined(ESP8266)
#include <ESP8266WiFi.h>
#endif
#include <Firebase_ESP_Client.h>
#include <TinyGPS++.h>
#include <addons/TokenHelper.h>
#include<string>
#define WIFI_PASSWORD //利用したいWiFiの設定
#define API_KEY //FirebaseプロジェクトからAPIkeyを取得
#define FIREBASE_PROJECT_ID //FirebaseのプロジェクトからIDを取得
#define USER_EMAIL "esp32@gmail.com"
#define USER_PASSWORD "esp32_test"
FirebaseData fbdo;
FirebaseAuth auth;
FirebaseConfig config;
unsigned long dataMillis = 0;
int count = 0;
TinyGPSPlus gps;
HardwareSerial ss(2);
double Lat;
double Lng;
void setup()
{
Serial.begin(115200);
ss.begin(9600);
WiFi.begin(WIFI_SSID, WIFI_PASSWORD);
Serial.print("Connecting to Wi-Fi");
while (WiFi.status() != WL_CONNECTED)
{
Serial.print(".");
delay(300);
}
Serial.println();
Serial.print("Connected with IP: ");
Serial.println(WiFi.localIP());
Serial.println();
Serial.printf("Firebase Client v%s\n\n", FIREBASE_CLIENT_VERSION);
config.api_key = API_KEY;
auth.user.email = USER_EMAIL;
auth.user.password = USER_PASSWORD;
config.token_status_callback = tokenStatusCallback; // see addons/TokenHelper.h
#if defined(ESP8266)
fbdo.setBSSLBufferSize(2048 /* Rx buffer size in bytes from 512 - 16384 */, 2048 /* Tx buffer size in bytes from 512 - 16384 */);
#endif
fbdo.setResponseSize(2048);
Firebase.begin(&config, &auth);
Firebase.reconnectWiFi(true);
}
void loop()
{
while(ss.available() > 0){
char c = ss.read();
gps.encode(c);
if(gps.location.lat()){
Lat = gps.location.lat();
Lng = gps.location.lng();
}
}
if (Firebase.ready() && (millis() - dataMillis > 60000 || dataMillis == 0))
{
dataMillis = millis();
String documentPath = "esp32/gps";
FirebaseJson content;
content.set("fields/lat/doubleValue", String(Lat,6));
content.set("fields/lng/doubleValue", String(Lng,6));
if(Firebase.Firestore.patchDocument(&fbdo, FIREBASE_PROJECT_ID, "", documentPath.c_str(), content.raw(), "")){
Serial.printf("ok\n%s\n\n", fbdo.payload().c_str());
return;
}else{
Serial.println(fbdo.errorReason());
}
if(Firebase.Firestore.createDocument(&fbdo, FIREBASE_PROJECT_ID, "", documentPath.c_str(), content.raw())){
Serial.printf("ok\n%s\n\n", fbdo.payload().c_str());
return;
}else{
Serial.println(fbdo.errorReason());
}
}
}
先ほどCopyしたExampleとほとんど変わりません。 自分が取得したい値をcontent.set()の部分に入れればとりあえずFirestoreに値を入れることができます。 APIkeyとProjectIDはFirebaseのプロジェクトのプロジェクト設定から確認することができます。 USER_EMAILの部分はFirebaseのFireAuthを活用して作成してください 実際に実行するとFirestoreにはこのように値が出力されます。 ここまできたら後もう一踏ん張りですね! こちらのサイトから関数の説明を見ることができます。(https://github.com/mobizt/Firebase-ESP-Client)
こちらもgoogle_maps_flutterのExampleを利用しましたgoogle_maps_flutter(https://pub.dev/packages/google_maps_flutter)
import 'dart:async';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:flutter/material.dart';
import 'package:google_maps_flutter/google_maps_flutter.dart';
class HomePage extends StatefulWidget {
const HomePage({super.key});
State<HomePage> createState() => _HomePageState();
}
class _HomePageState extends State<HomePage> {
double Lat = 0;
double Lng = 0;
var esp32 = CameraPosition(
target: LatLng(0, 0),
);
final Completer<GoogleMapController> _controller =
Completer<GoogleMapController>();
Future<void> _goToesp32() async {
final GoogleMapController controller = await _controller.future;
controller.animateCamera(CameraUpdate.newCameraPosition(esp32));
}
Widget build(BuildContext context) {
return Scaffold(
body: GoogleMap(
mapType: MapType.hybrid,
initialCameraPosition: CameraPosition(
target: LatLng(40.7127753, -74.0059728),
zoom: 14.4746,
),
onMapCreated: (GoogleMapController controller) {
_controller.complete(controller);
},
),
floatingActionButton: FloatingActionButton.extended(
onPressed: () async {
final values = await FirebaseFirestore.instance
.collection('esp32')
.doc('gps')
.get();
setState(() {
Lat = values['lat'];
Lng = values['lng'];
});
esp32 = CameraPosition(target: LatLng(Lat, Lng), zoom: 14);
_goToesp32();
},
label: const Text('場所確認'),
),
);
}
}
実行すると次のようになりfloatingActionButtonを押すことでesp32の位置情報を取得することができます! 僕は熊本から可茂ITのインターンをしているので熊本市が表示されています
今回はESP32に内蔵されているWiFi機能と追加でつけたGPS機能を利用してデバイスの位置情報取得アプリを作成しました 実用化できるかは分かりませんが総額でも2000円もしないくらいで作成できるので気になる方は試してみてください!
可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。
Read More可茂IT塾ではFlutter/Reactのインターンを募集しています!可茂IT塾のエンジニアの判断で、一定以上のスキルをを習得した方には有給でのインターンも受け入れています。
Read More