mpv 0.2.2

safe mpv bindings for Rust
Documentation

mpv-rs

safe libmpv bindings for Rust.

mpv is a media player based on MPlayer and mplayer2. It supports a wide variety of video file formats, audio and video codecs, and subtitle types.

The crate is a safe libmpv API binding in Rust. For more info about mpv, see here.

Online documentation for version 0.2.1 (19 July 2016) of this crate is available at this location

If the documentation is outdated and/or the crate is outdated (major changes to master), please submit an issue.

Installing

[dependencies]
mpv = "0.2"

the mpv package is needed for this to run.

Linux

On linux, you can ask your package manager to install it for you.

Arch

# pacman -S mpv

Debian-based systems

# apt-get install libmpv1

Windows

libmpv can be found here for windows. You need to copy the library into your rust binaries folder for it to be linked properly.

Running

2 examples are available from the get go in this crate.

simple.rs will alow you to display a standard mpv player in a new window. Controls will be available.

$ cargo run --example simple

sdl2.rs will embed mpv in an sdl2 window. Controls will not be available and cannot be. If you want an interface on top of this player, you must draw your own with OpenGL calls or SDL2 calls.

$ cargo run --example sdl2

Contributing

Any contribution is welcome, as well as any code review !

What is left to implement

Events :

Formats :

MpvHandler impls :

  • resume / suspend core (not pause/unpause !)
  • load_config_file
  • detach_destroy (if only I knew what this was for ?)
  • client_name
  • set_wakeup_callback
  • get_wakeup_pipe
  • request_log_messages
  • request_event

MpvHandlerWithGl impls :

API breaks and version numbers

  • Minor beta changes (0.X.0) -> (0.X.1) are non-breaking changes.
  • Major beta changes (0.1.X) -> (0.2.0) will probably break the API.
  • Once this binding is finished, this crate will be released as 1.0.0

Submitting an issue

Any question concerning the mpv-rs API is welcome in the issues.

If your mpv crashes, please make sure it's coming from this Rust binding and not from the mpv player itself.

License

mpv is globally licensed under GPLv2+ (see here), but this crate is licensed under the zlib license.

Relicensing is possible if it can be properly justified for whatever reason.