mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-01-07 17:55:29 +00:00
afc301de3a
Most notably this allows the video line stride to be set to 0, in which case a default value is to be used, and it deprecates selecting NDI sources by their IP address and because of that we remove the relevant properties. Usually the SDK will give an URL instead of an IP address now, so usage would've been broken anyway.
80 lines
3.4 KiB
Markdown
80 lines
3.4 KiB
Markdown
GStreamer NDI Plugin for Linux
|
|
====================
|
|
|
|
*Compiled and tested with NDI SDK 3.5, 3.8, 4.0 and 4.1*
|
|
|
|
This is a plugin for the [GStreamer](https://gstreamer.freedesktop.org/) multimedia framework that allows GStreamer to receive a stream from a [NDI](https://www.newtek.com/ndi/) source. This plugin has been developed by [Teltek](http://teltek.es/) and was funded by the [University of the Arts London](https://www.arts.ac.uk/) and [The University of Manchester](https://www.manchester.ac.uk/).
|
|
|
|
Currently the plugin has two source elements, `ndivideosrc` to get video from the stream and `ndiaudiosrc` for audio. By just providing the name or the ip of the stream, all the information required from the stream is picked up automatically, such as resolution, framerate, audio channels, ...
|
|
|
|
Some examples of how to use these elements from the command line:
|
|
|
|
```
|
|
#Information about the elements
|
|
gst-inspect-1.0 ndi
|
|
gst-inspect-1.0 ndivideosrc
|
|
gst-inspect-1.0 ndiaudiosrc
|
|
|
|
#Video pipeline
|
|
gst-launch-1.0 ndivideosrc ndi-name="GC-DEV2 (OBS)" ! autovideosink
|
|
#Audio pipeline
|
|
gst-launch-1.0 ndiaudiosrc ndi-name="GC-DEV2 (OBS)" ! autoaudiosink
|
|
|
|
#Video and audio pipeline
|
|
gst-launch-1.0 ndivideosrc ndi-name="GC-DEV2 (OBS)" ! autovideosink ndiaudiosrc ndi-name="GC-DEV2 (OBS)" ! autoaudiosink
|
|
```
|
|
|
|
Feel free to contribute to this project. Some ways you can contribute are:
|
|
* Testing with more hardware and software and reporting bugs
|
|
* Doing pull requests.
|
|
|
|
Compilation of the NDI element
|
|
-------
|
|
To compile the NDI element it's necessary to install Rust, the NDI SDK and the following packages for gstreamer:
|
|
|
|
```
|
|
apt-get install libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev \
|
|
gstreamer1.0-plugins-base gstreamer1.0-plugins-good \
|
|
gstreamer1.0-plugins-bad gstreamer1.0-plugins-ugly \
|
|
gstreamer1.0-libav libgstrtspserver-1.0-dev
|
|
|
|
```
|
|
To install the required NDI library there are two options:
|
|
1. Download NDI SDK from NDI website and move the library to the correct location.
|
|
2. Use a [deb package](https://github.com/Palakis/obs-ndi/releases/download/4.5.2/libndi3_3.5.1-1_amd64.deb) made by the community. Thanks to [NDI plugin for OBS](https://github.com/Palakis/obs-ndi).
|
|
|
|
To install Rust, you can follow their documentation: https://www.rust-lang.org/en-US/install.html
|
|
|
|
Once all requirements are met, you can build the plugin by executing the following command from the project root folder:
|
|
|
|
```
|
|
cargo build
|
|
export GST_PLUGIN_PATH=`pwd`/target/debug
|
|
gst-inspect-1.0 ndi
|
|
```
|
|
|
|
By defult GStreamer 1.16 is required, to use only GStreamer 1.12 instead of 1.16, pass `--disable-default-features` to cargo. Only a subset of video formats is supported with this GStreamer version.
|
|
|
|
If all went ok, you should see info related to the NDI element. To make the plugin available without using `GST_PLUGIN_PATH` it's necessary to copy the plugin to the gstreamer plugins folder.
|
|
```
|
|
cargo build --release
|
|
sudo install -o root -g root -m 644 target/release/libgstndi.so /usr/lib/x86_64-linux-gnu/gstreamer-1.0/
|
|
sudo ldconfig
|
|
gst-inspect-1.0 ndi
|
|
```
|
|
|
|
More info about GStreamer plugins written in Rust:
|
|
----------------------------------
|
|
https://gitlab.freedesktop.org/gstreamer/gstreamer-rs
|
|
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs
|
|
|
|
|
|
License
|
|
-------
|
|
This plugin is licensed under the LGPL - see the [LICENSE](LICENSE) file for details
|
|
|
|
|
|
Acknowledgments
|
|
-------
|
|
* University of the Arts London and The University of Manchester.
|
|
* Sebastian Dröge (@sdroege).
|