mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-19 08:03:14 +08:00
51e016089e
PUBLISHED_FROM=28b3a30ad82432e8e3ca194d7e204acf9a998e94
73 lines
2.0 KiB
Plaintext
73 lines
2.0 KiB
Plaintext
= Raspberry Pi camera/LED demo
|
|
|
|
== Overview
|
|
|
|
The link:/[demo] consists of web app providing access to a webcam and a LED attached to a RaspberryPi.
|
|
The device is assumed to have a limited bandwidth towards the server hosting the web app.
|
|
|
|
== Objective
|
|
|
|
The demo shows how to use websockets to communicate bidirectionally with an embedded device using standard protocols.
|
|
|
|
It also shows that it's possible to use Smart.c to develop also the cloud endpoint and expose WebSocket and RESTful APIs
|
|
easy to integreate with modern web stacks.
|
|
|
|
== How it works
|
|
|
|
image::docs/arch.png[]
|
|
|
|
There are two components, once with runs on the device (`device_side`) and one that runs on a stronger machine
|
|
and with more bandwidth (`cloud_side`).
|
|
|
|
The device app connects to the cloud app via websocket and sends a new jpeg frame as fast as the underlying `raspistill` camera
|
|
grabbing application can handle. The device automatically attempts reconnecting.
|
|
|
|
The cloud side serves the webapp static pages and serves an MPJEG image on `/mpjg`.
|
|
The MPJEG image handler blocks all the clients until a JPEG frame arrives via websocket
|
|
and then every client will receive a copy of the frame.
|
|
|
|
The web app can turn on and off the LED via a RESTful api accessible via the `/api` handler.
|
|
|
|
== Installation
|
|
|
|
=== Server side
|
|
|
|
----
|
|
git clone https://github.com/cesanta/mongoose
|
|
cd mongoose/examples/web_demo
|
|
make cloud_side && ./cloud_side 0.0.0.0:8080
|
|
----
|
|
|
|
=== Raspberry Pi
|
|
|
|
The instructions provided here are tailored for the Raspbian distribution.
|
|
|
|
==== Dependencies
|
|
|
|
jpegoptim::
|
|
apt-get install jpegoptim
|
|
|
|
camera::
|
|
run raspi-config and enable camera
|
|
|
|
==== LED
|
|
|
|
In order to access the led on your link:http://www.qdh.org.uk/wordpress/?page_id=15[HotPi]
|
|
board you need to export the gpio pins:
|
|
|
|
----
|
|
for i in 22 23 24; do
|
|
echo $i >/sys/class/gpio/export
|
|
echo out >/sys/class/gpio/gpio$i/direction
|
|
chgrp pi /sys/class/gpio/gpio$i/value
|
|
done
|
|
----
|
|
|
|
==== Build and run
|
|
|
|
----
|
|
git clone https://github.com/cesanta/mongoose
|
|
cd mongoose/examples/web_demo
|
|
make device_side && ./device_side yourserver:8080
|
|
----
|