This example shows how you can play H264/H265/MJPEG encoded streams on the host computer. It showcases three different ways of playing the encoded stream.
-
main.pyusing Visualizer: This plays encoded stream by passing it directly to Visualizer. This is the most straightforward way of playing the encoded stream, however, it is currently not possible to play H265 encoded streams using Visualizer. -
pyav.pyusing PyAv library: This decodes encoded stream using the PyAv library and then displays them using Visualizer. This supports H264, MJPEG and H265 encoded streams. -
mjpeg.pywith OpenCV decoding: This decodes encoded stream using OpenCV's cv2.imdecode() function and displays them using Visualizer. This example supports only MJPEG encoding. Note that MJPEG compression isn't as great compared to H.264/H.265.
Running this example requires a Luxonis device connected to your computer. Refer to the documentation to setup your device if you haven't done it already.
You can run the example fully on device (STANDALONE mode) or using your computer as host (PERIPHERAL mode).
Here is a list of all available parameters:
-d DEVICE, --device DEVICE
Optional name, DeviceID or IP of the camera to connect
to. (default: None)
-fps FPS_LIMIT, --fps_limit FPS_LIMIT
FPS limit for the model runtime. (default: 30)
-media MEDIA_PATH, --media_path MEDIA_PATH
Path to the media file you aim to run the model on. If
not set, the model will run on the camera input.
(default: None)
-enc {mjpeg,h265,h264}, --encode {mjpeg,h265,h264}
Select encoding format. (default: h264)
You need to first prepare a Python 3.10 environment with the following packages installed:
You can simply install them by running:
pip install -r requirements.txtRunning in peripheral mode requires a host computer and there will be communication between device and host which could affect the overall speed of the app. Below are some examples of how to run the example.
python3 main.pyThis will run the example with default argument values and will play the encoded stream on the host computer.
python3 pyav.py -fps 10This will run the the example at 10 FPS and will use PyAv to decode the encoded stream.
Running the example in the standalone mode, app runs entirely on the device.
To run the example in this mode, first install the oakctl tool using the installation instructions here.
The app can then be run with:
oakctl connect <DEVICE_IP>
oakctl app run .This will run the example with default argument values. If you want to change these values you need to edit the oakapp.toml file (refer here for more information about this configuration file).