Overview
This project provides details on how to use the Gadget Renesas GR-LYCHEE board as a web camera to display images on a web browser using Wi-Fi. GR-LYCHEE has an ESP32 module, which allows a connection between Wi-Fi and Bluetooth Low Energy (BLE).
Preparation
Hardware
Prepare the GR-LYCHEE board, a USB cable (Micro B type) and an SD card. For details on how to install the camera, refer to the How to Attach the Camera, Accessories, LCD project.
data:image/s3,"s3://crabby-images/07004/0700441370e6f782f62bb18861b9905deb8e023a" alt="gr-lychee-board"
data:image/s3,"s3://crabby-images/1e9f4/1e9f412348e7aac320c4a32d5ae38c947295541e" alt="usb-cable"
data:image/s3,"s3://crabby-images/743c9/743c96bef54236ebca24ad72ecd4ce7e32b8df5b" alt="sd-card-2gb"
Web Camera Sample
First, save the "index.htm" file for the browser display on the SD card.
-
Right click on the following link and save "Save target to file" to download.
After saving, insert the SD card into the GR-LYCHEE board and execute the following sketch.
#include <Arduino.h>
#include <Camera.h>
#include <SD.h>
#include <HTTPServer.h>
#include <mbed_rpc.h>
#include <SdUsbConnect.h>
#include <ESP32Interface.h>
ESP32Interface network;
#define WIFI_SSID "elecom2g01-45ea1e"
#define WIFI_PW "renerene"
Camera camera(320, 240);
SdUsbConnect storage("storage");
static int snapshot_req(const char ** pp_data) {
size_t size = camera.createJpeg();
*pp_data = (const char*)camera.getJpegAdr();
return size;
}
void setup(void) {
Serial.begin(9600);
Serial.println("Starts.");
// SD & USB
Serial.print("Finding strage..");
storage.wait_connect();
Serial.println("done");
camera.begin();
Serial.print("Connecting Wi-Fi..");
network.connect(WIFI_SSID, WIFI_PW, NSAPI_SECURITY_WPA_WPA2);
Serial.println("done");
Serial.print("MAC Address is ");
Serial.println(network.get_mac_address());
Serial.print("IP Address is ");
Serial.println(network.get_ip_address());
Serial.print("NetMask is ");
Serial.println(network.get_netmask());
Serial.print("Gateway Address is ");
Serial.println(network.get_gateway());
Serial.println("Network Setup OK\r\n");
SnapshotHandler::attach_req(&snapshot_req);
HTTPServerAddHandler<SnapshotHandler>("/camera"); //Camera
FSHandler::mount("/storage", "/");
HTTPServerAddHandler<FSHandler>("/");
HTTPServerAddHandler<RPCHandler>("/rpc");
HTTPServerStart(&network, 80);
}
void loop() {
}
Confirm Web Camera Operation
Activate the serial monitor and press the GR-LYCHEE board's reset button. The IP address obtained by DHCP is displayed as shown in the image to the right.
data:image/s3,"s3://crabby-images/14bc9/14bc926c0b5125c46bc266221f6bdfbe0f918716" alt="sp-webcamera-serial"
Type in the displayed IP address in the web browser's URL. The screen shown to the right is displayed.
The camera image is displayed.
data:image/s3,"s3://crabby-images/db1f3/db1f346bfe6b7622f7874f9eca61b5d8547bff9e" alt="sp-webcamera-iphone"