256 lines
11 KiB
Markdown
256 lines
11 KiB
Markdown

|
|
|
|
     [](https://www.paypal.me/stax76)
|
|
|
|
# 🎞 mpv.net
|
|
|
|
mpv.net is a modern media player for Windows that works just like [mpv](https://mpv.io).
|
|
|
|
#### Based on libmpv
|
|
|
|
mpv.net is based on libmpv which offers a straightforward C API that was designed from the ground up to make mpv usable as a library and facilitate easy integration into other applications. mpv is like vlc not based on DirectShow or Media Foundation.
|
|
|
|
#### Command Line Interface
|
|
|
|
mpv.net has the [CLI of mpv](https://mpv.io/manual/master/#options).
|
|
|
|
#### High quality video output
|
|
|
|
libmpv has an OpenGL based video output that is capable of many features loved by videophiles, such as video scaling with popular high quality algorithms, color management, frame timing, interpolation, HDR, and more.
|
|
|
|
#### On Screen Controller
|
|
|
|
The OSC of libmpv offers play controls with a modern flat design. ([Screenshot](#main-window-screenshot))
|
|
|
|
#### GPU video decoding
|
|
|
|
libmpv leverages the FFmpeg hwaccel APIs to support DXVA2 video decoding acceleration.
|
|
|
|
#### Active development
|
|
|
|
mpv.net is under active development. Want a feature? Post a [patch](https://github.com/stax76/mpv.net/pulls) or [request it](https://github.com/stax76/mpv.net/issues)!
|
|
|
|
Table of contents
|
|
-----------------
|
|
|
|
- [Features](#features)
|
|
- [Screenshots](#screenshots)
|
|
- [Manual](#manual)
|
|
- [Context Menu](#context-menu)
|
|
- [Settings](#settings)
|
|
- [Scripting](#scripting)
|
|
- [Extensions](#extensions)
|
|
- [Architecture](#architecture)
|
|
- [Support](#support)
|
|
- [Links](#links)
|
|
- [Changelog](#changelog)
|
|
- [Download](#download)
|
|
|
|
### Features
|
|
|
|
- Very high degree of mpv compatibility, almost all mpv features are available
|
|
- Great usability due to everything in the application being searchable
|
|
- Open source built with modern tools
|
|
- Customizable context menu defined in the same file as the key bindings ([Screenshot](#context-menu-screenshot), [Defaults](https://github.com/stax76/mpv.net/blob/master/mpv.net/Resources/inputConf.txt))
|
|
- Searchable config dialog ([Screenshot](#config-editor-screenshot), [Defaults](https://github.com/stax76/mpv.net/blob/master/mpv.net/Resources/mpvConf.txt))
|
|
- Searchable input (key/mouse) binding editor ([Screenshot](#input-editor-screenshot), [Defaults](https://github.com/stax76/mpv.net/blob/master/mpv.net/Resources/inputConf.txt))
|
|
- Configuration files that are easy to read and edit
|
|
- Searchable command palette to quickly launch commands and look for keys ([Screenshot](#command-palette-screenshot))
|
|
- Modern WPF based graphical user interface with dark mode ([Screenshot](#config-editor-screenshot))
|
|
- Extension API for .NET languages
|
|
- Scripting API for Python, C#, Lua, JavaScript and PowerShell ([Wiki](https://github.com/stax76/mpv.net/wiki/Scripting))
|
|
- Language agnostic JSON IPC to control the player with a external programs
|
|
- On Screen Controler (OSC, play control buttons)
|
|
- [Command Line Interface](https://mpv.io/manual/master/#options)
|
|
- If started from a PowerShell terminal mpv.net will attach to the terminal and print status and debug output
|
|
- DXVA2 video decoding acceleration
|
|
- OpenGL based video output capable of features loved by videophiles, such as video scaling with popular high quality algorithms, color management, frame timing, interpolation, HDR, and more
|
|
- Search feature powered by [Everything](https://www.voidtools.com) to find and play media ([Screenshot](#media-search-screenshot))
|
|
- Extension to start mpv.net from Google Chrome ([Manual](Manual.md#chrome-extension))
|
|
- Extremely fast seek performance
|
|
- Very fast startup performance, video is usally ready to play in less then a second
|
|
- Usable as video player, audio player and image viewer with a wide range of supported formats
|
|
- All decoders are built-in, no external codecs have to be installed
|
|
- Setup and portable download options, setup is recommended but not required
|
|
- Build-in media streaming via youtube-dl
|
|
- x64 and x86 Support (64-bit and 32-bit)
|
|
- File associations can be created by the setup and from the player
|
|
- External audio and subtitle files can either be loaded manually or automatically
|
|
- Screenshot feature with many options
|
|
- File history feature to log time and filename
|
|
- A-B loop feature
|
|
- watch later feature to save the position
|
|
- [Manual](#manual)
|
|
|
|
### Screenshots
|
|
|
|
#### Main Window Screenshot
|
|
|
|

|
|
|
|
#### Context Menu Screenshot
|
|
|
|
Context menu defined in the input.conf file with dark mode support.
|
|
|
|

|
|
|
|
#### Config Editor Screenshot
|
|
|
|
A searchable config editor as alternative to edit the mpv.conf file manually.
|
|
|
|

|
|
|
|
#### Input Editor Screenshot
|
|
|
|
A searchable key and mouse binding editor.
|
|
|
|

|
|
|
|
#### Command Palette Screenshot
|
|
|
|
Forgot where a command in the menu is located or what shortcut key it has?
|
|
Just press F1 and find it easily in the searchable command palette.
|
|
|
|

|
|
|
|
#### Media Search Screenshot
|
|
|
|
Media search feature powered by [Everything](https://www.voidtools.com) to find and play media.
|
|
|
|

|
|
|
|
### Manual
|
|
|
|
[Manual](Manual.md)
|
|
|
|
### Context Menu
|
|
|
|
The context menu can be customized via input.conf file located in the config directory:
|
|
|
|
```Text
|
|
C:\Users\%username%\AppData\Roaming\mpv\input.conf
|
|
```
|
|
|
|
if it's missing mpv.net generates it with the following defaults:
|
|
|
|
<https://github.com/stax76/mpv.net/blob/master/mpv.net/Resources/inputConf.txt>
|
|
|
|
input.conf defines mpv's key and mouse bindings and mpv.net uses comments to define the context menu.
|
|
|
|
### Settings
|
|
|
|
When mpv.net finds no config folder on startup it will ask for a location.
|
|
|
|
If a folder named portable_config next to the mpvnet.exe exists,
|
|
all config will be loaded from this folder only.
|
|
|
|
```Text
|
|
<startup>\portable_config\
|
|
```
|
|
|
|
mpv specific settings are stored in the file mpv.conf, if no mpv.conf file exists
|
|
mpv.net generates it with the following defaults:
|
|
|
|
<https://github.com/stax76/mpv.net/blob/master/mpv.net/Resources/mpvConf.txt>
|
|
|
|
mpv.net specific settings are stored in the file mpvnet.conf
|
|
|
|
The input (key/mouse) bindings and the context menu definitions are stored in the
|
|
input.conf file, if it's missing mpv.net generates it with the following defaults:
|
|
|
|
<https://github.com/stax76/mpv.net/blob/master/mpv.net/Resources/inputConf.txt>
|
|
|
|
mpv.net supports almost all mpv settings and features,
|
|
[limitations are listed in the wiki](https://github.com/stax76/mpv.net/wiki/Limitations).
|
|
|
|
The config folder can be opened from the context menu.
|
|
|
|
### Scripting
|
|
|
|
[Scripting wiki page](https://github.com/stax76/mpv.net/wiki/Scripting)
|
|
|
|
### Extensions
|
|
|
|
[Extensions wiki page](https://github.com/stax76/mpv.net/wiki/Extensions)
|
|
|
|
### Architecture
|
|
|
|
Coding mpv.net was great fun because libmpv is such a awesome
|
|
library with a very clever design, I'm having a great experience
|
|
with libmpv.
|
|
|
|
The player does not contain any feature that was more work than 1-2 days or
|
|
was difficult to build, the hard parts are totally covered by libmpv.
|
|
|
|
mpv.net is written in C# 7 and runs on .NET 4.7, I've not yet decided
|
|
if I will port it to C# 8 and .NET 5 once available.
|
|
|
|
The Extension implementation is based on the [Managed Extensibility Framework](https://docs.microsoft.com/en-us/dotnet/framework/mef/).
|
|
|
|
There are no specific extension or scripting interfaces but instead everyting
|
|
is accessible for .NET compatible languages (C#, VB.NET, F#, Python, PowerShell),
|
|
this decision was made to keep the code simple and lightweight.
|
|
|
|
Python scripting is implemented with IronPython which uses Python 2.7.
|
|
|
|
The main window is WinForms based and uses less than 600 lines of code,
|
|
all other windows are WPF based and use even less code.
|
|
|
|
The config editor adds it's controls dynamically and uses [TOML](https://en.wikipedia.org/wiki/TOML) to define it's
|
|
content, there are only two simple types, StringSetting and OptionSetting.
|
|
|
|
mpv.net was started 2017 and consists of about 6000 lines of code and markup.
|
|
|
|
IDE, Editor: Visual Studio, Visual Studio Code.
|
|
|
|
Due to mpv.net being my first WPF app and mpv.net never meant to be a large
|
|
application best practices and design pattern are not always applied.
|
|
|
|
Third party components:
|
|
|
|
- [libmpv, the heard and soul of mpv.net](https://mpv.io/)
|
|
- [MediaInfo, no media related project could do without](https://mediaarea.net/en/MediaInfo)
|
|
- [Tommy, a single file TOML parser](https://github.com/dezhidki/Tommy)
|
|
- [IronPython, bringing Python to dotnet](https://ironpython.net/)
|
|
- [CS-Script, scripting with C#](http://www.csscript.net/)
|
|
- [Everything, a blazing fast file search service](https://www.voidtools.com)
|
|
|
|
### Support
|
|
|
|
[Support thread in Doom9 forum](https://forum.doom9.org/showthread.php?t=174841)
|
|
|
|
[Support thread in VideoHelp forum](https://forum.videohelp.com/threads/392514-mpv-net-a-extendable-media-player-for-windows)
|
|
|
|
[Issue tracker](https://github.com/stax76/mpv.net/issues), feel free to use for anything mpv.net related
|
|
|
|
[frank.skare.de@gmail.com](mailto:frank.skare.de@gmail.com?Subject=mpv.net%20support)
|
|
|
|
Please click on the star at the top of the page and like mpv.net at [alternativeto.net](https://alternativeto.net/software/mpv-net/).
|
|
|
|
If you want to support the development of mpv.net or express your appreciation you can do so with a donation:
|
|
|
|
<https://www.paypal.me/stax76>
|
|
|
|
### Links
|
|
|
|
- mpv.net wiki: <https://github.com/stax76/mpv.net/wiki>
|
|
- mpv.net default key bindings: <https://github.com/stax76/mpv.net/blob/master/mpv.net/Resources/inputConf.txt>
|
|
- mpv.net download: <https://github.com/stax76/mpv.net/releases>
|
|
- mpv.net bugs and requests: <https://github.com/stax76/mpv.net/issues>
|
|
- mpv website: <https://mpv.io/>
|
|
- mpv manual: <https://mpv.io/manual/master/>
|
|
- mpv wiki: <https://github.com/mpv-player/mpv/wiki>
|
|
- mpv apps: <https://github.com/mpv-player/mpv/wiki/Applications-using-mpv>
|
|
- mpv user scripts: <https://github.com/mpv-player/mpv/wiki/User-Scripts>
|
|
- mpv default key bindings: <https://github.com/mpv-player/mpv/blob/master/etc/input.conf>
|
|
- mpv download: <https://mpv.io/installation/>
|
|
- mpv bugs and requests: <https://mpv.io/bug-reports/>
|
|
|
|
### Changelog
|
|
|
|
[Changelog](Changelog.md)
|
|
|
|
### Download
|
|
|
|
<https://github.com/stax76/mpv.net/releases>
|