Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Lensual/go-libav
[WIP] Golang binding for FFmpeg and libav
https://github.com/Lensual/go-libav
ffmpeg libav libavcodec libavformat libavutil
Last synced: about 1 month ago
JSON representation
[WIP] Golang binding for FFmpeg and libav
- Host: GitHub
- URL: https://github.com/Lensual/go-libav
- Owner: Lensual
- License: lgpl-2.1
- Created: 2021-09-17T07:01:56.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-01-21T19:51:19.000Z (12 months ago)
- Last Synced: 2024-08-07T23:47:26.281Z (5 months ago)
- Topics: ffmpeg, libav, libavcodec, libavformat, libavutil
- Language: Go
- Homepage:
- Size: 439 KB
- Stars: 11
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# go-libav
[![Go Reference](https://pkg.go.dev/badge/github.com/Lensual/go-libav.svg)](https://pkg.go.dev/github.com/Lensual/go-libav)
![GitHub release (with filter)](https://img.shields.io/github/v/release/Lensual/go-libav?include_prereleases&color=blue)
![GitHub go.mod Go version (subdirectory of monorepo)](https://img.shields.io/github/go-mod/go-version/Lensual/go-libav)
![Static Badge](https://img.shields.io/github/license/Lensual/go-libav)
[![Go Report Card](https://goreportcard.com/badge/github.com/Lensual/go-libav)](https://goreportcard.com/report/github.com/Lensual/go-libav)
![Static Badge](https://img.shields.io/badge/FFmpeg_version-6.1-purple)[English](./README.md) | [中文](./README_zh.md)
Golang binding for [FFmpeg and libav](https://ffmpeg.org/).
## Things to know
1. This package is implemented using CGO and requires FFmpeg's header files and libraries for compilation.
2. Due to well-known performance issues with CGO calls, it is recommended to use C/CPP to achieve your needs.## Getting Started
Package `go-libav/av*` are cgo bindings. Before using this package, you'd better to master the basic usage of the FFmpeg library.
Package `golibav/advance` is a secondary package to simplify use in go.
Need Golang version `1.21` and FFmpeg library version `6.1`.
Set your environment variable if your library is not in the default directory.
```env
# using pkg-config
PKG_CONFIG_PATH="/ffmpeg/lib/pkgconfig"# or set compiler flags
CGO_LDFLAGS="-L/ffmpeg/lib -lavcodec -lavdevice -lavfilter -lavformat -lavutil -lswresample -lswscale"
CGO_CFLAGS="-I/ffmpeg/include"
```## Examples
Check [advance/example](./advance/example) directory.
Try examples With Docker
```bash
# Run container with Debian 13 (trixie).
sudo docker run --rm -it debian:trixie
# Install development environment.
apt install golang git
# Clone project.
git clone https://github.com/Lensual/go-libav
# Install FFmpeg development libraries.
apt install libavcodec-dev libavdevice-dev libavfilter-dev libavformat-dev libavutil-dev libswresample-dev libswscale-dev
# Build example like 'mux' and then run iut.
cd go-libav/example/mux
go build .
./mux ./test.mp4
```## License
[GNU Lesser General Public License version 2.1](./LICENSE)