11 个版本 (7 个破坏性更新)

0.23.0 2024年7月11日
0.22.0 2024年2月8日
0.21.1 2023年10月4日
0.20.0 2023年2月9日
0.0.0 2020年8月10日

#40 in #audio-video

Download history 491/week @ 2024-04-26 999/week @ 2024-05-03 498/week @ 2024-05-10 456/week @ 2024-05-17 509/week @ 2024-05-24 469/week @ 2024-05-31 582/week @ 2024-06-07 635/week @ 2024-06-14 713/week @ 2024-06-21 483/week @ 2024-06-28 552/week @ 2024-07-05 609/week @ 2024-07-12 788/week @ 2024-07-19 546/week @ 2024-07-26 700/week @ 2024-08-02 589/week @ 2024-08-09

2,725 每月下载量
3 个crate中使用(通过 gst-plugin-gtk4

MIT/Apache

2.5MB
65K SLoC

gstreamer-rs crates.io pipeline status

GStreamer(OpenGL库,Wayland 支持)的 Rust 绑定。文档可以在这里找到。

这些绑定提供了一个安全的 API,可用于与 GStreamer 交互,例如编写基于 GStreamer 的应用程序和 GStreamer 插件。

这些绑定主要使用基于 GStreamer 项目提供的 girGObject-Introspection API 元数据自动生成。

目录

  1. 安装
    1. Linux/BSDs
    2. macOS
    3. Windows
  2. 入门指南
  3. 许可
  4. 贡献

安装

要构建 GStreamer 绑定或依赖它们的任何内容,您至少需要安装 GStreamer 1.14 和 gst-plugins-base 1.14。此外,一些示例/教程需要各种 GStreamer 插件可用,这些插件可以在 gst-plugins-base、gst-plugins-good、gst-plugins-bad、gst-plugins-ugly 和/或 gst-libav 中找到。

Linux/BSDs

您需要使用您的发行版的包管理器安装上述提到的包,或者从源代码构建它们。

在 Debian/Ubuntu 上,它们可以通过以下方式安装

$ 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 libges-1.0-dev

上述库的最低版本要求为 >= 1.14。如果您构建 gstreamer-player 子库或任何依赖 gstreamer-player 的示例,您必须确保除了上述包之外,还需要安装 libgstreamer-plugins-bad1.0-dev。有关详细信息,请参阅 Cargo.toml 文件。

$ apt-get install libgstreamer-plugins-bad1.0-dev

其他发行版的包名应该类似。请提交一个带有您说明的 pull request。

macOS

您可以通过 Homebrew 或安装 GStreamer 项目提供的 二进制文件 来安装 GStreamer 和插件。

我们建议使用官方的 GStreamer 二进制文件而不是 Homebrew,尤其是由于 Homebrew 中的 GStreamer 目前 已损坏

GStreamer 二进制文件

您需要从 GStreamer 网站下载两个 .pkg 文件并安装它们,例如 gstreamer-1.0-1.20.4-universal.pkggstreamer-1.0-devel-1.20.4-universal.pkg

安装后,您还需要按以下方式设置环境变量 PATH

$ export PATH="/Library/Frameworks/GStreamer.framework/Versions/1.0/bin${PATH:+:$PATH}"

请注意,GStreamer 的 pkg-config 应该是 PATH 中的第一个,因为其他版本都有各种怪癖,会导致问题。

Homebrew

Homebrew 只在明确启用的情况下安装各种插件,因此可能需要一些额外的 --with-* 标志。

$ brew install gstreamer gst-plugins-base gst-plugins-good \
      gst-plugins-bad gst-plugins-ugly gst-libav gst-rtsp-server \
      gst-editing-services --with-orc --with-libogg --with-opus \
      --with-pango --with-theora --with-libvorbis --with-libvpx \
      --enable-gtk3

确保这些库的版本 >= 1.14。

Windows

您可以通过 MSYS2 使用 pacman 或通过安装 GStreamer 项目提供的 二进制文件 来安装 GStreamer 和插件。

我们建议使用官方的 GStreamer 二进制文件而不是 MSYS2。

GStreamer 二进制文件

您需要从 GStreamer 网站下载适合您平台的两个 .msi 文件并安装它们,例如 gstreamer-1.0-x86_64-1.20.4.msigstreamer-1.0-devel-1.20.4.msi。请确保选择与您的 Rust 工具链匹配的版本,即 MinGW 或 MSVC。

安装后设置环境变量 PATH 如下

# For a UNIX-style shell:
$ export PATH="c:/gstreamer/1.0/msvc_x86_64/bin${PATH:+:$PATH}"

# For cmd.exe:
$ set PATH=C:\gstreamer\1.0\msvc_x86_64\bin;%PATH%

请确保更新到您实际安装 GStreamer 和相应工具链的路径。

请注意,GStreamer 的 pkg-config.exe 应该是 PATH 中的第一个,因为其他版本都有各种怪癖,会导致问题。

MSYS2 / pacman

$ pacman -S glib2-devel pkg-config \
      mingw-w64-x86_64-gstreamer mingw-w64-x86_64-gst-plugins-base \
      mingw-w64-x86_64-gst-plugins-good mingw-w64-x86_64-gst-plugins-bad \
      mingw-w64-x86_64-gst-plugins-ugly mingw-w64-x86_64-gst-libav \
      mingw-w64-x86_64-gst-rtsp-server

确保这些库的版本 >= 1.14。

请注意,MSYS2中包含的pkg-config版本存在已知问题,无法编译GStreamer,因此您可能需要安装另一个版本。一个选项是pkg-config-lite

入门

API参考可以在这里找到,但这仅是Rust API参考,并不解释任何概念。

要开始GStreamer开发,最好的方法是遵循GStreamer网站上的文档,特别是应用开发手册。虽然以C语言为中心,但它解释了GStreamer的所有基本概念,并且代码示例应该可以相对容易地转换为Rust。API基本上是相同的,函数/结构体名称相同,并且所有东西都更加方便(希望如此)且更安全。

此外,GStreamer网站上还有教程。其中许多已经被移植到Rust,代码可以在教程目录中找到。

有关GStreamer的各个方面以及如何从Rust使用它的更多示例可以在示例目录中找到。

gst-plugins-rs存储库中可以找到用Rust编写的各种GStreamer插件。

许可协议

gstreamer-rs和此处包含的所有crates都受以下任一许可协议的许可:

任选其一。

GStreamer本身根据Lesser General Public License version 2.1许可,或者(根据您的选择)任何后续版本:https://www.gnu.org/licenses/lgpl-2.1.html

贡献

欢迎以拉取请求的形式提交各种类型的贡献。

除非您明确声明,否则根据Apache-2.0许可协议定义的您提交给gstreamer-rs的任何有意提交的贡献,都应按上述方式双许可,无需附加条款或条件。

依赖关系

~8.5MB
~184K SLoC