This project provides code, setup instructions and other materials, to implement video streaming from a USB webcam connected to an Intel Edison board. The webcam can be connected to a telescope, to provide a live video feed of objects in the sky. Also, setting up the Edison as a WiFi access point enables unique and practical outreach opportunities at public star parties, letting attendees share snapshots and video direct from the telescope to social media.
The webcam server provides an admin front end with buttons to start and stop the video stream, and for shutting down and rebooting the Edison board. It also provides a client front end with buttons to take snapshots and record video. Users can save the snapshots and video to their devices and share them to social media.
The Node.js video streaming code is based on the edi-cam project by Esther Jun Kim.
The web UI was developed using React.js by PJ Cabrera.
The Node.js server is responsible for:
- Listening for the incoming video stream via HTTP. ffmpeg, a multimedia framework for converting and streaming audio / video, is used to encode the webcam's video to MPEG1.
- Broadcasting the video stream via WebSockets to all connected browsers.
- Serving the web page which renders the WebSockets video stream and the webcam UI. More detail on this below.
- Implementing API endpoints for taking a snapshots and generating video out of the video stream, turning streaming on and off, and shutting down the Edison board.
The web page at src/client/index.html
is responsible for:
- Rendering the video stream onto a canvas element. jsmpeg, a JavaScript MPEG1 decoder, is used to decode the video stream.
- Rendering the admin and client front ends using React.js components. The React.js components call the API endpoints when tapped.
To get started with Edison if you have never set it up before, see this post. The most relevant sections are "Connecting Edison" and "Connect Edison to WiFi". Although the instructions are for the Arduino breakout board, setup is similar for the Mini breakout board, and the SparkFun Base Block for Intel® Edison: Snap Edison onto the board, then connect two micro USB cables to the board and to your computer.
The setup assumes that Edison and your computer are on the same Wi-Fi network. This is also the case for additional computers that are used to view the video stream.
With Edison and your computer on the same Wi-Fi network, it is also possible to connect to Edison wirelessly via SSH. This is particularly helpful when running the demo. To do so, open a new terminal window and type the following:
$ ssh [email protected]
[email protected]'s password:
root@myedison:~#
Replace myedison
with the name of your Edison. When prompted for your password, use the password you created when configuring Edison.
Use a UVC-compatible webcam. The video streaming code has been tested with a Creative Live! Cam Sync HD 720P and a Logitech HD Webcam C525.
External power (7-15 VDC) must be supplied to use Edison as a USB host. Refer to the appropriate item below (based on the board you have) to power and connect a USB device:
- If you have the Arduino breakout board, see this document. Power must be supplied on J1 (the power jack). Plug the webcam into the USB port next to the power jack. Make sure the switch SW1 is switched towards the USB port.
- If you have the Mini breakout board, see this document. Power must be supplied on J21 / J22, e.g. a 9V battery can be connected to J21 with a 2-pin connector. Connect a micro USB to USB OTG adapter to the webcam and plug into the micro USB port closest to J21 (lower right).
- If you have the SparkFun Base Block for Intel® Edison, see this document. Power is supplied by connecting a micro USB cable to the micro USB port marked Console on the SparkFun Base Block, or by plugging the SparkFun Base Block to a SparkFun Battery Block. Connect a micro USB to USB OTG adapter to the webcam and plug into the micro USB port marked OTG on the SparkFun Base Block.
Edison's operating system is based off Yocto Linux, which uses opkg
as its package manager. AlexT's unofficial opkg repository is highly recommended for adding packages to Edison. It includes many useful packages, such as git and the UVC driver.
To configure the repository, add the following lines to /etc/opkg/base-feeds.conf
:
src/gz all http://repo.opkg.net/edison/repo/all
src/gz edison http://repo.opkg.net/edison/repo/edison
src/gz core2-32 http://repo.opkg.net/edison/repo/core2-32
The configuration used in this demo is also provided for reference. If /etc/opkg/base-feeds.conf
is empty on your Edison, simply copy opkg/base-feeds.conf
file into /etc/opkg/
on your Edison's file system.
Update opkg
:
opkg update
If the update is successful, the output should look like this:
Downloading http://repo.opkg.net/edison/repo/all/Packages.gz.
Inflating http://repo.opkg.net/edison/repo/all/Packages.gz.
Updated list of available packages in /var/lib/opkg/all.
Downloading http://repo.opkg.net/edison/repo/edison/Packages.gz.
Inflating http://repo.opkg.net/edison/repo/edison/Packages.gz.
Updated list of available packages in /var/lib/opkg/edison.
Downloading http://repo.opkg.net/edison/repo/core2-32/Packages.gz.
Inflating http://repo.opkg.net/edison/repo/core2-32/Packages.gz.
Updated list of available packages in /var/lib/opkg/core2-32.
To install git:
opkg install git
Then clone this repository using git clone <git repo URL>
, then type cd edison-telescope-webcam
.
Older versions of the Edison Yocto image do not contain the UVC driver. To check whether or not the UVC driver is installed, type the following:
find /lib/modules/* -name 'uvc'
If the UVC driver is installed, the output should look something like this:
/lib/modules/3.10.17-poky-edison+/kernel/drivers/media/usb/uvc
If nothing is returned, the UVC driver needs to be installed:
opkg install kernel-module-uvcvideo
To make sure the UVC driver is loaded and the webcam is detected properly, plug in your webcam, then type lsmod | grep uvc
:
root@myedison:~# lsmod | grep uvc
uvcvideo 71516 0
videobuf2_vmalloc 13003 1 uvcvideo
videobuf2_core 37707 1 uvcvideo
Also, verify that the video device node has been created by typing ls -l /dev/video0
:
root@myedison:~# ls -l /dev/video0
crw-rw---- 1 root video 81, 0 Nov 10 15:57 /dev/video0
To install ffmpeg
:
- Navigate to the
bin
folder in the cloned repo. - Type
./install_ffmpeg.sh
to run the shell script.
If the download doesn't work, the release link may have changed. Check here, copy the address of the latest release, and replace this in the shell script.
From the root folder of the cloned repo, install the Node.js packages by typing npm install
.
From the root folder of the cloned repo, run the server by typing scripts/start_webcam.sh
.
The Node.js server should now be running. The console will look something like this:
WebSocket server listening on port 8084
HTTP server listening on port 8080
Listening for video stream on port 8082
Stream Connected: 127.0.0.1:52995 size: 1280x720
Open a browser window and navigate to http://myedison.local:8080
, where myedison
is the name of your Edison. You should now see the video stream from your webcam!
From the root folder of the cloned repo, shut down the server by typing scripts/stop_webcam.sh
.
If you are out in the field away from WiFi networks, you can set up the Edison's WiFi adapter to provide a local WiFi network. This will allow mobile devices to connect to the Edison, letting passersby to take snapshots and record video of objects shown in the video stream.