Skip to content

Streams ESP32 camera images to web backend and forwards them to a website in realtime.

Notifications You must be signed in to change notification settings

lenicyl/esp32_camera_webstream

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 

Repository files navigation

headline

esp32_camera_webstream

Bringing the ESP32 camera video stream to the web!

The Arduino ESP32-Camera test sketch only lets you use the stream on your local network. To get the stream to the web, you need a bit more...

This collection of scripts consists of:

  • Arduino code for ESP32 camera module (AI Thinker CAM) websocket_camera_stream.ino
  • Python code to receive the images via websockets with receive_stream.py
  • Python code to push the most recent image to a website with send_image_stream.py

Why is this cool?

I havent found a working repository that streams ESP32 camera images in real time to a web backend. This sovles this issue.

How to run?

  1. Open the ESP32 code in your Arduino IDE, install all missing libraries, change the ssid, password and websockets_server_host. Upload the code to you ESP32 AI Thinker Cam board. Please test the Arduino camera example before you test this code!

  2. Install the missing python requirements using pip: pip install pillow websockets flask asyncio

  3. Run python receive_stream.py You should get a constant stream of numbers (sizes of images). The image.jpg in the directory is always the latest received image.

  4. Open a second terminal and run python send_image_stream.py You should get a response by flask with an IP and port to enter in your browser.

Now enjoy your fresh live stream! 📺

Known Issues

Browsers don't like broken images.

This is solved using the placeholder.jpg. It just replaces the image, if the backend receives a broken frame to prevent the browser from freezing the stream.

You have to have the right board.

There are many ESP32 Camera modules. The defined pins in websocket_camera_stream.ino only work with the AI Thinker Cam. Change this, if you have a different board. The only tested camera is currently the OV2640.

Video!

LINK TO VIDEO

About

Streams ESP32 camera images to web backend and forwards them to a website in realtime.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 62.4%
  • Python 37.6%